This article aims to present the reader to the current workings of the Accord.NET Machine Learning Framework; show where the sequences classifiers are located within the framework, describe their source code, how the Markov namespace is organized and the general ideas behind this organization. This will also provide the base to talk about Hidden Conditional Random Fields, which is my main goal in this series.
|
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.ComponentModel;
using System.IO;
using System.Xml.Serialization;
using System.Drawing;
namespace Gestures
{
public class Database
{
public BindingList<string> Classes { get; private set; }
public BindingList<Sequence> Samples { get; private set; }
public Database()
{
Classes = new BindingList<string>();
Samples = new BindingList<Sequence>();
}
public void Save(Stream stream)
{
var serializer = new XmlSerializer(typeof(BindingList<Sequence>));
serializer.Serialize(stream, Samples);
}
public void Load(Stream stream)
{
var serializer = new XmlSerializer(typeof(BindingList<Sequence>));
var samples = (BindingList<Sequence>)serializer.Deserialize(stream);
Classes.Clear();
foreach (string label in samples.First().Classes)
Classes.Add(label);
Samples.Clear();
foreach (Sequence sample in samples)
{
sample.Classes = Classes;
Samples.Add(sample);
}
}
public Sequence Add(Point[] sequence, string classLabel)
{
if (sequence == null || sequence.Length == 0)
return null;
if (!Classes.Contains(classLabel))
Classes.Add(classLabel);
int classIndex = Classes.IndexOf(classLabel);
Sequence sample = new Sequence()
{
Classes = Classes,
SourcePath = sequence,
Output = classIndex
};
Samples.Add(sample);
return sample;
}
public void Clear()
{
Classes.Clear();
Samples.Clear();
}
public int SamplesPerClass()
{
int min = 0;
foreach (string label in Classes)
{
int c = Samples.Count(p => p.OutputName == label);
if (min == 0)
min = c;
else if (c < min)
min = c;
}
return min;
}
}
}
|
By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.
If a file you wish to view isn't highlighted, and is a text file (not binary), please
let us know and we'll add colourisation support for it.
Computer and technology enthusiast, interested in artificial intelligence and image processing. Has a Master's degree on Computer Science specialized on Image and Signal Processing, with expertise on Machine Learning, Computer Vision, Pattern Recognition and Data Mining systems. Author of the
Accord.NET Framework for developing scientific computing applications.
If you would like to hire good developers to build your dream application, please check out
DaitanGroup, one of the top outsourcing companies in Brazil. This company, located in Brazil's Sillicon Valley but with US-based offices, has huge experience developing telecommunications software for large and small companies worldwide.