add-rcpp-integration
정보
이 Claude Skill은 개발자들이 R 패키지에 고성능 C++ 코드를 추가하기 위해 Rcpp 또는 RcppArmadillo를 통합하는 데 도움을 줍니다. 설정, 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-integrationClaude Code에서 이 명령을 복사하여 붙여넣어 스킬을 설치하세요
문서
name: add-rcpp-integration description: > Rcpp- oder RcppArmadillo-Integration zu einem R-Paket fuer hochperformanten C++-Code hinzufuegen. Behandelt Einrichtung, Schreiben von C++-Funktionen, RcppExports-Generierung, Tests fuer kompilierten Code und Debugging. Verwenden, wenn eine R-Funktion zu langsam ist und Profiling einen Engpass bestaetigt, wenn eine Schnittstelle zu bestehenden C/C++-Bibliotheken benoetigt wird, oder beim Implementieren von Algorithmen (Schleifen, Rekursion, lineare Algebra), die von kompiliertem Code profitieren. locale: de source_locale: en source_commit: 6f65f316 translator: claude-opus-4-6 translation_date: 2026-03-16 license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: r-packages complexity: advanced language: R tags: r, rcpp, cpp, performance, compiled-code
Rcpp-Integration hinzufuegen
C++-Code mit Rcpp fuer leistungskritische Operationen in ein R-Paket integrieren.
Wann verwenden
- R-Funktion ist zu langsam und Profiling bestaetigt einen Engpass
- Schnittstelle zu bestehenden C/C++-Bibliotheken wird benoetigt
- Algorithmen implementieren, die von kompiliertem Code profitieren (Schleifen, Rekursion)
- RcppArmadillo fuer lineare Algebra-Operationen hinzufuegen
Eingaben
- Erforderlich: Bestehendes R-Paket
- Erforderlich: Zu ersetzende oder zu ergaenzende R-Funktion durch C++
- Optional: Externe C++-Bibliothek fuer die Schnittstelle
- Optional: Ob RcppArmadillo verwendet werden soll (Standard: einfaches Rcpp)
Vorgehensweise
Schritt 1: Rcpp-Infrastruktur einrichten
usethis::use_rcpp()
Dies:
- Erstellt
src/-Verzeichnis - Fuegt
Rcppzu LinkingTo und Imports in DESCRIPTION hinzu - Erstellt
R/packagename-package.Rmit@useDynLibund@importFrom Rcpp sourceCpp - Aktualisiert
.gitignorefuer kompilierte Dateien
Fuer RcppArmadillo:
usethis::use_rcpp_armadillo()
Erwartet: src/-Verzeichnis erstellt, DESCRIPTION mit Rcpp in LinkingTo und Imports aktualisiert, und R/packagename-package.R enthaelt @useDynLib-Direktive.
Bei Fehler: Wenn usethis::use_rcpp() fehlschlaegt, manuell src/ erstellen, LinkingTo: Rcpp und Imports: Rcpp zu DESCRIPTION hinzufuegen und #' @useDynLib packagename, .registration = TRUE sowie #' @importFrom Rcpp sourceCpp zur Paket-Level-Dokumentationsdatei hinzufuegen.
Schritt 2: C++-Funktion schreiben
src/my_function.cpp erstellen:
#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;
}
Fuer 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;
}
Erwartet: C++-Quelldatei existiert unter src/my_function.cpp mit gueltiger // [[Rcpp::export]]-Annotation und Roxygen-artigen //'-Dokumentationskommentaren.
Bei Fehler: Pruefen, ob die Datei #include <Rcpp.h> (oder <RcppArmadillo.h> fuer Armadillo) verwendet, dass die Export-Annotation in einer eigenen Zeile direkt oberhalb der Funktionssignatur steht und die Rueckgabetypen auf gueltige Rcpp-Typen abgebildet sind.
Schritt 3: RcppExports generieren
Rcpp::compileAttributes()
devtools::document()
Erwartet: R/RcppExports.R und src/RcppExports.cpp automatisch generiert.
Bei Fehler: Auf C++-Syntaxfehler pruefen. Sicherstellen, dass das // [[Rcpp::export]]-Tag oberhalb jeder exportierten Funktion vorhanden ist.
Schritt 4: Kompilierung verifizieren
devtools::load_all()
Erwartet: Paket kompiliert und wird ohne Fehler geladen.
Bei Fehler: Compiler-Ausgabe auf Fehler pruefen. Haeufige Probleme:
- Fehlende System-Header: Entwicklungsbibliotheken installieren
- Syntaxfehler: C++-Compiler-Meldungen zeigen auf die Zeile
- Fehlendes
Rcpp::depends-Attribut fuer RcppArmadillo
Schritt 5: Tests fuer kompilierten Code schreiben
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_))
})
Erwartet: Tests bestehen und bestaetigen, dass die C++-Funktion identische Ergebnisse wie das R-Aequivalent liefert und Grenzfaelle (leere Vektoren, NA-Werte) korrekt behandelt.
Bei Fehler: Wenn Tests bei der NA-Behandlung fehlschlagen, explizite NA-Pruefungen im C++-Code mit NumericVector::is_na() hinzufuegen. Wenn Tests bei leerer Eingabe fehlschlagen, am Anfang der Funktion eine Schutzklausel fuer Vektoren der Laenge Null hinzufuegen.
Schritt 6: Bereinigungsskript hinzufuegen
src/Makevars erstellen:
PKG_CXXFLAGS = -O2
cleanup im Paketstammverzeichnis erstellen (fuer CRAN):
#!/bin/sh
rm -f src/*.o src/*.so src/*.dll
Ausfuehrbar machen: chmod +x cleanup
Erwartet: src/Makevars setzt Compiler-Flags und das cleanup-Skript entfernt kompilierte Objekte. Beide Dateien existieren auf Paketstamm-Ebene.
Bei Fehler: Pruefen, ob cleanup Ausfuehrungs-Berechtigungen hat (chmod +x cleanup) und dass Makevars Tabs (keine Leerzeichen) fuer Einrueckungen verwendet, wenn Makefile-Regeln hinzugefuegt werden.
Schritt 7: .Rbuildignore aktualisieren
Sicherstellen, dass kompilierte Artefakte korrekt behandelt werden:
^src/.*\.o$
^src/.*\.so$
^src/.*\.dll$
Erwartet: .Rbuildignore-Muster verhindern, dass kompilierte Objektdateien in das Paket-Tarball aufgenommen werden, waehrend Quelldateien und Makevars erhalten bleiben.
Bei Fehler: devtools::check() ausfuehren und nach Hinweisen zu unerwarteten Dateien in src/ suchen. .Rbuildignore-Muster anpassen, um nur .o-, .so- und .dll-Dateien auszuschliessen.
Validierung
-
devtools::load_all()kompiliert ohne Warnungen - Kompilierte Funktion liefert korrekte Ergebnisse
- Tests bestehen fuer Grenzfaelle (NA, leer, grosse Eingaben)
-
R CMD checkbesteht ohne Kompilierungswarnungen - RcppExports-Dateien sind generiert und eingecheckt
- Leistungsverbesserung mit Benchmarks bestaetigt
Haeufige Stolperfallen
compileAttributes()vergessen: RcppExports nach Aenderungen an C++-Dateien neu generieren- Integer-Ueberlauf:
doublestattintfuer grosse numerische Werte verwenden - Speicherverwaltung: Rcpp verwaltet Speicher fuer Rcpp-Typen automatisch; nicht manuell
deleteaufrufen - NA-Behandlung: C++ kennt Rs NA nicht. Mit
Rcpp::NumericVector::is_na()pruefen - Plattformportabilitaet: Plattformspezifische C++-Funktionen vermeiden. Auf Windows, macOS und Linux testen.
- Fehlendes
@useDynLib: Die Paket-Level-Dokumentation muss@useDynLib packagename, .registration = TRUEenthalten
Verwandte Skills
create-r-package- Paketeinrichtung vor dem Hinzufuegen von Rcppwrite-testthat-tests- kompilierte Funktionen testensetup-github-actions-ci- CI muss C++-Toolchain habensubmit-to-cran- kompilierte Pakete benoetigen zusaetzliche CRAN-Pruefungen
GitHub 저장소
연관 스킬
evaluating-llms-harness
테스팅이 Claude Skill은 MMLU, GSM8K를 포함한 60개 이상의 표준화된 학술 과제에서 LLM 성능을 벤치마크하기 위해 lm-evaluation-harness를 실행합니다. 개발자들이 모델 품질을 비교하고, 학습 진행 상황을 추적하거나 학술 결과를 보고할 수 있도록 설계되었습니다. 이 도구는 HuggingFace와 vLLM 모델을 포함한 다양한 백엔드를 지원합니다.
cloudflare-cron-triggers
테스팅이 스킬은 cron 표현식을 사용하여 Worker를 스케줄링하기 위한 Cloudflare Cron Triggers 구현에 관한 포괄적인 지식을 제공합니다. 주기적 작업, 유지보수 작업, 자동화된 워크플로우 설정 방법을 다루며, 잘못된 cron 표현식이나 시간대 문제 같은 일반적인 이슈들을 해결하는 방법을 포함합니다. 개발자들은 이를 통해 스케줄된 핸들러 구성, cron 트리거 테스트, Workflows 및 Green Compute와의 연동 작업을 수행할 수 있습니다.
webapp-testing
테스팅이 Claude Skill은 Python 스크립트를 통해 로컬 웹 애플리케이션을 테스트하기 위한 Playwright 기반 툴킷을 제공합니다. 프론트엔드 검증, UI 디버깅, 스크린샷 캡처, 로그 확인 기능을 지원하며 서버 라이프사이클을 관리합니다. 브라우저 자동화 작업에 사용하되 컨텍스트 오염을 방지하기 위해 소스 코드를 읽지 않고 스크립트를 직접 실행하세요.
finishing-a-development-branch
테스팅이 스킬은 테스트 통과를 확인한 후 체계적인 통합 옵션을 제시하여 개발자가 완성된 작업을 마무리하도록 돕습니다. 구현이 완료된 후 머지, PR 생성, 브랜치 정리와 같은 워크플로우를 안내합니다. 코드가 준비되고 테스트가 완료되었을 때 개발 프로세스를 체계적으로 마무리하기 위해 사용하세요.
