FundamentalsNumericalComputation.jl

Core functions for the Julia (2nd) edition of the text Fundamentals of Numerical Computation, by Driscoll and Braun.
Popularity
97 Stars
Updated Last
4 Months Ago
Started In
March 2021

Fundamentals of Numerical Computation

These are core functions for the text Fundamentals of Numerical Computation by T. A. Driscoll and R. J. Braun (preview site). They are a companion to the Julia (2nd) edition, to be published in 2022.

For Julia versions of the functions accompanying the MATLAB (first) edition, go to https://github.com/fncbook/fnc instead.

Installation

  1. Install Julia. Any of the available methods for the latest stable version 1.x should be fine. The Julia Pro version comes with an integrated editor and many preinstalled packages, and it might be the best choice for those not comfortable with their command line shell.

  2. Start Julia on your machine. Look for the julia> prompt.

  3. At the prompt type the ] character. This will turn the prompt a different color and say pkg>, indicating that you can give commands to the package manager.

  4. At the pkg prompt, type

    add FundamentalsNumericalComputation

    The process will take a while. In order to flatten the learning curve, this package loads many other standard numerical and plotting packages and makes them available, so there is a lot of code to install and compile.

  5. Hit the backspace (delete on Mac) key to go back to the main Julia prompt. Steps 3-5 should only need to be done once per Julia installation.

Usage

In order to use the functions, in each new Julia session you must enter

using FundamentalsNumericalComputation

None of the functions are exported, so they must all be prefixed with the package name. However, the constant FNC is set as an alias to the package name to make typing more reasonable, e.g., FNC.lufact, FNC.rk23, etc.

There is a bare-bones documentation site, but it only gives summaries of the documentation strings that are found in the text. The textbook is meant to be the real guide.

Startup speed

After installation, importing the package with a using statement should only take 5-10 seconds in Julia 1.6 or later. The first plot created in a Julia session may take 20-60 seconds to appear. This is a well-known irritant in the Julia ecosystem, and progress is steadily being made toward reducing the lag. In the meantime, there are a few options available for power users.

PackageCompiler

The PackageCompiler package allows you to compile a new version of the Julia binary to get better startup performance. It's not too hard to use, but it helps if you are comfortable with command line/terminal interfaces.

Minimal package version

You can speed up loading time by installing a special branch of this package. At the prompt, type the ] character to enter package mode. If you already installed the default version, enter

rm FundamentalsNumericalComputation

Then enter

add https://github.com/fncbook/FundamentalsNumericalComputation.jl#fast-load

Now, each import of this package should take ten seconds or less. However, you will need to manually install and then load packages in order to run the demos and solve many of the exercises in the book. (This is how Julia is normally used in practice.) In particular, only LinearAlgebra, Polynomials, SparseArrays, and a few packages for loading files and displaying output are provided. Other packages used in the text, and their key dependents, are given in the following table.

Package name Key dependent functions
Arpack eigs
Dierckx Splline1D
DifferentialEquations solve
FFTW fft
GraphRecipes graphplot
Images image loading and display, Gray
IncompleteLU iLU
IterativeSolvers gmres, minres, cg
LinearMaps LinearMap
MatrixDepot matrixdepot
NLsolve nlsolve
Plots plot, scatter, contour
Preconditioners DiagonalPreconditioner
QuadGK quadgk
SpecialFunctions besselj, gamma
TestImages testimage

Alternative numerical packages

These codes are for instructional purposes. They are not recommended for applications. Compared to superior alternatives, they lack generality, efficiency, and robustness to syntax and more subtle mistakes. My personal recommendations for preferable alternatives are as follows. Most of them are demonstrated in the textbook.

Problem type Associated Julia packages
Linear system / least squares LinearAlgebra (standard library)
Sparse matrix SparseArrays, IterativeSolvers, Arpack, Preconditioners
Polynomial interpolation/approximation Polynomials, ApproxFun
Polynomial roots Polynomials
Rootfinding NLsolve
Finite differences FiniteDifferences, FiniteDiff
Integration QuadGK
Spline Dierckx
Initial-value problem DifferentialEquations
Boundary-value problem DifferentialEquations
Method of lines MethodOfLines (still under development)

License

This code stored on this site is under an MIT license. Please see the LICENSE file for details.