Skip to content

Scikit-DYN2SEL is a framework for applying and implementing DCS techniques in the data stream mining context.

License

Notifications You must be signed in to change notification settings

luccaportes/Scikit-DYN2SEL

Repository files navigation

Scikit-DYN2SEL

codecov CircleCI Code style: black PyPI version Documentation Status CodeFactor
Scikit-DYN2SEL is a framework for applying and implementing DCS techniques in the data stream mining context.

Installation

Scikit-dyn2sel can be easily installed with pip. Just run:

pip install dyn2sel

Features

Implemented on top of scikit-multiflow

Scikit-DYN2SEL fully works with ensembles from the scikit-multiflow library, or any implementation that follows the same interface.

User-friendly

Scikit-DYN2SEL classifiers follows the same interface as scikit-multiflow, which is based on the popular scikit-learn. Thus, scikit-DYN2SEL will be extremely familiar if you know any of these libraries.

Stream learning tools

In its current state, scikit-multiflow contains data generators, multi-output/multi-target stream learning methods, change detection methods, evaluation methods, and more.

Open source and open to contributions

Distributed under the MIT license, scikit-DYN2SEL implements the current state of art methods, however if you thinks it that it misses a method, feel free to either open an issue or opening a pull request with your implementation.

Usage

The usage of Scikit-DYN2SEL is very straightforward.

from skmultiflow.evaluation import EvaluatePrequential
from skmultiflow.data import SEAGenerator
from skmultiflow.trees import HoeffdingTree
from dyn2sel.apply_dcs import DYNSEMethod
from dyn2sel.dcs_techniques import KNORAE

clf = DYNSEMethod(
    HoeffdingTree(), chunk_size=1000, 
    dcs_method=KNORAE(), max_ensemble_size=10)
gen = SEAGenerator()
ev = EvaluatePrequential()
ev.evaluate(gen, clf)

For a complete reference on the library, you can check the documentation.

Citation

If you use scikit-dyn2sel in a paper, please cite us as following:

@ARTICLE{dyn2sel,
       author = {{Portes Cavalheiro}, Lucca and {Barddal}, Jean Paul and
         {Souza de Britto Jr}, Alceu and {Heutte}, Laurent},
        title = "{scikit-dyn2sel -- A Dynamic Selection Framework for Data Streams}",
      journal = {arXiv e-prints},
     keywords = {Computer Science - Machine Learning},
         year = 2020,
        month = aug,
          eid = {arXiv:2008.08920},
        pages = {arXiv:2008.08920},
archivePrefix = {arXiv},
       eprint = {2008.08920},
 primaryClass = {cs.LG},
       adsurl = {https://ui.adsabs.harvard.edu/abs/2020arXiv200808920P},
      adsnote = {Provided by the SAO/NASA Astrophysics Data System}
}

About

Scikit-DYN2SEL is a framework for applying and implementing DCS techniques in the data stream mining context.

Resources

License

Stars

Watchers

Forks

Languages