Skip to content

Implementation of Kohonen SOM for anomaly detection purposes.

License

Notifications You must be signed in to change notification settings

ann94827/som-anomaly-detector

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

SOM Anomaly Detection

This Python module provides a very simple, but efficient implementaion of Kohonen's Self-Organizing-Maps for anomaly detection purposes. The idea is based on the following paper:

Tian, J., Azarian, M. H., Pecht, M. (2014). Anomaly detection using self-organizing maps-based K-nearest neighbour Algorithm. Proceedings of the European Conference of the Prognostics and Health Management Society.

Simple description of the algorithm

  1. Train a self organizing map of some dimension on the set of normal data (possibly containing some noise or outliers).
  2. Per node in the SOM, count the number of training vectors mapped to this node, suppose we call this number the degree.
  3. Remove all nodes with degree less than a certain threshold.
  4. For each observation in the data to be assessed, perform k-NN wrt. the SOM nodes. And calculate the mean distance to the nodes found. This is the anomaly metric.
  5. Order the evaluation data wrt. to the anomaly metric.

How to install

Installation can be done by executing:

git clone https://github.com/FlorisHoogenboom/som-anomaly-detector.git

Subsequently one can install the package by just executing

pip install

in the directory to which the repository was cloned.

About

Implementation of Kohonen SOM for anomaly detection purposes.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%