Skip to content
/ samoa Public
forked from YahooArchive/samoa

SAMOA (Scalable Advanced Massive Online Analysis) is a distributed streaming machine learning (ML) framework that contains a programing abstraction for distributed streaming ML algorithms.

License

Notifications You must be signed in to change notification settings

abifet/samoa

 
 

Repository files navigation

SAMOA: Scalable Advanced Massive Online Analysis.

SAMOA is a platform for mining on big data streams. It is a distributed streaming machine learning (ML) framework that contains a programing abstraction for distributed streaming ML algorithms.

SAMOA enables development of new ML algorithms without dealing with the complexity of underlying streaming processing engines (SPE, such as Apache Storm and Apache S4). SAMOA also provides extensibility in integrating new SPEs into the framework. These features allow SAMOA users to develop distributed streaming ML algorithms once and to execute the algorithms in multiple SPEs, i.e., code the algorithms once and execute them in multiple SPEs.

Build

###Storm mode

Simply clone the repository and install SAMOA.

git clone git@github.com:yahoo/samoa.git
cd samoa
mvn -Pstorm package

The deployable jar for SAMOA will be in target/SAMOA-Storm-0.0.1-SNAPSHOT.jar.

###S4 mode

If you want to compile SAMOA for S4, you will need to install the S4 dependencies manually as explained in Executing SAMOA with Apache S4.

Once the dependencies if needed are installed, you can simply clone the repository and install SAMOA.

git clone git@github.com:yahoo/samoa.git
cd samoa
mvn -Ps4 package

###Local mode

If you want to test SAMOA in a local environment, simply clone the repository and install SAMOA.

git clone git@github.com:yahoo/samoa.git
cd samoa
mvn package

The deployable jar for SAMOA will be in target/SAMOA-Local-0.0.1-SNAPSHOT.jar.

Documentation

The documentation is intended to give an introduction on how to use SAMOA in the various different ways possible. As a user you can use it to develop new algorithms and test different Stream Processing Engines.

  • [0 Getting Started in 5 minutes](../../wiki/Getting Started)

  • [1 Scalable Advanced Massive Online Analysis](../../wiki/Scalable Advanced Massive Online Analysis)

    • [1.0 Building SAMOA](../../wiki/Building SAMOA)
    • [1.1 Executing SAMOA with Apache Storm](../../wiki/Executing SAMOA with Apache Storm)
    • 1.2 Executing SAMOA with Apache S4
  • [2 SAMOA and Machine Learning](../../wiki/SAMOA and Machine Learning)

    • [2.1 Prequential Evaluation Task](../../wiki/Prequential Evaluation Task)
    • [2.2 Vertical Hoeffding Tree Classifier](../../wiki/Vertical Hoeffding Tree Classifier)
    • [2.3 Distributed Stream Clustering](../../wiki/Distributed Stream Clustering)
  • [3 SAMOA Topology](../../wiki/SAMOA Topology)

    • 3.1 Processor
    • [3.2 Content Event](../../wiki/Content Event)
    • 3.3 Stream
    • 3.4 Task
    • [3.5 Topology Builder](../../wiki/Topology Builder)
    • [3.6 Topology Starter](../../wiki/Topology Starter)
    • 3.7 Learner
    • [3.8 Processing Item](../../wiki/Processing Item)
  • [4 Developing New Tasks in SAMOA](../../wiki/Developing New Tasks in SAMOA)

Slides

SAMOA Slides

G. De Francisci Morales SAMOA: A Platform for Mining Big Data Streams Keynote Talk at RAMSS ’13: 2nd International Workshop on Real-Time Analysis and Mining of Social Streams WWW, Rio De Janeiro, 2013.

SAMOA Developer's Guide

SAMOA Developer's guide

Contributors

List of contributors to the SAMOA project

License

The use and distribution terms for this software are covered by the Apache License, Version 2.0 (http://www.apache.org/licenses/LICENSE-2.0.html).

About

SAMOA (Scalable Advanced Massive Online Analysis) is a distributed streaming machine learning (ML) framework that contains a programing abstraction for distributed streaming ML algorithms.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 99.4%
  • Shell 0.6%