-
-
Notifications
You must be signed in to change notification settings - Fork 595
GSoC 2024 ‐ Gunj Joshi
Hello 👋. I am Gunj Joshi, from Banswara, Rajasthan, India. I am a pre-final year undergraduate at Indian Institute of Information Technology, Kottayam, Kerala, India. It has been an year since I started my open-source journey, and believe me, it has been a great ride! Apart from stdlib, my interests include mathematics (which might be evident from my GSoC project) and sports.
The goals of my project included adding C
implementations for various base special mathematical functions. Along with that, I also worked on adding single-precision variants for pre-existing functions. To achieve this, I followed certain reference implementations, some of which include:
The approach for developing a certain C implementation from the reference implementation to its stdlib equivalent included quite a few things, out of which some are as follows:
- Using a relevant
napi
function, in order to match the function signature.
For instance,binomcoef
, has the following signature:
double stdlib_base_binomcoef( const int64_t n, const int64_t k ) {
It takes in two 64-bit
integers, and gives a number of type double
as output.
In order to achieve this, I worked on adding LL_D
in math/base/napi/binary
, which was as follows:
napi_value stdlib_math_base_napi_ll_d( napi_env env, napi_callback_info info, double (*fcn)( double, int64_t, int64_t ) )
- Replacing certain functions used in reference implementations with their stdlib equivalents. For instance, replacing
scalbn
inFreeBSD
implementation forrempio2
byldexp
, which is the appropriate stdlib equivalent.
and a few more tweaks to follow the conventions used in stdlib.
In order to develop single-precision implementations, certain conventions and methods were followed, some of which include:
- Choosing an appropriate reference implementation.
- Modifying tests to suit single-precision calculations, along with changing the range of the test fixtures.
For example, Inmath/base/special/ln
, for testing subnormal inputs, we use the range as:
x = range( 1.0e-309, stop = 1.0e-312, length = 500 );
But, in math/base/special/lnf
, we use a smaller range, as it is only for single-precision values.
x = range( 1.0e-39, stop = 1.40129846e-45, length = 500 );
- Modifying the algorithm to align with single-precision arithmetic, whether it is casting expressions to
float32
after each arithmetic operation inJavaScript
usingfloat64ToFloat32
, or using a suffixf
for every decimal number inC
.
For example,
Double-precision in JavaScript
:
var a = 2.5;
var b = 1.5e3;
var c = a + b;
Single-precision in JavaScript
:
var float64ToFloat32 = require( '@stdlib/number/float64/base/to-float32' );
var a = 2.5;
var b = 1.5e3;
var c = float64ToFloat32( float64ToFloat32( a ) + float64ToFloat32( b ) );
Double-precision in C
:
double a = 2.5;
double b = 1.5e3;
double c = a + b;
Single-precision in C
:
float a = 2.5f;
float b = 1.5e3f;
float c = a + b;
Along with these, some updates were also made in existing packages to make sure they are up to the mark.
I started out with adding the C
implementations for various base special mathematical functions. I generated a topological sort using:
node ./lib/node_modules/@stdlib/_tools/pkgs/toposort/bin/cli $PWD/lib/node_modules/@stdlib/math/base
to identify all the dependencies, with the help of which I made this dependency diagram. With the help of this diagram, I was able to work on those packages first, which could unlock several others. For instance, most of the trigonometric functions were dependent on rempio2
, and thus it was among the first ones to be focused upon. After I completed most of the C
implementations, I moved towards adding single-precision variants for the packages whose double-precision variants we already had.
In order to develop the C
implementations or to add single-precision packages, I followed the steps which were explained in the previous section.
TODO: include a list of links to all relevant PRs along with a short description for each. For small bug fix PRs, you can group them together and describe them as, e.g., "various maintenance work".
Everything that I did till now can be categorized in four major categories:
- Adding C implementations for various base special mathematical functions.
- Adding single-precision variants of pre-existing functions.
- Adding new packages
- Various other maintenance work
Let us have an overview for each one of them:
- feat: add C implementation for
math/base/special/bessely0
- feat: add C implementation for
math/base/special/besselj0
- feat: add C implementation for math/base/special/binomcoefln
- feat: add C implementation for
math/base/special/trigamma
- feat: add C implementation for
math/base/special/betaln
- feat: add C implementation for
math/base/special/gamma1pm1
- feat: add C implementation for
math/base/special/factorialln
- feat: add C implementation for
math/base/special/binomcoef
- feat: add C implementation for
math/base/special/sinc
- feat: add C implementation for
math/base/special/fresnel
- feat: add
F_I
inmath/base/napi/unary
- feat: add
constants/float32/min-base2-exponent-subnormal
- feat: add
constants/float32/max-base2-exponent-subnormal
- feat: add
constants/float32/max-base2-exponent
- feat: add
LL_D
inmath/base/napi/binary
- docs: update function description in
math/base/special/log
- fix: correct include directory name for
constants/float32/max-base2-exponent-subnormal
- fix: correct include directory name for
constants/float32/max-base2-exponent
- fix: correct include directory name for constants/float32/min-base2-exponent-subnormal
- docs: add comment, revert to previous tolerance in math/base/special/factorialln
- feat!: fix function name and update docs
- bench: remove irrelevant benchmark, update
boost
link inmath/base/special/gamma-delta-ratio
- docs: compare
n
withinteger
, not adouble
inmath/base/special/binomcoefln
- docs: update function description comments in
math/base/special/betaln
- docs: update license header and remove
stdlib
include inmath/base/special/trigamma
- docs: update license header in
math/base/special/gamma1pm1
- bench: update sample value in
math/base/assert/is-integer
- bench: use
float
instead ofdouble
in benchmarks formath/base/special/truncf
- docs: update comment to use 8 bits in
constants/float32/max-base2-exponent-subnormal
- refactor: use
int64_t
, check last bit, cast todouble
inmath/base/special/binomcoef
- docs: remove comments, set
isNegative
touint8_t
inmath/base/special/gammaln
- docs: add missing
stdint
includes in examples inmath/base/napi/binary
- docs: use native in
benchmark.native.js
inmath/base/special/gcd
- refactor: correct return value in math/base/special/sincos
- test: add missing tests, return
NaN
inmath/base/special/powm1
- style: correct spacing and return format in
math/base/special/fresnel
- docs: remove
stdint
include, return Float64Array
inmath/base/special/sincospi
TODO: add a summary of the current state of the project.
TODO: add a summary of what remains left to do. If there is a tracking issue, include a link to that issue.
TODO: add a summary of any unexpected challenges that you faced, along with any lessons learned during the course of your project.
TODO: add a report summary and include any acknowledgments (e.g., shout outs to contributors/maintainers who helped out along the way, etc).