C++ Neural Networks and Fuzzy Logic:The Kohonen Self-Organizing Map
Click Here!
function GetCookie (name)
{
var arg = name + "=";
var alen = arg.length;
var clen = document.cookie.length;
var i = 0;
while (i < clen)
{
var j = i + alen;
if (document.cookie.substring(i, j) == arg) {
var end = document.cookie.indexOf (";", j);
if (end == -1)
end = document.cookie.length;
return unescape(document.cookie.substring(j, end));
}
i = document.cookie.indexOf(" ", i) + 1;
if (i == 0) break;
}
return null;
}
var m1='';
var gifstr=GetCookie("UsrType");
if((gifstr!=0 ) && (gifstr!=null)) { m2=gifstr; }
document.write(m1+m2+m3);
Keyword
Title
Author
ISBN
Publisher
Imprint
Brief
Full
Advanced Search
Search Tips
Please Select
-----------
Components
Content Mgt
Certification
Databases
Enterprise Mgt
Fun/Games
Groupware
Hardware
Intranet Dev
Middleware
Multimedia
Networks
OS
Prod Apps
Programming
Security
UI
Web Services
Webmaster
Y2K
-----------
New Titles
-----------
Free Archive
To access the contents, click the chapter and section titles.
C++ Neural Networks and Fuzzy Logic
(Publisher: IDG Books Worldwide, Inc.)
Author(s): Valluru B. Rao
ISBN: 1558515526
Publication Date: 06/01/95
Search this book:
Previous
Table of Contents
Next
C++ Code for Implementing a Kohonen Map
The C++ code for the Kohonen map draws on much of the code developed for the backpropagation simulator. The Kohonen map is a much simpler program and may not rely on as large a data set for input. The Kohonen map program uses only two files, an input file and an output file. In order to use the program, you must create an input data set and save this in a file called input.dat. The output file is called kohonen.dat and is saved in your current working directory. You will get more details shortly on the formats of these files.
The Kohonen Network
The Kohonen network has two layers, an input layer and a Kohonen output layer. (See Figure 11.4). The input layer is a size determined by the user and must match the size of each row (pattern) in the input data file.
Figure 11.4 A Kohonen network.
Modeling Lateral Inhibition and Excitation
The mexican hat function shows positive values for an immediate neighborhood around the neuron and negative values for distant neurons. A true method of modeling would incorporate mutual excitation or support for neurons that are within the neighborhood (with this excitation increasing for nearer neurons) and inhibition for distant neurons outside the neighborhood. For the sake of computational efficiency, we model lateral inhibition and excitation by looking at the maximum output for the output neurons and making that output belong to a winner neuron. Other outputs are inhibited by setting their outputs to zero. Training, or weight update, is performed on all outputs that are within a neighborhood size distance from the winner neuron. Neurons outside the neighborhood do not participate in training. The true way of modeling lateral inhibition would be too expensive since the number of lateral connections is quite large. You will find that this approximation will lead to a network with many if not all of the properties of a true modeling approach of a Kohonen network.
Classes to be Used
We use many of the classes from the backpropagation simulator. We require only two layers, the input layer and the Kohonen layer. We make a new layer class called the Kohonen layer class, and a new network class called the Kohonen_network.
Revisiting the Layer Class
The layer class needs to be slightly modified, as shown in Listing 11.1.
Listing 11.1 Modification of layer.h
// layer.h V.Rao, H. Rao
// header file for the layer class hierarchy and
// the network class
#define MAX_LAYERS 5
#define MAX_VECTORS 100
class network;
class Kohonen_network;
class layer
{
protected:
int num_inputs;
int num_outputs;
float *outputs;// pointer to array of outputs
float *inputs; // pointer to array of inputs, which
// are outputs of some other layer
friend network;
friend Kohonen_network; // update for Kohonen model
public:
virtual void calc_out()=0;
};
...
Here the changes are indicated in italic. You notice that the Kohonen_network is made a friend to the layer class, so that the Kohonen_network can have access to the data of a layer.
A New Layer Class for a Kohonen Layer
The next step to take is to create a Kohonen_layer class and a Kohonen_network class. This is shown in Listing 11.2.
Listing 11.2 The Kohonen_layer class and Kohonen_network class in layerk.h
// layerk.h V.Rao, H. Rao
// header file for the Kohonen layer and
// the Kohonen network
class Kohonen_network;
class Kohonen_layer: public layer
{
protected:
float * weights;
int winner_index;
float win_distance;
int neighborhood_size;
friend Kohonen_network;
public:
Kohonen_layer(int, int, int);
~Kohonen_layer();
virtual void calc_out();
void randomize_weights();
void update_neigh_size(int);
void update_weights(const float);
void list_weights();
void list_outputs();
float get_win_dist();
};
class Kohonen_network
{
private:
layer *layer_ptr[2];
int layer_size[2];
int neighborhood_size;
public:
Kohonen_network();
~Kohonen_network();
void get_layer_info();
void set_up_network(int);
void randomize_weights();
void update_neigh_size(int);
void update_weights(const float);
void list_weights();
void list_outputs();
void get_next_vector(FILE *);
void process_next_pattern();
float get_win_dist();
int get_win_index();
};
The Kohonen_layer is derived from the layer class, so it has pointers inherited that point to a set of outputs and a set of inputs. Lets look at some of the functions and member variables.
Previous
Table of Contents
Next
Products | Contact Us | About Us | Privacy | Ad Info | Home
Use of this site is subject to certain Terms & Conditions, Copyright © 1996-1999 EarthWeb Inc.
All rights reserved. Reproduction whole or in part in any form or medium without express written permision of EarthWeb is prohibited.
Wyszukiwarka
Podobne podstrony:
274 279 lesl3b4yz6xa7m3isjf22yetzbqfiwblbz6lrra274 279 (2)274,2,artykulrozdzial (279)nipponicumid)274278 279279 281 ryvlygit7x6kx4rpzyopztpswwn4bk6rqqmnn7i07 (279)274?2109 operator piecow do obrobki cieplnej274 275Ustawa o ochr przyrody Dz U 1934 Nr 31, poz 274rozdzial (279)276 279więcej podobnych podstron