Skip to main content

A set of core numerical methods used in engineering and applied mathematics

Project description

numeth Logo

PyPI version PyPI downloads License

numeth

A fully functional Python package implementing core numerical methods for engineering and applied mathematics. Designed for usability and educational clarity.

Installation

Install via pip:

pip install numeth

Quick Start

Here's a simple example using the Newton-Raphson method to find the square root of 2:

from numeth import newton_raphson

def f(x):
    return x**2 - 2

def df(x):
    return 2 * x

root, iterations, converged = newton_raphson(f, df, x0=1.0, tol=1e-6, max_iter=100)
print(f"Root: {root}, Iterations: {iterations}, Converged: {converged}")
# Output: Root: 1.414213562373095, Iterations: 4, Converged: True

Visualization

You can easily visualize the convergence or the results of any numerical method using the .graph() method.

import numeth

# Integration visualization
tr = numeth.trapezoidal(lambda x: x**2, 0, 1)
tr.graph()

# Root finding visualization
sol = numeth.bisection(lambda x: x**2 - 2, 0, 2)
sol.graph()

The .graph() method provides a visual representation of how the algorithm works, including function plots, integration areas, root markers, and tangent lines for differentiation.

Supported Methods

Integration

  • Trapezoidal Rule (single and composite)
  • Simpson’s 1/3 Rule (single and composite)
  • Simpson’s 3/8 Rule
  • Gaussian Quadrature (2-point and 3-point)

Differentiation

  • Forward difference (first derivative)
  • Backward difference (first derivative)
  • Central difference (first derivative)
  • Central difference (second derivative)
  • Richardson extrapolation (first derivative)

Root Finding

  • Bisection Method
  • Newton-Raphson Method
  • Secant Method
  • False Position Method

Interpolation

  • Linear Interpolation
  • Lagrange Interpolation
  • Newton’s Divided Difference Interpolation

Linear Algebra

  • Gauss Elimination with partial pivoting
  • LU Decomposition (Doolittle’s method)
  • Jacobi Iterative Method
  • Gauss-Seidel Iterative Method

Optimization

  • Golden Section Search (minimization)
  • Newton’s Method for Optimization (1D)

How to Contribute or Report Issues

Contributions are welcome! Please submit pull requests or open issues on the GitHub repository.

License

This project is licensed under the MIT License - see the LICENSE file for details.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

numeth-1.1.1.tar.gz (13.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

numeth-1.1.1-py3-none-any.whl (12.9 kB view details)

Uploaded Python 3

File details

Details for the file numeth-1.1.1.tar.gz.

File metadata

  • Download URL: numeth-1.1.1.tar.gz
  • Upload date:
  • Size: 13.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for numeth-1.1.1.tar.gz
Algorithm Hash digest
SHA256 e816d2cba4c6882ee14d838c827bc0df9b77c9d2c0e6a04738c1d9f14a8440a1
MD5 693118e8de76016dbf6886ed693b224d
BLAKE2b-256 0100bbba5e0b53c0390f4fdafef8db1e9328fb919a8bf623213076b4cb59090b

See more details on using hashes here.

File details

Details for the file numeth-1.1.1-py3-none-any.whl.

File metadata

  • Download URL: numeth-1.1.1-py3-none-any.whl
  • Upload date:
  • Size: 12.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.7

File hashes

Hashes for numeth-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 26167bcea62d7e247d24a2319cb4b518d8bf1236404a15271a1b988c3813df99
MD5 776573cef95f23b2196bbc87bec16378
BLAKE2b-256 3f2cf3b397da9a22e9172666c08944d64002bf73486979cbedaa60ff149cc88c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page