Python automated machine learning framework.
Project description
NiaAML is an automated machine learning Python framework based on nature-inspired algorithms for optimization. The name comes from the automated machine learning method of the same name [1]. Its goal is to efficiently compose the best possible classification pipeline for the given task using components on the input. The components are divided into three groups: feature seletion algorithms, feature transformation algorithms and classifiers. The framework uses nature-inspired algorithms for optimization to choose the best set of components for the classification pipeline on the output and optimize their parameters. We use NiaPy framework for the optimization process which is a popular Python collection of nature-inspired algorithms. The NiaAML framework is easy to use and customize or expand to suit your needs.
The NiaAML framework allows you not only to run full pipeline optimization, but also separate implemented components such as classifiers, feature selection algorithms, etc. It supports numerical and categorical features as well as missing values in datasets.
Documentation: https://niaaml.readthedocs.io/en/latest/,
Tested OS: Windows, Ubuntu, Fedora, Linux Mint and CentOS. However, that does not mean it does not work on others.
Installation
pip
Install NiaAML with pip3:
pip3 install niaaml
In case you would like to try out the latest pre-release version of the framework, install it using:
pip3 install niaaml --pre
Install From Source
In case you want to install directly from the source code, use:
git clone https://github.com/lukapecnik/NiaAML.git
cd NiaAML
python3 setup.py install
Graphical User Interface
You can find a simple graphical user interface for NiaAML package here.
Usage
See the project’s repository for usage examples.
Components
In the following sections you can see a list of currently implemented components divided into groups: classifiers, feature selection algorithms and feature transformation algorithms. At the end you can also see a list of currently implemented fitness functions for the optimization process, categorical features’ encoders, and missing values’ imputers.
Classifiers
Adaptive Boosting (AdaBoost),
Bagging (Bagging),
Extremely Randomized Trees (ExtremelyRandomizedTrees),
Linear SVC (LinearSVC),
Multi Layer Perceptron (MultiLayerPerceptron),
Random Forest Classifier (RandomForest),
Decision Tree Classifier (DecisionTree),
K-Neighbors Classifier (KNeighbors),
Gaussian Process Classifier (GaussianProcess),
Gaussian Naive Bayes (GaussianNB),
Quadratic Discriminant Analysis (QuadraticDiscriminantAnalysis).
Feature Selection Algorithms
Select K Best (SelectKBest),
Select Percentile (SelectPercentile),
Variance Threshold (VarianceThreshold).
Nature-Inspired
Bat Algorithm (BatAlgorithm),
Differential Evolution (DifferentialEvolution),
Self-Adaptive Differential Evolution (jDEFSTH),
Grey Wolf Optimizer (GreyWolfOptimizer),
Particle Swarm Optimization (ParticleSwarmOptimization).
Feature Transformation Algorithms
Normalizer (Normalizer),
Standard Scaler (StandardScaler),
Maximum Absolute Scaler (MaxAbsScaler),
Quantile Transformer (QuantileTransformer),
Robust Scaler (RobustScaler).
Fitness Functions based on
Accuracy (Accuracy),
Cohen’s kappa (CohenKappa),
F1-Score (F1),
Precision (Precision).
Categorical Feature Encoders
One-Hot Encoder (OneHotEncoder).
Feature Imputers
Simple Imputer (SimpleImputer).
Licence
This package is distributed under the MIT License. This license can be found online at http://www.opensource.org/licenses/MIT.
Disclaimer
This framework is provided as-is, and there are no guarantees that it fits your purposes or that it is bug-free. Use it at your own risk!
References
[1] Iztok Fister Jr., Milan Zorman, Dušan Fister, Iztok Fister. Continuous optimizers for automatic design and evaluation of classification pipelines. In: Frontier applications of nature inspired computation. Springer tracts in nature-inspired computing, pp.281-301, 2020.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file NiaAML-1.1.2.tar.gz
.
File metadata
- Download URL: NiaAML-1.1.2.tar.gz
- Upload date:
- Size: 42.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.8.2 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 88d9f2bd125aed64a1c48904b9125d52e7e8747bc650686493f91f83f2252953 |
|
MD5 | c884b777f472005e1974340e65fc9eed |
|
BLAKE2b-256 | 6b221e92576f84d568d7d74fae6af372d03069203e40b3111920b8bbd5a96adf |
File details
Details for the file NiaAML-1.1.2-py3-none-any.whl
.
File metadata
- Download URL: NiaAML-1.1.2-py3-none-any.whl
- Upload date:
- Size: 99.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.4 CPython/3.8.2 Windows/10
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1671cd35b502baa8415d85b694d1a7fe17d879464ac9efa2944a4f3cc0df69f3 |
|
MD5 | 7e1dec4a03ea42bcd9aa2c3cf7753ce7 |
|
BLAKE2b-256 | 85fa3efd39922af7889920d38a4e2ba5ab8527086d578245cd47ca54dc4dd949 |