Python package that contains some numerical analysis & optimization algorithms.
Instructions:
-
Install: Run this command in your terminal:
pip install NumAn-Op
-
Modules: There are 3 modules in this package:
To use them you can import them as following:
from NumAn_Op import one_dim_min from NumAn_Op import sys_eq from NumAn_op import multi_dim_min
After importing the modules, you can use the help() function to get information about the modules and the functions that it contains.
Following are the algorithms present in this package:
I. One dimensional function minimization algorithms:
- Searching with elimination methods
- Unrestricted search
- Exhaustive search
- Dichotomous search
- Interval halving method
- Fibonacci method
- Golden section method
- Searching with interpolation methods
- Newton-Rapson method
- Quasi-Newton method
- Secant method
II. System of Equations & Decompositions:
- The Elimination Of Gauss-Jordan
- LU Decomposition Method
- Cholesky Decomposition Method
III. Multi-dimensional function minimization algorithms:
- Gradient methods
- Gradient Descent method
- Conjugate Gradient method
- AdaGrad
- Newton methods
- Newton method
- Quasi-Newton with DFP and armijo
Following are some plots visualizing the progress of some algorithms that the package contains. You can find all the scripts to make them in the Plotting_Scripts folder in this repository.
-
One dimensional function minimization comparison:
-
Mutli-Variable function minimization comparison:
Note: You won't get the same progess path for the Adagrad method if you try to use the scripts in the Plotting_Scripts folder, and this is due to the fact that Adagrad is a variant of the stochastic gradient descent method, this means that it takes a random starting point each time.