2 releases
0.1.1 | Feb 12, 2024 |
---|---|
0.1.0 | Feb 9, 2024 |
#367 in Graphics APIs
84KB
2K
SLoC
Welcome to FerriLab!
This library allows you to process data from a physics laboratory, make calculations between measures and plot figures.
Usage
FerriLab
is based in the object [Measure], used to store either
the value and the error of a measure. To make it easy to create a new measure
the [measure] macro let you introduce data on various formats.
The object measure has all operations implemented between measures and numbers along with the basic math functions you may need for processing your data.
With every operation applied to a measure, the error will be modified following error propagation. Also a measure can be aproximated to the first significative figure of the error.
use ferrilab::{measure, Measure};
let time = measure!([0.227, 0.312, 0.4019, 0.512], [0.012, 0.023, 0.025, 0.048]);
let position = measure!([2.425, 3.41515, 5.13545, 7.24524], [0.2, 0.43, 0.544, 0.872]; true);
let speed = &position / &time; // Using reference allows position and time to still be used.
let angle_grads = measure!([0, 30, 45, 60, 90, 180], [0.01, 3, 4, 5.8, 7, 11.6]);
let angle_rad = angle_grads.rad(); // Transform grades to radians.
let cosine = angle_rad.cos(); // Calculates the cosine of angles.
Dependencies
~3.5–9MB
~89K SLoC