GNU Scientific Library
Original author(s) | Mark Galassi, James Theiler, Brian Gough, Gerard Jungman and many others |
---|---|
Developer(s) | GNU Project |
Initial release | May 1996 |
Repository | ftpmirror |
Written in | C |
Type | Numerical library |
License | 2007: GPL-3.0-or-later[lower-alpha 1] 1996: GPL-2.0-or-later[lower-alpha 2] |
Website | www |
The GNU Scientific Library (or GSL) is a software library for numerical computations in applied mathematics and science. The GSL is written in C; wrappers are available for other programming languages. The GSL is part of the GNU Project[1] and is distributed under the GNU General Public License.
Project history
The GSL project was initiated in 1996 by physicists Mark Galassi and James Theiler of Los Alamos National Laboratory.[2] They aimed at writing a modern replacement for widely used but somewhat outdated Fortran libraries such as Netlib.[3] They carried out the overall design and wrote early modules; with that ready they recruited other scientists to contribute. The "overall development of the library and the design and implementation of the major modules" was carried out by Brian Gough and Gerard Jungman.[2] Other major contributors were Jim Davies, Reid Priedhorsky, M. Booth, and F. Rossi.[2] Version 1.0 was released in 2001. In the following years, the library expanded only slowly; as the documentation stated, the maintainers were more interested in stability than in additional functionality. Major version 1 ended with release 1.16 of July 2013; this was the only public activity in the three years 2012–2014. Vigorous development resumed with publication of version 2.0 in October 2015, which included user contributed patches. The latest version 2.8 was released in May 2024.
Example
The following example program calculates the value of the Bessel function of the first kind and order zero for 5:[4]
#include <stdio.h>
#include <gsl/gsl_sf_bessel.h>
int main(void)
{
double x = 5.0;
double y = gsl_sf_bessel_J0(x);
printf("J0(%g) = %.18e\n", x, y);
return 0;
}
The example program has to be linked to the GSL library upon compilation:
$ gcc $(gsl-config --cflags) example.c $(gsl-config --libs)
The output is shown below and should be correct to double-precision accuracy:
J0(5) = -1.775967713143382920e-01
Features
The software library provides facilities for:
- Basic mathematical functions
- Complex numbers
- Polynomials
- B-splines
- Special functions
- Vectors and matrices
- Permutations
- Combinations
- Multisets
- Sorting
- BLAS
- Linear algebra
- Eigensystems
- Fast Fourier transforms
- Numerical integration (based on QUADPACK)
- Random number generation
- Quasi-random sequences
- Random number distributions
- Statistics
- Histograms
- N-tuples
- Monte Carlo integration
- Simulated annealing
- Ordinary differential equations
- Interpolation
- Numerical differentiation
- Chebyshev approximations
- Series acceleration
- Discrete Hankel transform
- Root finding in one and multiple dimensions
- Minimization in one and multiple dimensions
- Least-squares fitting
- Nonlinear least-squares fitting
- Physical constants
- IEEE floating-point arithmetic
- Discrete wavelet transform
Programming-language bindings
Since the GSL is written in C, it is straightforward to provide wrappers for other programming languages. Such wrappers currently exist for
- AMPL[5]
- C++[6][7][8][9]
- Fortran[10]
- Haskell[11][12]
- Java[13]
- Julia[14]
- Common Lisp[15]
- OCaml[16]
- Octave
- Perl Data Language
- Python[17]
- R[18][19]
- Ruby[20]
- Rust[21]
C++ support
The GSL can be used in C++ classes, but not using pointers to member functions, because the type of pointer to member function is different from pointer to function.[22] Instead, pointers to static functions have to be used. Another common workaround is using a functor. C++ wrappers for GSL are available.[6][7][8][9] Not all of these are regularly maintained. They do offer access to matrix and vector classes without having to use GSL's interface to malloc and free functions. Some also offer support for also creating workspaces that behave like Smart pointer classes. Finally, there is (limited, as of April 2020) support for allowing the user to create classes to represent a parameterised function as a functor. While not strictly wrappers, there are some C++ classes [23][24] that allow C++ users to use the Gnu Scientific Library with wrapper features.
See also
Notes
References
- ↑ "GNU - Free Software Directory".
- ↑ 2.0 2.1 2.2 GSL homepage.
- ↑ GSL design document.
- ↑ Using the Library. An Example Program. GSL documentation.
- ↑ AMPL bindings for the GNU Scientific Library Archived 2021-10-28 at the Wayback Machine.
- ↑ 6.0 6.1 ccgsl: a C++ interface for the GNU Scientific Library;
- ↑ 7.0 7.1 GSL-- C++ wrappers for GSL Archived 2015-01-29 at the Wayback Machine;
- ↑ 8.0 8.1 GSLwrap: A C++ wrapper class for the GNU Scientific Library;
- ↑ 9.0 9.1 gslcpp: A Header-Only, Modern C++-Library Wrapping the GNU Scientific Library.
- ↑ FGSL - A Fortran interface to the GNU Scientific Library.
- ↑ The hmatrix-special package, an interface to GSL special functions.
- ↑ The hmatrix-gsl package, a purely functional interface to selected numerical computations, internally implemented using GSL.
- ↑ JavaCPP Presets for GSL.
- ↑ Julia interface to GSL.
- ↑ GSLL, GNU Scientific Library for Lisp.
- ↑ gsl-ocaml: OCaml bindings to the GSL.
- ↑ Python interface for GNU Scientific Library.
- ↑ RcppGSL: 'Rcpp' Integration for 'GNU GSL' Vectors and Matrices.
- ↑ gsl: wrapper for the Gnu Scientific Library.
- ↑ rb-gsl: Ruby/GSL is a Ruby interface to the GNU Scientific Library, for numerical computing with Ruby.
- ↑ rust-gsl: A Rust binding for the GSL library (the GNU Scientific Library).
- ↑ Pointers to member functions. Archived 2004-10-13 at the Wayback Machine.
- ↑ o2scl Object-oriented Scientific Computing Library;
- ↑ yat[permanent dead link ].
External links
- Official website
- GSL Design Document
- The gsl package for R (programming language), an R wrapper for the special functions and quasi random number generators.
- FLOSS FOR SCIENCE interview with Mark Galassi on the history of GSL.