Gaurav Hivre Report
Gaurav Hivre Report
Gaurav Hivre Report
Neural network simulations appear to be a recent development. However, this field was
established before the advent of computers, and has survived at least one major setback and
several eras.Many importand advances have been boosted by the use of inexpensive computer
emulations. Following an initial period of enthusiasm, the field survived a period of frustration
and disrepute. During this period when funding and professional support was minimal,
important advances were made by relatively few reserchers. These pioneers were able to
develop convincing technology which surpassed the limitations identified by Minsky and
Papert. Minsky and Papert, published a book (in 1969) in which they summed up a general
feeling of frustration (against neural networks) among researchers, and was thus accepted by
1
most without further analysis.
Currently, the neural network field enjoys a resurgence of interest and a corresponding increase
in funding.The first artificial neuron was produced in 1943 by the neurophysiologist Warren
McCulloch and the logician Walter Pits. But the technology available at that time did not allow
them to do too much.
Neural networks, with their remarkable ability to derive meaning from complicated or imprecise
data Why, can be used patterns and detect trends that are too complex to be noticed by to extract
2
1.4 Neural networks versus conventional computers
Neural networks take a different approach to problem solving than that of conventional
computers. Conventional computers use an algorithmic approach i.e. the computer follows a set
of instructions in order to solve a problem. Unless the specific steps that the computer needs to
follow are known the computer cannot solve the problem. That restricts the problem solving
capability of conventional computers to problems that we already understand and know how to
solve. But computers would be so much more useful if they could do things that we don't exactly
know how to do.
Neural networks process information in a similar way the human brain does. The network is
composed of a large number of highly interconnected processing elements(neurones) working in
parallel to solve a specific problem. Neural networks learn by example. They cannot be
programmed to perform a specific task. The examples must be selected carefully otherwise
useful time is wasted or even worse the network might be functioning incorrectly. The
disadvantage is that because the network finds out how to solve the problem by itself, its
operation can be unpredictable.
On the other hand, conventional computers use a cognitive approach to problem solving; the way
the problem is to solved must be known and stated in small unambiguous instructions. These
instructions are then converted to a high level language program and then into machine code that
the computer can understand. These machines are totally predictable; if anything goes wrong is
due to a software or hardware fault.
Neural networks and conventional algorithmic computers are not in competition but complement
each other. There are tasks are more suited to an algorithmic approach like arithmetic operations
and tasks that are more suited to neural networks. Even more, a large number of tasks, require
systems that use a combination of the two approaches (normally a conventional computer is used
to supervise the neural network) in order to perform at maximum efficiency.
3
2. Human and Artificial Neurones - investigating the similarities
Much is still unknown about how the brain trains itself to process information, so theories
abound. In the human brain, a typical neuron collects signals from others through a host of fine
structures called dendrites. The neuron sends out spikes of electrical activity through a long,
thin stand known as an axon, which splits into thousands of branches.
At the end of each branch, a structure called a synapse converts the activity from the axon into
electrical effects that inhibit or excite activity from the axon into electrical effects that inhibit or
excite activity in the connected neurones.
When a neuron receives excitatory input that is sufficiently large compared with its inhibitory
input, it sends a spike of electrical activity down its axon. Learning occurs by changing the
effectiveness of the synapses so that the influence of one neuron on another changes.
4
2.2 From Human Neurones to Artificial Neurones
We conduct these neural networks by first trying to deduce the essential features of neurones and
their interconnections. We then typically program a computer to simulate these features.
However because our knowledge of neurones is incomplete and our computing power is limited,
our models are necessarily gross idealisations of real networks of neurones.
5
3. An engineering approach
An artificial neuron is a device with many inputs and one output. The neuron has two modes of
operation; the training mode and the using mode. In the training mode, the neuron can be
trained to fire (or not), for particular input patterns. In the using mode, when a taught input
pattern is detected at the input, its associated output becomes the current output. If the input
pattern does not belong in the taught list of input patterns, the firing rule is used to determine
whether to fire or not.
A simple neuron
The firing rule is an important concept in neural networks and accounts for their high flexibility.
A firing rule determines how one calculates whether a neuron should fire for any input pattern. It
relates to all the input patterns, not only the ones on which the node was trained.
6
A simple firing rule can be implemented by using Hamming distance technique. The rule goes as
follows:
Take a collection of training patterns for a node, some of which cause it to fire (the 1-taught set
of patterns) and others which prevent it from doing so (the 0-taught set). Then the patterns not in
the collection cause the node to fire if, on comparison , they have more input elements in
common with the 'nearest' pattern in the 1-taught set than with the 'nearest' pattern in the 0-taught
set. If there is a tie, then the pattern remains in the undefined state.
For example, a 3-input neuron is taught to output 1 when the input (X1,X2 and X3) is 111 or 101
and to output 0 when the input is 000 or 001. Then, before applying the firing rule, the truth
table is;
X1: 0 0 0 0 1 1 1 1
X2: 0 0 1 1 0 0 1 1
X3: 0 1 0 1 0 1 0 1
As an example of the way the firing rule is applied, take the pattern 010. It differs from 000 in 1
element, from 001 in 2 elements, from 101 in 3 elements and from 111 in 2 elements. Therefore,
the 'nearest' pattern is 000 which belongs in the 0-taught set. Thus the firing rule requires that the
neuron should not fire when the input is 001. On the other hand, 011 is equally distant from two
taught patterns that have different outputs and thus the output stays undefined (0/1).
By applying the firing in every column the following truth table is obtained;
X1: 0 0 0 0 1 1 1 1
X2: 0 0 1 1 0 0 1 1
X3: 0 1 0 1 0 1 0 1
77
The difference between the two truth tables is called the generalisation of the neuron. Therefore
the firing rule gives the neuron a sense of similarity and enables it to respond 'sensibly' to
patterns not seen during training.
6
When the network is used, it identifies the input pattern and tries to output the associated output
pattern. The power of neural networks comes to life when a pattern that has no output associated
with it, is given as an input. In this case, the network gives the output that corresponds to a taught
input pattern that is least different from the given pattern.
Figure 1.
For example:
The network of figure 1 is trained to recognise the patterns T and H. The associated patterns are
all black and all white respectively as shown below.
If we represent black squares with 0 and white squares with 1 then the truth tables for the 3
neurones after generalisation are;
X11: 0 0 0 0 1 1 1 1
X12: 0 0 1 1 0 0 1 1
X13: 0 1 0 1 0 1 0 1
OUT: 0 0 1 1 0 0 1 1
77
Top neuron
X21: 0 0 0 0 1 1 1 1
X22: 0 0 1 1 0 0 1 1
X23: 0 1 0 1 0 1 0 1
X21: 0 0 0 0 1 1 1 1
X22: 0 0 1 1 0 0 1 1
X23: 0 1 0 1 0 1 0 1
OUT: 1 0 1 1 0 0 1 0
Bottom neuron
From the tables it can be seen the following associasions can be extracted:
In this case, it is obvious that the output should be all blacks since the input pattern is almost
the same as the 'T' pattern.
Here also, it is obvious that the output should be all whites since the input pattern is almost the
same as the 'H' pattern.
Here, the top row is 2 errors away from the a T and 3 from an H. So the top output is black. The
middle row is 1 error away from both T and H so the output is random. The bottom row is 1
error away from T and 2 away from H. Therefore the output is black. The total output of the
network is still in favour of the T shape.
3.4 A more complicated neuron
The previous neuron doesn't do anything that conventional conventional computers don't do
already. A more sophisticated neuron (figure 2) is the McCulloch and Pitts model (MCP). The
difference from the previous model is that the inputs are 'weighted', the effect that each input
has at decision making is dependent on the weight of the particular input. The weight of an
input is a number which when multiplied with the input gives the weighted input. These
weighted inputs are then added together and if they exceed a pre-set threshold value, the neuron
fires. In any other case the neuron does not fire.
The addition of input weights and of the threshold makes this neuron a very flexible and
powerful one. The MCP neuron has the ability to adapt to a particular situation by changing its
weights and/or threshold. Various algorithms exist that cause the neuron to 'adapt'; the most used
ones are the Delta rule and the back error propagation. The former is used in feed-forward
networks and the latter in feedback networks.
4 Architecture of neural networks
Feed-forward ANNs (figure 1) allow signals to travel one way only; from input to output. There
is no feedback (loops) i.e. the output of any layer does not affect that same layer. Feed-forward
ANNs tend to be straight forward networks that associate inputs with outputs. They are
extensively used in pattern recognition. This type of organisation is also referred to as bottom-up
or top-down.
Feedback networks (figure 1) can have signals travelling in both directions by introducing loops
in the network. Feedback networks are very powerful and can get extremely complicated.
Feedback networks are dynamic; their 'state' is changing continuously until they reach an
equilibrium point. They remain at the equilibrium point until the input changes and a new
equilibrium needs to be found. Feedback architectures are also referred to as interactive or
recurrent, although the latter term is often used to denote feedback connections in single-layer
organisations.
The commonest type of artificial neural network consists of three groups, or layers, of units: a
layer of "input" units is connected to a layer of "hidden" units, which is connected to a layer of
"output" units. (see Figure 4.1)
The activity of the input units represents the raw information that is fed into the network.
The activity of each hidden unit is determined by the activities of the input units and the
weights on the connections between the input and the hidden units.
The behaviour of the output units depends on the activity of the hidden units and the weights
between the hidden and output units.
This simple type of network is interesting because the hidden units are free to construct their
own representations of the input. The weights between the input and hidden units determine
when each hidden unit is active, and so by modifying these weights, a hidden unit can choose
what it represents.
4.4 Perceptrons
The most influential work on neural nets in the 60's went under the heading of 'perceptrons' a
term coined by Frank Rosenblatt. The perceptron (figure 4.4) turns out to be an MCP model (
neuron with weighted inputs ) with some additional, fixed, pre--processing. Units labelled A1,
A2, Aj , Ap are called association units and their task is to extract specific, localised featured
from the input images. Perceptrons mimic the basic idea behind the mammalian visual system.
They were mainly used in pattern recognition even though their capabilities extended a lot
more.
Figure 4.4
In 1969 Minsky and Papert wrote a book in which they described the limitations of single layer
Perceptrons. The impact that the book had was tremendous and caused a lot of neural network
5. The Learning Process
The memorisation of patterns and the subsequent response of the network can be categorised into
two general paradigms:
associative mapping in which the network learns to produce a particular pattern on the set of
input units whenever another particular pattern is applied on the set of input units. The associtive
mapping can generally be broken down into two mechanisms:
auto-association: an input pattern is associated with itself and the states of input and output
units coincide. This is used to provide pattern completition, ie to produce a pattern whenever a
portion of it or a distorted pattern is presented. In the second case, the network actually stores
pairs of patterns building an association between two sets of patterns.
nearest-neighbour recall, where the output pattern produced corresponds to the input pattern
stored, which is closest to the pattern presented, and
interpolative recall, where the output pattern is a similarity dependent interpolation of the
patterns stored corresponding to the pattern presented. Yet another paradigm, which is a variant
associative mapping is classification, ie when there is a fixed set of categories into which the
input patterns are to be classified.
regularity detection in which units learn to respond to particular properties of the input
patterns. Whereas in asssociative mapping the network stores the relationships among patterns,
in regularity detection the response of each unit has a particular 'meaning'. This type of learning
mechanism is essential for feature discovery and knowledge representation.
Every neural network posseses knowledge which is contained in the values of the
connections weights. Modifying the knowledge stored in the network as a function of
experience implies a learning rule for changing the values of the weights.
Information is stored in the weight matrix W of a neural network. Learning is the determination
of the weights. Following the way learning is performed, we can distinguish two major
categories of neural networks:
fixed networks in which the weights cannot be changed, ie dW/dt=0. In such networks, the
weights are fixed a priori according to the problem to solve.
adaptive networks which are able to change their weights, ie dW/dt not= 0.
All learning methods used for adaptive neural networks can be classified into two major
categories:
Supervised learning which incorporates an external teacher, so that each output unit is told
what its desired response to input signals ought to be. During the learning process global
information may be required. Paradigms of supervised learning include error-correction learning,
reinforcement learning and stochastic learning.
An important issue conserning supervised learning is the problem of error convergence, ie the
minimisation of error between the desired and computed unit values. The aim is to determine
a set of weights which minimises the error. One well-known method, which is common to
many learning paradigms is the least mean square (LMS) convergence.
Unsupervised learning uses no external teacher and is based upon only local information. It
is also referred to as self-organisation, in the sense that it self-organises data presented to the
network and detects their emergent collective properties. Paradigms of unsupervised learning are
Hebbian lerning and competitive learning.
Ano2.2 From Human Neurones to Artificial Neuronesther aspect of learning concerns the
distinction or not of a seperate phase, during which the network is trained, and a subsequent
operation phase. We say that a neural network learns off-line if the learning phase and the
operation phase are distinct. A neural network learns on-line if it learns and operates at the same
time. Usually, supervised learning is performed off-line, whereas usupervised learning is
performed on-line.
The behaviour of an ANN (Artificial Neural Network) depends on both the weights and the
input-output function (transfer function) that is specified for the units. This function
typically falls into one of three categories:
For threshold units, the output is set at one of two levels, depending on whether the total
input is greater than or less than some threshold value.
For sigmoid units, the output varies continuously but not linearly as the input changes. Sigmoid
units bear a greater resemblance to real neurones than do linear or threshold units, but all three
must be considered rough approximations.
To make a neural network that performs some specific task, we must choose how the units are
connected to one another (see figure 4.1), and we must set the weights on the connections
appropriately. The connections determine whether it is possible for one unit to influence another.
The weights specify the strength of the influence.
We can teach a three-layer network to perform a particular task by using the following
procedure:
Assume that we want a network to recognise hand-written digits. We might use an array of, say,
256 sensors, each recording the presence or absence of ink in a small area of a single digit. The
network would therefore need 256 input units (one for each sensor), 10 output units (one for
each kind of digit) and a number of hidden units.
For each kind of digit recorded by the sensors, the network should produce high activity in the
appropriate output unit and low activity in the other output units.
To train the network, we present an image of a digit and compare the actual activity of the 10
output units with the desired activity. We then calculate the error, which is defined as the square
of the difference between the actual and the desired activities. Next we change the weight of
each connection so as to reduce the error.We repeat this training process for many different
images of each different images of each kind of digit until the network classifies every image
correctly.
To implement this procedure we need to calculate the error derivative for the weight (EW) in
order to change the weight by an amount that is proportional to the rate at which the error
changes as the weight is changed. One way to calculate the EW is to perturb a weight slightly
and observe how the error changes. But that method is inefficient because it requires a separate
perturbation for each of the many weights.
Another way to calculate the EW is to use the Back-propagation algorithm which is described
below, and has become nowadays one of the most important tools for training neural networks. It
was developed independently by two teams, one (Fogelman-Soulie, Gallinari and Le Cun) in
France, the other (Rumelhart, Hinton and Williams) in U.S.
In order to train a neural network to perform some task, we must adjust the weights of each unit
in such a way that the error between the desired output and the actual output is reduced. This
process requires that the neural network compute the error derivative of the weights (EW). In
other words, it must calculate how the error changes as each weight is increased or decreased
slightly. The back propagation algorithm is the most widely used method for determining the
EW.
The back-propagation algorithm is easiest to understand if all the units in the network are linear.
The algorithm computes each EW by first computing the EA, the rate at which the error changes
as the activity level of a unit is changed. For output units, the EA is simply the difference
between the actual and the desired output. To compute the EA for a hidden unit in the layer just
before the output layer, we first identify all the weights between that hidden unit and the output
units to which it is connected. We then multiply those weights by the EAs of those output units
and add the products. This sum equals the EA for the chosen hidden unit. After calculating all
the EAs in the hidden layer just before the output layer, we can compute in like fashion the EAs
for other layers, moving from layer to layer in a direction opposite to the way activities
propagate through the network. This is what gives back propagation its name. Once the EA has
been computed for a unit, it is straight forward to compute the EW for each incoming
connection of the unit. The EW is the product of the EA and the activity through the incoming
connection.
Note that for non-linear units, (see Appendix C) the back-propagation algorithm includes an
extra step. Before back-propagating, the EA must be converted into the EI, the rate at which the
error changes as the total input received by a unit is changed.
6. Applications of neural networks
Given this description of neural networks and how they work, what real world applications are
they suited for? Neural networks have broad applicability to real world business problems. In
fact, they have already been successfully applied in many industries.
Since neural networks are best at identifying patterns or trends in data, they are well suited for
prediction or forecasting needs including:
sales forecasting
industrial process control
customer research
data validation
risk management
target marketing
But to give you some more specific examples; ANN are also used in the following specific
paradigms: recognition of speakers in communications; diagnosis of hepatitis; recovery of
telecommunications from faulty software; interpretation of multimeaning Chinese words;
undersea mine detection; texture analysis; three-dimensional object recognition; hand-written
word recognition; and facial recognition.
6.2 Neural networks in medicine
Artificial Neural Networks (ANN) are currently a 'hot' research area in medicine and it is
believed that they will receive extensive application to biomedical systems in the next few
years. At the moment, the research is mostly on modelling parts of the human body and
recognising diseases from various scans (e.g. cardiograms, CAT scans, ultrasonic scans, etc.).
Neural networks are ideal in recognising diseases using scans since there is no need to provide a
specific algorithm on how to identify the disease. Neural networks learn by example so the
details of how to recognise the disease are not needed. What is needed is a set of examples that
are representative of all the variations of the disease. The quantity of examples is not as
important as the 'quantity'. The examples need to be selected very carefully if the system is to
perform reliably and efficiently.
6.2.1 Modelling and Diagnosing the Cardiovascular System
Neural Networks are used experimentally to model the human cardiovascular system. Diagnosis
can be achieved by building a model of the cardiovascular system of an individual and
comparing it with the real time physiological measurements taken from the patient. If this
routine is carried out regularly, potential harmful medical conditions can be detected at an early
stage and thus make the process of combating the disease much easier.
Another reason that justifies the use of ANN technology, is the ability of ANNs to provide
sensor fusion which is the combining of values from several different sensors. Sensor fusion
enables the ANNs to learn complex relationships among the individual sensor values, which
would otherwise be lost if the values were individually analysed. In medical modelling and
diagnosis, this implies that even though each sensor in a set may be sensitive only to a specific
physiological variable, ANNs are capable of detecting complex medical conditions by fusing
the data from the individual biomedical sensors.
ANNs are used experimentally to implement electronic noses. Electronic noses have several
potential applications in telemedicine. Telemedicine is the practice of medicine over long
distances via a communication link. The electronic nose would identify odours in the remote
surgical environment. These identified odours would then be electronically transmitted to
another site where an door generation system would recreate them. Because the sense of smell
can be an important sense to the surgeon, telesmell would enhance telepresent surgery.
6.2.3 Instant Physician
There is a marketing application which has been integrated with a neural network system. The
Airline Marketing Tactician (a trademark abbreviated as AMT) is a computer system made of
various intelligent technologies including expert systems. A feedforward neural network is
integrated with the AMT and was trained using back-propagation to assist the marketing control
of airline seat allocations. The adaptive neural approach was amenable to rule expression.
Additionaly, the application's environment changed rapidly and constantly, which required a
continuously adaptive solution. The system is used to monitor and recommend booking advice
for each departure. Such information has a direct impact on the profitability of an airline and
can provide a technological advantage for users of the system. [Hutchison & Stephens, 1987]
While it is significant that neural networks have been applied to this problem, it is also important
to see that this intelligent technology can be integrated with expert systems and other approaches
to make a functional system. Neural networks were used to discover the influence of undefined
interactions by the various variables. While these interactions were not defined, they were used
by the neural system to develop useful conclusions. It is also noteworthy to see that neural
networks can influence the bottom line.
The HNC company, founded by Robert Hecht-Nielsen, has developed several neural network
applications. One of them is the Credit Scoring system which increase the profitability of the
existing model up to 27%. The HNC neural systems were also applied to mortgage screening. A
neural network automated mortgage insurance underwritting system was developed by the
Nestor Company. This system was trained with 5048 applications of which 2597 were certified.
The data related to property and borrower qualifications. In a conservative mode the system
agreed on the underwritters on 97% of the cases. In the liberal model the system agreed 84% of
the cases. This is system run on an Apollo DN3000 and used 250K memory while processing a
case file in approximately 1 sec.
7. Conclusion
The computing world has a lot to gain fron neural networks. Their ability to learn by example
makes them very flexible and powerful. Furthermore there is no need to devise an algorithm in
order to perform a specific task; i.e. there is no need to understand the internal mechanisms of
that task. They are also very well suited for real time systems because of their fast responseand
computational times which are due to their parallel architecture.
Neural networks also contribute to other areas of research such as neurology and psychology.
They are regularly used to model parts of living organisms and to investigate the internal
mechanisms of the brain.
Perhaps the most exciting aspect of neural networks is the possibility that some day 'consious'
networks might be produced. There is a number of scientists arguing that conciousness is a
'mechanical' property and that 'consious' neural networks are a realistic possibility.
Finally, I would like to state that even though neural networks have a huge potential we will only
get the best of them when they are intergrated with computing, AI, fuzzy logic and related
subjects.
References:
www.google.com
www.wikipedia.com
www.yahoo.com