autogoal

A Python framework for program synthesis with a focus on Automated Machine Learning.

https://github.com/gia-uh/autogoal

Science Score: 67.0%

This score indicates how likely this project is to be science-related based on various indicators:

  • CITATION.cff file
    Found CITATION.cff file
  • codemeta.json file
    Found codemeta.json file
  • .zenodo.json file
    Found .zenodo.json file
  • DOI references
    Found 4 DOI reference(s) in README
  • Academic publication links
    Links to: springer.com
  • Committers with academic emails
  • Institutional organization owner
  • JOSS paper metadata
  • Scientific vocabulary similarity
    Low similarity (15.5%) to scientific vocabulary

Keywords

automl framework machine-learning optimization program-synthesis python3

Keywords from Contributors

state-management interactive networks particles standardization optim embedded genomics hacking data-manager
Last synced: 4 months ago · JSON representation ·

Repository

A Python framework for program synthesis with a focus on Automated Machine Learning.

Basic Info
  • Host: GitHub
  • Owner: gia-uh
  • License: mit
  • Language: Python
  • Default Branch: main
  • Homepage: https://autogoal.uhgia.org
  • Size: 12.5 MB
Statistics
  • Stars: 211
  • Watchers: 11
  • Forks: 66
  • Open Issues: 25
  • Releases: 0
Topics
automl framework machine-learning optimization program-synthesis python3
Created over 5 years ago · Last pushed 7 months ago
Metadata Files
Readme License Citation

Readme.md

AutoGOAL Logo


PyPI PyPI - Python Version PyPI - License GitHub stars Twitter Follow

Docker Image Size (CPU) Docker Pulls


AutoGOAL is a Python library for automatically finding the best way to solve a given task. It has been designed mainly for Automated Machine Learning (aka AutoML) but it can be used in any scenario where you have several possible ways to solve a given task.

Technically speaking, AutoGOAL is a framework for program synthesis, i.e., finding the best program to solve a given problem, provided that the user can describe the space of all possible programs. AutoGOAL provides a set of low-level components to define different spaces and efficiently search in them. In the specific context of machine learning, AutoGOAL also provides high-level components that can be used as a black-box in almost any type of problem and dataset format.

⭐ Quickstart

AutoGOAL is first and foremost a framework for Automated Machine Learning. As such, it comes pre-packaged with hundreds of low-level machine learning algorithms that can be automatically assembled into pipelines for different problems.

The core of this functionality lies in the AutoML class.

To illustrate the simplicity of its use we will load a dataset and run an automatic classifier in it. The following code will run for approximately 5 minutes on a classic dataset.

```python from autogoal.datasets import cars from autogoal.kb import (MatrixContinuousDense, Supervised, VectorCategorical) from autogoal.ml import AutoML

Load dataset

X, y = cars.load()

Instantiate AutoML and define input/output types

automl = AutoML( input=(MatrixContinuousDense, Supervised[VectorCategorical]), output=VectorCategorical )

Run the pipeline search process

automl.fit(X, y)

Report the best pipeline

print(automl.bestpipeline) print(automl.bestscore) ```

Sensible defaults are defined for each of the many parameters of AutoML. Make sure to read the documentation for more information.

⚙️ Installation

The easiest way to get AutoGOAL up and running with all the dependencies is to pull the development Docker image, which is somewhat big:

docker pull autogoal/autogoal

Instructions for setting up Docker are available here.

Once you have the development image downloaded, you can fire up a console and use AutoGOAL interactively.

If you prefer to not use Docker, or you don't want all the dependencies, you can also install AutoGOAL directly with pip:

pip install autogoal

This will install the core library but you won't be able to use any of the underlying machine learning algorithms until you install the corresponding optional dependencies. You can install them all with:

pip install autogoal[contrib]

To fine-pick which dependencies you want, read the dependencies section.

⚠️ NOTE: By installing through pip you will get the latest release version of AutoGOAL, while by installing through Docker, you will get the latest development version.

The development version is mostly up-to-date with the main branch, hence it will probably contain more features, but also more bugs, than the release version.

💻 CLI

You can use AutoGOAL directly from the CLI. To see options just type:

autogoal

Using the CLI you can train and use AutoML models, download datasets and inspect the contrib libraries without writing a single line of code.

Read more in the CLI documentation.

🤩 Demo

An online demo app is available at autogoal.github.io/demo. This app showcases the main features of AutoGOAL in interactive case studies.

To run the demo locally, simply type:

docker run -p 8501:8501 autogoal/autogoal

And navigate to localhost:8501.

⚖️ API stability

We make a conscious effort to maintain a consistent public API across versions, but the private API can change at any time. In general, everything you can import from autogoal without underscores is considered public.

For example:

```python

"clean" imports are part of the public API

from autogoal import optimize
from autogoal.ml import AutoML
from autogoal.contrib.sklearn import find_classes

public members of public types as well

automl = AutoML automl.fit(...)

underscored imports are part of the private API

from autogoal.ml.automl import ... from autogoal.contrib.sklearn.generated import ...

as well as private members of any type

automl.inputtype(...)

```

These are our consistency rules:

  • Major breaking changes are introduced between major version updates, e.g., x.0 and y.0. These can be additions, removals, or modifications of any kind in any part of the API.

  • Between minor version updates, e.g., 1.x and 1.y, you can expect to find new functionality, but anything you can use from the public API will still be there with a consistent semantic (save for bugfixes).

  • Between micro version updates, e.g., 1.3.x and 1.3.y, the public API is frozen even for additions.

  • The private API can be changed at all times.

⚠️ While AutoGOAL is on public beta (versions 0.x) the public API is considered unstable and thus everything can change. However, we try to keep breaking changes to a minimum.

📚 Documentation

This documentation is available online at autogoal.github.io. Check the following sections:

  • User Guide: Step-by-step showcase of everything you need to know to use AutoGOAL.
  • Examples: The best way to learn how to use AutoGOAL by practice.
  • API: Details about the public API for AutoGOAL.

The HTML version can be deployed offline by downloading the AutoGOAL Docker image and running:

docker run -p 8000:8000 autogoal/autogoal mkdocs serve -a 0.0.0.0:8000

And navigating to localhost:8000.

📃 Publications

If you use AutoGOAL in academic research, please cite the following paper:

bibtex @article{estevez2020general, title={General-purpose hierarchical optimisation of machine learning pipelines with grammatical evolution}, author={Est{\'e}vez-Velarde, Suilan and Guti{\'e}rrez, Yoan and Almeida-Cruz, Yudivi{\'a}n and Montoyo, Andr{\'e}s}, journal={Information Sciences}, year={2020}, publisher={Elsevier}, doi={10.1016/j.ins.2020.07.035} }

The technologies and theoretical results leading up to AutoGOAL have been presented at different venues:

🤝 Contribution

Code is licensed under MIT. Read the details in the collaboration section.

This project follows the all-contributors specification. Any contribution will be given credit, from fixing typos, to reporting bugs, to implementing new core functionalities.

Here are all the current contributions.

🙏 Thanks!


Suilan Estevez-Velarde

💻 ⚠️ 🤔 📖

Alejandro Piad

💻 ⚠️ 📖

Yudivián Almeida Cruz

🤔 📖

ygutierrez

🤔 📖

Ernesto Luis Estevanell Valladares

💻 ⚠️

Alexander Gonzalez

💻 ⚠️

Anshu Trivedi

💻

Alex Coto

📖

Guillermo Blanco

🐛 💻 📖

yacth

🐛 💻

Brandon Fergerson

🐛

Aditya Nikhil

🐛

lucas-FP

🐛 💻

Leynier Gutiérrez González

📖

Ender Minyard

📖

Owner

  • Name: gia-uh
  • Login: gia-uh
  • Kind: organization

Citation (CITATION.cff)

cff-version: 1.2.0
message: "If you use this software, please cite it as below."
authors:
- family-names: Estévez-Velarde
  given-names: Suilan
- family-names: Gutiérrez
  given-names: Yoan
- family-names: Almeida-Cruz
  given-names: Yudivián
- family-names: Montoyo
  given-names: Andrés
title: "General-purpose hierarchical optimisation of machine learning pipelines with grammatical evolution"
version: 0.6.0
doi: 10.1016/j.ins.2020.07.035
journal: "Information Sciences"
publisher: Elsevier
year: 2020
url: https://github.com/autogoal/autogoal

GitHub Events

Total
  • Watch event: 2
  • Pull request event: 2
  • Create event: 1
Last Year
  • Watch event: 2
  • Pull request event: 2
  • Create event: 1

Committers

Last synced: 5 months ago

All Time
  • Total Commits: 1,024
  • Total Committers: 19
  • Avg Commits per committer: 53.895
  • Development Distribution Score (DDS): 0.377
Past Year
  • Commits: 1
  • Committers: 1
  • Avg Commits per committer: 1.0
  • Development Distribution Score (DDS): 0.0
Top Committers
Name Email Commits
Alejandro Piad a****d@g****m 638
Ernesto Estevanell e****v@g****m 171
rmarticedeno r****o@g****m 70
Suilan Estévez s****z@g****m 54
allcontributors[bot] 4****] 34
Ernesto Luis Estevanell Valladares e****l@i****s 13
Lucas Pereira l****e@g****m 9
yacth y****6@g****m 6
Carlos Bermudez c****v@g****m 6
Guillermo Blanco g****o@g****m 4
Alexander Gonzalez a****7@g****m 4
Ernesto Estevanell e****l@b****k 4
AnshuTrivedi a****k@g****m 3
dependabot[bot] 4****] 2
Suilan Estevez s****z@t****s 2
Alex Coto a****9@g****m 1
Ender Minyard 6****v 1
Lucas Pereira l****a@b****m 1
Leynier Gutiérrez González l****1@g****m 1
Committer Domains (Top 20 + Academic)