- Cluster Analysis
- Combinatorics
- Eigenvalues
- Fortran tools
- Graph algorithms
- Interpolation and Approximation
- Linear Algebra
- Linear Equations
- Nonlinear Equations and Nonlinear Least Squares
- Non-Uniform Random Number Generation
- Numerical Methods
- Optimization -- 1D
- Optimization
- Ordinary Differential Equations
- Probability Distributions
- Root-Finding
- Special functions
- Statistics
- Quadrature
- Quadrature-N-Dimensional
- Quasirandom Number Generation
- Uniform Random Number Generation
asa058 handles the K-Means problem, by David Sparks.
asa113 divides M points in N dimensions into K clusters seeking the division which minimizes a user-defined criterion, by Banfield and Bassill.
cities works with problems involving intercity distances.
gene_cluster divides a set of genetic data into clusters.
kmeans handles the K-Means problem, which organizes a set of N points in M dimensions into K clusters
spaeth analyzes data by grouping it into clusters.
change_making considers the change making problem, in which a given sum is to be formed using coins of various denominations.
combo routines for ranking, unranking, enumerating and randomly selecting balanced sequences, cycles, graphs, Gray codes, subsets, partitions, permutations, restricted growth functions, Pruefer codes and trees.
knapsack_01 uses brute force to solve small versions of the 0/1 knapsack problem.
lau_np implements heuristic algorithms for certain "hard" problems, by Hang Tong Lau.
partition_problem seeks solutions of the partition problem, splitting a set of integers into two subsets with equal sum.
subset enumerates, generates, randomizes, ranks and unranks combinatorial objects including combinations, compositions, Gray codes, index sets, partitions, permutations, polynomials, subsets, and Young tables.
subset_sum seeks solutions of the subset sum problem.
toms515 lists the subsets of size K selected from a set of size N, by Bill Buckles, Matthew Lybanon.
tsp_brute solves small versions of the traveling salesman problem, using brute force.
tsp_lau implements a heuristic algorithm for solution of the traveling salesman problem, by Hang Tong Lau.
arpack computes eigenvalues and eigenvectors of large matrices, by Richard Lehoucq, Danny Sorensen, Chao Yang.
eispack calculates the eigenvalues and eigenvectors of a matrix.
jacobi_eigenvalue computes the eigenvalues and eigenvectors of a real symmetric matrix.
power_method Power Method for Eigenvalues and Eigenvectors.
test_eigen Test Matrices for Eigenvalue Analysis.
toms384 implements ACM TOMS algorithm 384, for computing the eigenvalues and eigenvectors of a symmetric matrix.
extract extracts a subroutine, function or module by name from a FORTRAN file.
f77_to_f90 converts fixed source form to free source form.
fixcon converts the line continuation scheme used in a FORTRAN77 file to that used in FORTRAN90 files.
include_files makes a copy of a FORTRAN file, in which INCLUDE statements are replaced by the corresponding include files.
xerror collects information about errors that occur during a program's execution, and takes the appropriate action, which may include printing a message, diverting to a user routine, or aborting execution of the program.
bellman_ford implements the Bellman-Ford algorithm for finding the shortest distance from a given node to all other nodes in a directed graph whose edges have been assigned real-valued lengths.
djikstra implements a simple version of Dijkstra's algorithm for determining the minimum distance from one node in a graph to all other nodes.
grafpack performs common calculations involving (abstract mathematical) graphs.
laupack computes properties of mathematical graphs, including Euler circuits, Hamiltonian circuits, cliques, strongly connected components, minimal spanning tree, chromatic number, shortest paths, maximal flow, and planarity.
toms097 computes the distance between all pairs of nodes in a directed graph with weighted edges, using Floyd's algorithm.
treepack performs common calculations involving a special kind of graph known as a tree.
dislin_test illustrates the use of the DISLIN scientific plotting package.
graphics_dislin_test illustrates how various kinds of data can be displayed and analyzed graphically, using the dislin() graphics package.
graphics_gnuplot_test illustrate how various kinds of data can be displayed and analyzed graphically, using the gnuplot() graphics package.
gnufor interface to the GNUPLOT plotting software.
barycentric_interp_1d defines and evaluates the Lagrange polynomial p(x) which interpolates a set of data, so that p(x(i)) = y(i).
bivar interpolates scattered bivariate data, by Hiroshi Akima.
chebyshev constructs the Chebyshev interpolant to a function.
chebyshev_interp_1d determines the combination of Chebyshev polynomials which interpolates a set of data, so that p(x(i)) = y(i).
chebyshev_series evaluate a Chebyshev series approximating a function f(x), while efficiently computing one, two or three derivatives of the series, which approximate f'(x), f''(x), and f'''(x), by Manfred Zimmer.
divdif creates, prints and manipulates divided difference polynomials based on data tabulated at evenly spaced or unevenly spaced argument values.
hermite constructs the Hermite polynomial which interpolates function and derivative values at given points.
interp takes a set of data associated with successive values of a parameter, and produces an interpolating function which can be evaluated over a continuous range of the parameter.
lagrange_interp_1d defines and evaluates the Lagrange polynomial p(x) which interpolates a set of data, so that p(x(i)) = y(i).
lagrange_interp_2d defines and evaluates the Lagrange polynomial p(x,y) which interpolates a set of data depending on a 2D argument that was evaluated on a product grid, so that p(x(i),y(j)) = z(i,j).
lagrange_interp_nd defines and evaluates the Lagrange polynomial p(x) which interpolates a set of data depending on a M-dimensional argument that was evaluated on a product grid, so that p(x(i)) = z(i).
lagrange_nd given a set of ND points X() in D-dimensional space, constructs a family of ND Lagrange polynomials P()(X), associating polynomial P(i) with point X(i), such that, for 1 <= i <= ND, P(i)(X(i)) = 1 but, if i =/= j P(i)(X(j)) = 0
nearest_interp_1d interpolates a set of data using a piecewise constant interpolant defined by the nearest neighbor criterion, creating graphics files for processing by GNUPLOT.
newton_interp_1d finds a polynomial interpolant to data using Newton divided differences.
pwl_approx_1d defines and evaluates a piecewise linear function, using NC "control points", which approximates a set of ND data points (x(i),y(i)).
pwl_interp_1d interpolates a set of data with a piecewise linear function.
pwl_interp_2d evaluates a piecewise linear interpolant of data depending on a 2D argument, defined on on a product grid, so that p(x(i),y(j)) = z(i,j).
pwl_interp_2d_scattered produces a piecewise linear interpolant to 2D scattered data, that is, data that is not guaranteed to lie on a regular grid.
rbf_interp_1d defines and evaluates radial basis function (RBF) interpolants to 1D data.
rbf_interp_2d defines and evaluates radial basis function (RBF) interpolants to 2D data.
rbf_interp_nd defines and evaluates radial basis function (RBF) interpolants to multidimensional data.
sparse_interp_nd construct a sparse interpolant to a function f(x) of a multidimensional argument x.
shephard_interp_nd defines and evaluates Shepard interpolants to multidimensional data, based on inverse distance weighting.
test_interp_nd provides test functions for multidimensional interpolation.
toms446 implements ACM TOMS algorithm 446, for the manipulation of Chebyshev series, by Roger Broucke.
toms526 interpolates scattered bivariate data, by Hiroshi Akima.
toms660 interpolates scattered 2D data, also called "qshep2d", by Robert Renka.
toms661 interpolates scattered 3D data, also known as "qshep3d", by Robert Renka.
toms790 constructs an interpolant to scattered 2D data, by Robert Renka.
toms886 implements an interpolation procedure based on "Padua points", defined in the square [-1,+1]^2, whose interpolating power is especially good.
blas Basic Linear Algebra Subprograms.
condition computes or estimates the condition number of a matrix.
hankel_cholesky compute the upper Cholesky factor of a positive definite symmetric (PDS) Hankel matrix H, that is, H = R' * R.
hankel_pds computes a lower triangular matrix L which is the Cholesky factor of a positive definite (symmetric) Hankel matrix H, that is, H = L * L'.
lapack_d routines for solving systems of simultaneous linear equations, least-squares solutions of linear systems of equations, eigenvalue problems, and singular value problems.
matrix_exponential compares some algorithms for approximating the matrix exponential function.
r8ge basic linear algebra operations on R8GE matrices (real 64 bit precision general MxN format). There is r8lt for lower triangular and r83 for tridiagonal matrices.
sparsekit carries out a number of operations on sparse matrices, particularly conversion between various sparse formats.
toeplitz_cholesky computes the Cholesky factorization of a positive semidefinite symmetric (PSS) Toeplitz matrix.
bvls solves a least squares problem with bounds on the variables, by Charles Lawson and Richard Hanson.
cg simple version of the conjugate gradient (CG) method for solving a system of linear equations of the form A*x=b, suitable for situations in which the matrix A is positive definite (only real, positive eigenvalues) and symmetric.
cg_rc conjugate gradient (CG) method for solving a positive definite sparse linear system A*x=b, using reverse communication (RC).
dlap routines for solving sparse linear systems, by Anne Greenbaum and Mark Seager.
jacobi Jacobi iteration for linear systems.
lawson solve least squares problems.
linpack analyze and solve linear equations and linear least-squares problems.
mgmres restarted Generalized Minimum Residual (GMRES) algorithm to solve a sparse linear system, using compressed row (CR) or sparse triplet (ST) format, by Lili Ju.
qr_solve computes a linear least squares (LLS) solution of a system A*x=b.
sparsepak old version of the Waterloo Sparse Matrix Package that solves large sparse systems of linear equations.
superlu_test illustrate the use of the SUPERLU library for the fast direct solution of large sparse systems of linear equations.
templates outlines the most common iterative methods of solving a linear system.
toeplitz olves a variety of Toeplitz and circulant linear systems.
dqed solves (square) systems of nonlinear equations, or minimizes the residual in a set of nonlinear equations, using least squares, by Richard Hanson and Fred Krogh.
fsolve solves systems of nonlinear equations, inspired by the fsolve() function in MATLAB, and based on the minpack() minimization package.
minpack solves systems of nonlinear equations, or carries out the least squares minimization of the residual of a set of linear or nonlinear equations, by Jorge More, Danny Sorenson, Burton Garbow, Kenneth Hillstrom.
newton_rc solves a system of nonlinear equations by Newton's method, using reverse communication (RC).
nl2sol implements an adaptive nonlinear least-squares algorithm, by John Dennis, David Gay, Roy Welsch.
roots_rc seeks solutions of a system of nonlinear equations, using reverse communication (RC), by Gaston Gonnet.
asa053 returns samples from the Wishart distribution.
pdflib evaluates Probability Density Functions (PDF's) and produces random samples from them, including beta, binomial, chi, exponential, gamma, inverse chi, inverse gamma, multinomial, normal, scaled inverse chi, and uniform.
random_data uses a random number generator (RNG) to sample points for various probability distributions, spatial dimensions, and geometries, including the M-dimensional cube, ellipsoid, simplex and sphere.
ranlib produces random samples from Probability Density Functions (PDF's), including Beta, Chi-square Exponential, F, Gamma, Multivariate normal, Noncentral chi-square, Noncentral F, Univariate normal, random permutations, Real uniform, Binomial, Negative Binomial, Multinomial, Poisson and Integer uniform, by Barry Brown and James Lovato.
wishart produces sample matrices from the Wishart or Bartlett distributions, useful for sampling random covariance matrices.
ziggurat random number generator (RNG) for the uniform, normal or exponential distributions, by Marsaglia and Tsang.
nms accompanies the text "Numerical Methods and Software".
slatec general purpose mathematical and statistical routines.
local_min_rc seeks a local minimum of a scalar function of a scalar variable, without requiring derivatives, or assuming the function is differentiable, using reverse communication (RC), by Richard Brent.
test_min defines problems involving the minimization of a scalar function of a scalar argument.
asa047 minimize a scalar function of several variables using the Nelder-Mead algorithm, by R ONeill.
compass_search minimizes of a scalar function of several variables using compass search, a direct search algorithm that does not use derivatives.
praxis minimizes a scalar function of a vector argument, without needing derivative information, by Richard Brent.
test_opt defines test problems for the scalar function optimization problem.
test_opt_con Test Functions for Scalar Optimization Constrained to a Hyper-Rectangle.
toms178 uses the Hooke-Jeeves direct search algorithm to seek the minimizing point of a function F(X) of several variables, by Arthur Kaupe.
toms611 minimizes a scalar functional of multiple variables.
uncmin seeks to minimize a scalar function of N variables.
etdrk4 uses the ETD RK4 method to solve systems of stiff ODE's, by Aly-Khan Kassam, Lloyd Trefethen.
euler solves one or more ordinary differential equations (ODEs) using the forward Euler method.
midpoint_explicit solves one or more ordinary differential equations (ODE) using the (explicit) midpoint method, also known as the modified Euler method.
ode solves a system of ordinary differential equations (ODE), by Shampine and Gordon.
rk4 implements a simple Runge-Kutta solver for an initial value problem.
asa005 evaluates the lower tail of the noncentral student's T cumulative density function (CDF), by BE Cooper.
asa066 computes the cumulative density function (CDF) of the standard normal distribution, by David Hill.
asa076 evaluates Owen's T function, by Young and Minder. The function T(h, a) gives the probability of the event (X > h and 0 < Y < aX) where X and Y are independent standard normal random variables.
asa091 computes the percentage points of the Chi-Squared probability density function, by Best and Roberts.
asa111 computes the percentage points of the normal probability density function, by Beasley and Springer.
asa152 computes the cumulative probabilities associated with the hypergeometric probability distribution, by Richard Lund.
asa226 evaluates the cumulative distribution function (CDF) of the noncentral Beta Distribution, by Russell Lenth.
asa241 computes the inverse of the Normal Cumulative Density Function (CDF), by Michael Wichura.
asa243 computes the cumulative density function (CDF) of the noncentral Student's T probability density function, by Russell Lenth.
asa266 estimates the parameters of a Dirichlet probability density function (PDF).
asa310 computes the cumulative density function (CDF) of the noncentral Beta distribution, by Chattamvelli and Shanmugam.
beta_nc evaluates the cumulative distribution function (CDF) of the noncentral Beta distribution.
cdflib evaluates the cumulative density function (CDF) associated with common probability distributions, by Barry Brown, James Lovato, Kathy Russell.
owens evaluates Owen's T function.
prob routines for evaluating and inverting the normal CDF, and many other distributions.
alpert_rule sets up an Alpert quadrature rule for functions which are regular, log(x) singular, or 1/sqrt(x) singular.
ccn_rule defines a nested Clenshaw Curtis quadrature rule.
chebyshev1_rule computes and prints a Gauss-Chebyshev type 1 quadrature rule.
chebyshev2_rule computes and prints a Gauss-Chebyshev type 2 quadrature rule.
clenshaw_curtis_rule generates a Clenshaw Curtis quadrature rule based on user input.
cubpack estimates the integral of a function (or vector of functions) over a collection of N-dimensional hyperrectangles and simplices, by Alan Genz and Ronald Cools.
fastgl fast computation of the K-th value and weight of an N-point Gauss-Legendre quadrature rule, by Ignace Bogaert.
filon approximate integrals in which the integrand includes an oscillatory factor of sin(kx) or cos(kx).
gegenbauer_rule computes and prints a Gauss-Gegenbauer quadrature rule.
gen_hermite_rule computes and prints a generalized Gauss-Hermite quadrature rule.
gen_laguerre_rule computes and prints a generalized Gauss-Laguerre quadrature rule.
hermite_rule computes and prints a Gauss-Hermite quadrature rule
intlib contains routines for numerical estimation of integrals in 1d.
jacobi_rule computes and prints a Gauss-Jacobi quadrature rule.
kronrod computes both a Gauss quadrature rule of order N, and the Gauss-Kronrod rule of order 2*N+1.
laguerre_rule computes and prints a Gauss-Laguerre quadrature rule.
legendre_rule computes and prints a Gauss-Legendre quadrature rule.
legendre_rule_fast uses a fast (order n) algorithm to compute a Gauss-Legendre quadrature rule of given order.
line_integrals returns the exact value of the integral of any monomial over the length of the unit line in 1d.
line_ncc_rule computes a Newton Cotes Closed (ncc) quadrature rule for the line, that is, for an interval of the form [a,b], using equally spaced points which include the endpoints.
line_nco_rule computes a Newton Cotes Open (nco) quadrature rule, using equally spaced points, over the interior of a line segment in 1d.
patterson_rule returns the points and weights of a 1d Gauss-Patterson quadrature rule of order 1, 3, 7, 15, 31, 63, 127, 255 or 511.
patterson_rule_compute computes the points and weights of a 1d Gauss-Patterson quadrature rule of order 1, 3, 7, 15, 31, 63, 127, 255 or 511.
quadmom computes a Gaussian quadrature rule for a weight function rho(x) based on the Golub-Welsch procedure that only requires knowledge of the moments of rho(x).
quadpack estimates integrals using numerical quadrature, by Piessens, deDoncker-Kapenga, Ueberhuber, and Kahaner.
quadrule defines 1-dimensional quadrature rules.
romberg Integral Estimation using Repeated Quadrature and Extrapolation.
stroud defines quadrature rules for various geometric shapes.
test_int contains a number of functions that may be used as test integrands for quadrature rules in 1D.
test_int_2d defines test integrands for 2D quadrature rules.
toms341 implements ACM TOMS algorithm 351, for modified Romberg quadrature.
toms370 SQUANK (Simpson Quadrature Used Adaptively - Noise Killed).
toms468 Automatic Numerical Integration Over a Finite Interval.
toms655 computes weights for interpolatory quadrature schemes, by Sylvan Elhay and Jaroslav Kautsky.
truncated_normal_rule computes a quadrature rule for a normal distribution that has been truncated to [A,+oo), (-oo,B] or [a,b].
ball_integrals returns the exact value of the integral of any monomial over the interior of the unit ball in 3d.
circle_integrals returns the exact value of the integral of any monomial along the circumference of the unit circle in 2D.
circle_monte_carlo uses the Monte Carlo method to estimate the integral of a function over the circumference of the unit circle in 2d.
circle_rule computes quadrature rules for approximating integrals over the circumference of the unit circle.
cube_felippa_rule generates the points and weights of a Felippa quadrature rule over the interior of a cube in 3D.
cube_integrals returns the exact value of the integral of any monomial over the interior of the unit cube in 3d.
disk_rule computes quadrature rules for approximating integrals over the interior of the general disk in 2D.
disk01_integrals returns the exact value of the integral of any monomial over the interior of the unit disk in 2d.
hyperball_integrals returns the exact value of the integral of any monomial over the interior of the unit hyperball in m dimensions.
hypercube_integrals returns the exact value of the integral of any monomial over the interior of the unit hypercube in m dimensions.
hypersphere_integrals returns the exact value of the integral of any monomial over the surface of the unit hypersphere in m dimensions.
nintlib estimates integrals over multi-dimensional regions.
polygon_integrals returns the exact value of the integral of any monomial over the interior of a polygon in 2d.
pyramid_felippa_rule returns Felippa quadrature rules over the interior of the unit pyramid in 3D.
pyramid_integrals returns the exact value of the integral of any monomial over the interior of the unit pyramid in 3d.
simplex_integrals returns the exact value of the integral of any monomial over the interior of the unit simplex in m dimensions.
sphere_integrals returns the exact value of the integral of any monomial over the surface of the unit sphere in 3d.
sphere_lebedev_rule computes Lebedev quadrature rules on the surface of the unit sphere in 3D.
sphere_quad estimates the integral of a scalar function F(X,Y,Z) over the surface of the unit sphere centered at the origin.
square_felippa_rule returns the points and weights of a Felippa quadrature rule over the interior of a square in 2D.
square_integrals returns the exact value of the integral of any monomial over the interior of the unit square in 2d.
tetrahedron_felippa_rule returns Felippa's quadratures rules for approximating integrals over the interior of a tetrahedron in 3D.
tetrahedron_integrals returns the exact value of the integral of any monomial over the interior of the unit tetrahedron in 3d.
triangle_felippa_rule returns Felippa's quadratures rules for approximating integrals over the interior of a triangle in 2D.
triangle_integrals returns the exact value of the integral of any monomial over the interior of the unit triangle in 2d.
wedge_felippa_rule returns quadratures rules for approximating integrals over the interior of the unit wedge in 3D.
wedge_integrals returns the exact value of the integral of any monomial over the interior of the unit wedge in 3d.
faure Faure quasirandom sequence.
halton Halton Quasi Monte Carlo (QMC) sequence using a simple interface.
hammersley Hammersley Quasi Monte Carlo (QMC) sequence using a simple interface.
niederreiter Niederreiter quasirandom sequence, using an "arbitrary" base.
niederreiter2 Niederreiter quasirandom sequence, using a base of 2.
sobol Sobol quasirandom sequence, by Bennett Fox.
van_der_corput van der Corput Quasi Monte Carlo (QMC) sequence, using a simple interface.
bisection_integer seeks an integer solution to the equation F(X)=0, using bisection within a user-supplied change of sign interval [A,B].
bisection_rc bisection method for solving a scalar equation in a change of sign interval, using reverse communication (RC).
brent finds zeros or minima of a scalar function of a scalar variable, by Richard Brent.
muller seeks a root of a nonlinear equation using Muller's method, with complex arithmetic.
test_zero defines nonlinear functions that may be used to test zero finders.
zero_rc seeks a solution of a scalar nonlinear equation f(x)=0, using reverse communication (RC), by Richard Brent.
zoomin seeks a root of a scalar function.
asa103 evaluates the digamma or psi function, by Jose Bernardo.
asa239 evaluates the incomplete Gamma function, by Shea.
besselj evaluates Bessel J functions of noninteger order.
cordic uses the CORDIC algorithm to evaluate certain functions, in particular the sine and cosine.
fn evaluates elementary and special functions using Chebyshev polynomials.
specfun evaluates special functions, including Bessel I, J, K and Y functions, Dawson Integral, Error (Erf), Exponential Integral (E1 and EI), Gamma, log Gamma, and Psi/Digamma, by William Cody and Laura Stoltz.
special_functions evaluates special functions, including Airy, Associated Legendre Bessel, Beta, Complete Elliptic Integral, Confluent Hypergeometric, Cosine Integral, Elliptic Integral, Error, Exponential Integral, Fresnel Integral, Gamma, Hankel, Hypergeometric, Incomplete Beta, Incomplete Gamma, Jacobian Elliptic, Kelvin, Lambda, Legendre, Mathieu, Modified Spherical Bessel, Parabolic Cylinder, Psi, Riccati-Bessel, Sine Integral, Spheroidal Wave, Struve, Whittaker, as well as Bernoulli Numbers, Euler Numbers, Hermite Polynomials, Laguerre Polynomials, Legendre Polynomials, by Shanjie Zhang, Jianming Jin.
toms435 evaluates the modified incomplete Gamma function.
toms708 computes the Incomplete Beta Function ratio.
toms715 evaluates special functions, including the Bessel I, J, K, and Y functions of order 0, of order 1, and of any real order, Dawson's integral, the error function, exponential integrals, the gamma function, the normal distribution function, the psi function.
starpac nonlinear least squares regression, time series analysis (in both time and frequency domains), line printer graphics, basic statistical analysis, and linear least squares regression.
asa183 random number generator (RNG), by Wichman and Hill.
randlc random number generator (RNG) used by the NAS Parallel Benchmarks.
random_sorted create a vector of random values which are already sorted.
rnglib random number generators (RNG's) which can generate one or more streams of random numbers.
uniform random number generator is based on a simple, old, and limited linear congruential random number generator originally used in the IBM System 360.