Click here to Skip to main content
15,886,067 members
Articles / Programming Languages / C#

Neural Networks on C#

Rate me:
Please Sign up or sign in to vote.
4.95/5 (307 votes)
19 Nov 2006GPL313 min read 1.2M   73.6K   710  
The articles describes a C# library for neural network computations, and their application for several problem solving.
// AForge Neural Net Library
//
// Copyright � Andrew Kirillov, 2005-2006
// andrew.kirillov@gmail.com
//

namespace AForge.Neuro
{
	using System;

	/// <summary>
	/// Distance network
	/// </summary>
	///
	/// <remarks>Distance network is a neural network of only one <see cref="DistanceLayer">distance
	/// layer</see>. The network is a base for such neural networks as SOM, Elastic net, etc.
	/// </remarks>
	///
	public class DistanceNetwork : Network
	{
		/// <summary>
		/// Network's layers accessor
		/// </summary>
		/// 
		/// <param name="index">Layer index</param>
		/// 
		/// <remarks>Allows to access network's layer.</remarks>
		/// 
		public new DistanceLayer this[int index]
		{
			get { return ( (DistanceLayer) layers[index] ); }
		}

		/// <summary>
		/// Initializes a new instance of the <see cref="DistanceNetwork"/> class
		/// </summary>
		/// 
		/// <param name="inputsCount">Network's inputs count</param>
		/// <param name="neuronsCount">Network's neurons count</param>
		/// 
		/// <remarks>The new network will be randomized (see <see cref="Neuron.Randomize"/>
		/// method) after it is created.</remarks>
		/// 
		public DistanceNetwork( int inputsCount, int neuronsCount )
						: base( inputsCount, 1 )
		{
			// create layer
			layers[0] = new DistanceLayer( neuronsCount, inputsCount );
		}

		/// <summary>
		/// Get winner neuron
		/// </summary>
		/// 
		/// <returns>Index of the winner neuron</returns>
		/// 
		/// <remarks>The method returns index of the neuron, which weights have
		/// the minimum distance from network's input.</remarks>
		/// 
		public int GetWinner( )
		{
			// find the MIN value
			double	min = output[0];
			int		minIndex = 0;

			for ( int i = 1, n = output.Length; i < n; i++ )
			{
				if ( output[i] < min )
				{
					// found new MIN value
					min = output[i];
					minIndex = i;
				}
			}

			return minIndex;
		}
	}
}

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.

License

This article, along with any associated source code and files, is licensed under The GNU General Public License (GPLv3)


Written By
Software Developer IBM
United Kingdom United Kingdom
Started software development at about 15 years old and it seems like now it lasts most part of my life. Fortunately did not spend too much time with Z80 and BK0010 and switched to 8086 and further. Similar with programming languages – luckily managed to get away from BASIC and Pascal to things like Assembler, C, C++ and then C#. Apart from daily programming for food, do it also for hobby, where mostly enjoy areas like Computer Vision, Robotics and AI. This led to some open source stuff like AForge.NET, Computer Vision Sandbox, cam2web, ANNT, etc.

Comments and Discussions