2 stable releases
1.1.0 | Apr 29, 2024 |
---|---|
1.0.0 | Apr 23, 2024 |
#515 in Math
53 downloads per month
170KB
4.5K
SLoC
rmathlib
A Rust port of R's C Library of Special Functions.
Benefits
Some benefits of this port over the native C code are:
- Support
wasm32-unknown-unknown
target (avoiding emscripten). - Clearer documentation with the help of
cargo doc
. - Easier to read thanks to
cargo fmt
. - Enables Go To Definition (code navigation) when loading this package as a dependency.
- More clarity about the used compiler and supported Rust versions.
Status
The following functions have been ported:
Distribution | Density | Probability | Quantile | Random Generation |
---|---|---|---|---|
Normal | dnorm |
pnorm |
qnorm |
|
Student's t | dt |
pt , pnt |
||
Beta | pbeta |
|||
Poisson | dpois |
|||
Gamma | dgamma |
pgamma |
License
The original R code is licensed under the GPL-2.0. Therefore, this port is also licensed under the GPL-2.0.
The GPL-2.0 is known to be a very restrictive license. Each project that includes GPL-2.0 code should also be licensed under the GPL-2.0 ( One exception to this restriction is to use this library only for a small part of the functionality of your project (see, e.g., here). In such cases, your project would be considered not to be a "derivative work" and therefore not subject to the GPL-2.0.
Developer Notes
Some tips for debugging the C code in test/nmath/
:
To print from C, set
std::env::set_var("CFLAGS", "-DDEBUG_bratio");
and use --nocapture
like so:
$ cargo watch -x 'test -- --nocapture'
When printing inside C, verify that that the numbers are printed correctly.
REprintf
seems to not always print numbers correctly.
To fix that, REprintf
can just be replaced with printf
(and some \n
's).
For example, test the representation via:
double tmp = 1.2;
REprintf("from c: x=%g\n", x);
or
#include <stdio.h>
double tmp = 1.2;
printf("from c: x=%g\n", x);
Dependencies
~390KB