R-friendly multi-threading in c++

0Citations
Citations of this article
23Readers
Mendeley users who have this article in their library.
Get full text

Abstract

Calling multi-threaded C++ code from R has its perils. Since the R interpreter is single-threaded, one must not check for user interruptions or print to the R console from multiple threads. One can, however, synchronize with R from the main thread. The R package RcppThread (current version 1.0.0) contains a header only C++ library for thread safe communication with R that exploits this fact. It includes C++ classes for threads, a thread pool, and parallel loops that routinely synchronize with R. This article explains the package’s functionality and gives examples of its usage. The synchronization mechanism may also apply to other threading frameworks. Benchmarks suggest that, although synchronization causes overhead, the parallel abstractions of RcppThread are competitive with other popular libraries in typical scenarios encountered in statistical computing.

Author supplied keywords

Cite

CITATION STYLE

APA

Nagler, T. (2021). R-friendly multi-threading in c++. Journal of Statistical Software, 97(1), 1–18. https://doi.org/10.18637/JSS.V097.C01

Register to see more suggestions

Mendeley helps you to discover research relevant for your work.

Already have an account?

Save time finding and organizing research with Mendeley

Sign up for free