Skip to main content

ANFIS Toolbox is a comprehensive Python library for creating, training, and deploying Adaptive Neuro-Fuzzy Inference Systems (ANFIS). It provides an intuitive API that makes fuzzy neural networks accessible to both beginners and experts.

Project description

ANFIS Toolbox

ANFIS Toolbox

anfis-toolbox version doi License: MIT docs Python versions CI Coverage

ANFIS Toolbox is a comprehensive Python library for creating, training, and deploying Adaptive Neuro-Fuzzy Inference Systems (ANFIS). It provides an intuitive API that makes fuzzy neural networks accessible to both beginners and experts.

🚀 Overview

  • Takagi–Sugeno–Kang (TSK) ANFIS with the classic four-layer architecture (Membership → Rules → Normalization → Consequent).
  • Regressor and classifier facades with a familiar scikit-learn style (fit, predict, score).
  • Trainers (Hybrid, SGD, Adam, RMSProp, PSO) decoupled from the model for easy experimentation.
  • 10+ membership function families. The primary public interfaces are ANFISRegressor and ANFISClassifier.
  • Thorough test coverage (100%+).

📦 Installation

Install from PyPI:

pip install anfis-toolbox

🧠 Quick start

Regression

import numpy as np
from anfis_toolbox import ANFISRegressor

X = np.random.uniform(-2, 2, (100, 2))
y = X[:, 0]**2 + X[:, 1]**2

model = ANFISRegressor()
model.fit(X, y)
metrics = model.evaluate(X, y)

Classification

import numpy as np
from anfis_toolbox import ANFISClassifier

X = np.r_[np.random.normal(-1, .3, (50, 2)), np.random.normal(1, .3, (50, 2))]
y = np.r_[np.zeros(50, int), np.ones(50, int)]

model = ANFISClassifier()
model.fit(X, y)
metrics = model.evaluate(X, y)

🧩 Membership functions at a glance

  • Gaussian (GaussianMF) - Smooth bell curves
  • Gaussian2 (Gaussian2MF) - Two-sided Gaussian with flat region
  • Triangular (TriangularMF) - Simple triangular shapes
  • Trapezoidal (TrapezoidalMF) - Plateau regions
  • Bell-shaped (BellMF) - Generalized bell curves
  • Sigmoidal (SigmoidalMF) - S-shaped transitions
  • Diff-Sigmoidal (DiffSigmoidalMF) - Difference of two sigmoids
  • Prod-Sigmoidal (ProdSigmoidalMF) - Product of two sigmoids
  • S-shaped (SShapedMF) - Smooth S-curve transitions
  • Linear S-shaped (LinSShapedMF) - Piecewise linear S-curve
  • Z-shaped (ZShapedMF) - Smooth Z-curve transitions
  • Linear Z-shaped (LinZShapedMF) - Piecewise linear Z-curve
  • Pi-shaped (PiMF) - Bell with flat top

🛠️ Training options

  • SGD (Stochastic Gradient Descent) – Classic gradient-based optimization with incremental updates
  • Adam – Adaptive learning rates with momentum for faster convergence
  • RMSProp – Scales learning rates by recent gradient magnitudes for stable training
  • PSO (Particle Swarm Optimization) – Population-based global search strategy
  • Hybrid SGD + OLS – Combines gradient descent with least-squares parameter refinement
  • Hybrid Adam + OLS – Integrates adaptive optimization with analytical least-squares adjustment

📚 Documentation

  • Comprehensive guides, API reference, and examples: docs/ (built with MkDocs).

🧪 Testing & quality

Local setup

Clone the repository:

git clone https://github.com/dcruzf/anfis-toolbox.git
cd anfis-toolbox

Create a virtual environment:

python -m venv .venv

Activate it:

Linux / macOS

source .venv/bin/activate

Windows (PowerShell)

.venv\Scripts\Activate.ps1

Install the project in editable mode with development dependencies (this includes Hatch and all test tools):

pip install -e .[dev]

Running tests

Run the full test suite with coverage:

hatch test -c --all

This project is tested on Python 3.10 | 3.11 | 3.12 | 3.13 | 3.14 across Linux, Windows and macOS.

Linting & Formatting

Run the linter and format the codebase:

hatch fmt

Typing

Run static type checks:

hatch run typing

Security

Run security checks with Bandit:

hatch run security

🤝 Contributing

Issues and pull requests are welcome! Please open a discussion if you’d like to propose larger changes. See the docs/guide section for architecture notes and examples.

📄 License

Distributed under the MIT License. See LICENSE for details.

📚 References

  1. Jang, J. S. (1993). ANFIS: adaptive-network-based fuzzy inference system. IEEE transactions on systems, man, and cybernetics, 23(3), 665-685. https://doi.org/10.1109/21.256541

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

anfis_toolbox-0.2.2.tar.gz (139.9 kB view details)

Uploaded Source

Built Distribution

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

anfis_toolbox-0.2.2-py3-none-any.whl (90.7 kB view details)

Uploaded Python 3

File details

Details for the file anfis_toolbox-0.2.2.tar.gz.

File metadata

  • Download URL: anfis_toolbox-0.2.2.tar.gz
  • Upload date:
  • Size: 139.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.3 cpython/3.12.3 HTTPX/0.28.1

File hashes

Hashes for anfis_toolbox-0.2.2.tar.gz
Algorithm Hash digest
SHA256 7f7b3b8bb304c3b21a0709d9d650809bcf154bc25756e221f9a8369991d17182
MD5 e9e7c65942323068677e190877ce11fb
BLAKE2b-256 88ccb69157886cc8efb711bd9411c66aa5fe4b472a73db795e02ce511b57aacb

See more details on using hashes here.

File details

Details for the file anfis_toolbox-0.2.2-py3-none-any.whl.

File metadata

  • Download URL: anfis_toolbox-0.2.2-py3-none-any.whl
  • Upload date:
  • Size: 90.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.3 cpython/3.12.3 HTTPX/0.28.1

File hashes

Hashes for anfis_toolbox-0.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 886faad6066cacb05d5bb7237b538f92441b67d48f769125f54466aa749f6357
MD5 9b9cc8f39c4f1318ef0238b7539ace6f
BLAKE2b-256 2c04e950c675f7da834d8f629a9c5c8cad23e14089f6a5553e3bd4197c255b79

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