add-rcpp-integration
О программе
Этот навык интегрирует Rcpp или RcppArmadillo в R-пакет для замены критичных к производительности R-функций на высокопроизводительный код на C++. Он охватывает полный рабочий процесс: от настройки и написания функций на C++ до генерации RcppExports, тестирования и отладки. Используйте его, когда профилирование подтверждает узкое место в R, при взаимодействии с существующими библиотеками на C/C++ или при реализации алгоритмов (например, циклов и линейной алгебры), выигрывающих от компиляции.
Быстрая установка
Claude Code
Рекомендуетсяnpx skills add pjt222/agent-almanac -a claude-code/plugin add https://github.com/pjt222/agent-almanacgit clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/add-rcpp-integrationСкопируйте и вставьте эту команду в Claude Code для установки этого навыка
Документация
Add Rcpp Integration
Integrate C++ into R pkg via Rcpp → perf-critical ops.
Use When
- R fn too slow, profile confirms bottleneck
- Interface existing C/C++ libs
- Algos benefit compiled (loops, recursion)
- RcppArmadillo → linear algebra
In
- Required: Existing R pkg
- Required: R fn to replace/augment w/ C++
- Optional: External C++ lib
- Optional: RcppArmadillo? (default: plain Rcpp)
Do
Step 1: Rcpp Infra Setup
usethis::use_rcpp()
Does:
- Creates
src/dir - Adds
Rcpp→ LinkingTo + Imports in DESCRIPTION - Creates
R/packagename-package.Rw/@useDynLib+@importFrom Rcpp sourceCpp - Updates
.gitignorefor compiled
RcppArmadillo:
usethis::use_rcpp_armadillo()
→ src/ created, DESCRIPTION updated Rcpp LinkingTo + Imports, R/packagename-package.R has @useDynLib.
If err: usethis::use_rcpp() fails → manually create src/, add LinkingTo: Rcpp + Imports: Rcpp, add #' @useDynLib packagename, .registration = TRUE + #' @importFrom Rcpp sourceCpp to pkg doc file.
Step 2: Write C++ Fn
Create src/my_function.cpp:
#include <Rcpp.h>
using namespace Rcpp;
//' Compute cumulative sum efficiently
//'
//' @param x A numeric vector
//' @return A numeric vector of cumulative sums
//' @export
// [[Rcpp::export]]
NumericVector cumsum_cpp(NumericVector x) {
int n = x.size();
NumericVector out(n);
out[0] = x[0];
for (int i = 1; i < n; i++) {
out[i] = out[i - 1] + x[i];
}
return out;
}
RcppArmadillo:
#include <RcppArmadillo.h>
// [[Rcpp::depends(RcppArmadillo)]]
//' Matrix multiplication using Armadillo
//'
//' @param A A numeric matrix
//' @param B A numeric matrix
//' @return The matrix product A * B
//' @export
// [[Rcpp::export]]
arma::mat mat_mult(const arma::mat& A, const arma::mat& B) {
return A * B;
}
→ C++ src at src/my_function.cpp w/ valid // [[Rcpp::export]] + roxygen //' docs.
If err: Verify #include <Rcpp.h> (or <RcppArmadillo.h>), export annotation own line directly above signature, return types map valid Rcpp.
Step 3: Generate RcppExports
Rcpp::compileAttributes()
devtools::document()
→ R/RcppExports.R + src/RcppExports.cpp auto-generated.
If err: Check C++ syntax. Ensure // [[Rcpp::export]] above each exported fn.
Step 4: Verify Compilation
devtools::load_all()
→ Pkg compiles + loads no err.
If err: Check compiler out. Common:
- Missing system headers → install dev libs
- Syntax err → compiler msgs point to line
- Missing
Rcpp::dependsfor RcppArmadillo
Step 5: Tests for Compiled
test_that("cumsum_cpp matches base R", {
x <- c(1, 2, 3, 4, 5)
expect_equal(cumsum_cpp(x), cumsum(x))
})
test_that("cumsum_cpp handles edge cases", {
expect_equal(cumsum_cpp(numeric(0)), numeric(0))
expect_equal(cumsum_cpp(c(NA_real_, 1)), c(NA_real_, NA_real_))
})
→ Tests pass → C++ identical to R + edge cases (empty, NA) correct.
If err: NA fail → add explicit NA checks via NumericVector::is_na(). Empty fail → guard clause zero-length at top.
Step 6: Cleanup Script
Create src/Makevars:
PKG_CXXFLAGS = -O2
Create cleanup in pkg root (CRAN):
#!/bin/sh
rm -f src/*.o src/*.so src/*.dll
Make executable: chmod +x cleanup
→ src/Makevars sets compiler flags, cleanup removes objects. Both at pkg root.
If err: Verify cleanup has exec perms (chmod +x cleanup), Makevars tabs (not spaces) for Makefile rules.
Step 7: Update .Rbuildignore
Handle compiled artifacts:
^src/.*\.o$
^src/.*\.so$
^src/.*\.dll$
→ .Rbuildignore patterns prevent compiled objects in tarball, preserve src + Makevars.
If err: devtools::check() → NOTEs about unexpected files in src/. Adjust patterns → exclude only .o, .so, .dll.
Check
-
devtools::load_all()compiles no warn - Compiled fn produces correct results
- Tests pass edge cases (NA, empty, large)
-
R CMD checkpasses no compile warn - RcppExports generated + committed
- Perf improvement via benchmarks
Traps
- Forget
compileAttributes(): Must regen RcppExports after C++ changes - Int overflow:
doublenotintfor large numerics - Memory mgmt: Rcpp auto-handles for Rcpp types; no manual
delete - NA handling: C++ doesn't know R's NA. Check
Rcpp::NumericVector::is_na() - Platform portability: Avoid platform-specific C++. Test Win, macOS, Linux.
- Missing
@useDynLib: Pkg doc must@useDynLib packagename, .registration = TRUE
→
create-r-package— pkg setup before Rcppwrite-testthat-tests— testing compiled fnssetup-github-actions-ci— CI needs C++ toolchainsubmit-to-cran— compiled pkgs need extra CRAN checks
GitHub репозиторий
Похожие навыки
content-collections
МетаЭтот навык предоставляет проверенную в продакшене настройку для Content Collections — TypeScript-ориентированного инструмента, который преобразует файлы Markdown/MDX в типобезопасные коллекции данных с валидацией Zod. Используйте его при создании блогов, сайтов документации или контентных приложений на Vite + React для обеспечения типобезопасности и автоматической проверки содержимого. Он охватывает всё: от настройки плагина Vite и компиляции MDX до оптимизации развертывания и валидации схем.
polymarket
МетаЭтот навык позволяет разработчикам создавать приложения на платформе прогнозных рынков Polymarket, включая интеграцию с API для торговли и получения рыночных данных. Он также обеспечивает потоковую передачу данных в реальном времени через WebSocket для отслеживания текущих сделок и рыночной активности. Используйте его для реализации торговых стратегий или создания инструментов, обрабатывающих обновления рынка в реальном времени.
creating-opencode-plugins
МетаЭтот навык помогает разработчикам создавать плагины OpenCode, которые подключаются к более чем 25 типам событий, таким как команды, файлы и операции LSP. Он предоставляет структуру плагина, спецификации API событий и шаблоны реализации для модулей на JavaScript/TypeScript. Используйте его, когда вам нужно перехватывать, отслеживать или расширять жизненный цикл ассистента OpenCode AI с помощью пользовательской событийно-ориентированной логики.
sglang
МетаSGLang — это высокопроизводительный фреймворк для обслуживания больших языковых моделей (LLM), специализирующийся на быстрой структурированной генерации JSON, regex и рабочих процессов агентов с использованием кэширования префиксов RadixAttention. Он обеспечивает значительно более высокую скорость вывода, особенно для задач с повторяющимися префиксами, что делает его идеальным для сложных структурированных результатов и многократных диалогов. Выбирайте SGLang вместо альтернатив, таких как vLLM, когда вам требуется ограниченное декодирование или вы создаете приложения с интенсивным совместным использованием префиксов.
