Class Network
- java.lang.Object
- 
- org.apache.commons.math4.neuralnet.Network
 
- 
- 
Constructor SummaryConstructors Constructor Description Network(long firstId, int featureSize)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddLink(Neuron a, Neuron b)Adds a link from neuronato neuronb.Networkcopy()Performs a deep copy of this instance.longcreateNeuron(double[] features)Creates a neuron and assigns it a unique identifier.voiddeleteLink(Neuron a, Neuron b)Deletes the link between neuronsaandb.voiddeleteNeuron(Neuron neuron)Deletes a neuron.static Networkfrom(int featureSize, long[] idList, double[][] featureList, long[][] neighbourIdList)Builds a network from a list of neurons and their neighbours.intgetFeaturesSize()Gets the size of the neurons' features set.Collection<Neuron>getNeighbours(Iterable<Neuron> neurons)Retrieves the neurons in the neighbourhood of any neuron in theneuronslist.Collection<Neuron>getNeighbours(Iterable<Neuron> neurons, Iterable<Neuron> exclude)Retrieves the neurons in the neighbourhood of any neuron in theneuronslist.Collection<Neuron>getNeighbours(Neuron neuron)Retrieves the neighbours of the given neuron.Collection<Neuron>getNeighbours(Neuron neuron, Iterable<Neuron> exclude)Retrieves the neighbours of the given neuron.NeurongetNeuron(long id)Retrieves the neuron with the given (unique)id.Collection<Neuron>getNeurons()Iterator<Neuron>iterator()- 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface java.lang.IterableforEach, spliterator
 
- 
 
- 
- 
- 
Constructor Detail- 
Networkpublic Network(long firstId, int featureSize) - Parameters:
- firstId- Identifier of the first neuron that will be added to this network.
- featureSize- Size of the neuron's features.
 
 
- 
 - 
Method Detail- 
frompublic static Network from(int featureSize, long[] idList, double[][] featureList, long[][] neighbourIdList) Builds a network from a list of neurons and their neighbours.- Parameters:
- featureSize- Number of features.
- idList- List of neuron identifiers.
- featureList- List of neuron features.
- neighbourIdList- Links associated to each of the neurons in- idList.
- Returns:
- a new instance.
- Throws:
- IllegalArgumentException- if an inconsistency is detected.
 
 - 
copypublic Network copy() Performs a deep copy of this instance. Upon return, the copied and original instances will be independent: Updating one will not affect the other.- Returns:
- a new instance with the same state as this instance.
- Since:
- 3.6
 
 - 
getNeuronspublic Collection<Neuron> getNeurons() - Returns:
- a shallow copy of the network's neurons.
 
 - 
createNeuronpublic long createNeuron(double[] features) Creates a neuron and assigns it a unique identifier.- Parameters:
- features- Initial values for the neuron's features.
- Returns:
- the neuron's identifier.
- Throws:
- IllegalArgumentException- if the length of- featuresis different from the expected size (as set by the- constructor).
 
 - 
deleteNeuronpublic void deleteNeuron(Neuron neuron) Deletes a neuron. Links from all neighbours to the removed neuron will also bedeleted.- Parameters:
- neuron- Neuron to be removed from this network.
- Throws:
- NoSuchElementException- if- ndoes not belong to this network.
 
 - 
getFeaturesSizepublic int getFeaturesSize() Gets the size of the neurons' features set.- Returns:
- the size of the features set.
 
 - 
addLinkpublic void addLink(Neuron a, Neuron b) Adds a link from neuronato neuronb. Note: the link is not bi-directional; if a bi-directional link is required, an additional call must be made withaandbexchanged in the argument list.- Parameters:
- a- Neuron.
- b- Neuron.
- Throws:
- NoSuchElementException- if the neurons do not exist in the network.
 
 - 
deleteLinkpublic void deleteLink(Neuron a, Neuron b) Deletes the link between neuronsaandb.- Parameters:
- a- Neuron.
- b- Neuron.
- Throws:
- NoSuchElementException- if the neurons do not exist in the network.
 
 - 
getNeuronpublic Neuron getNeuron(long id) Retrieves the neuron with the given (unique)id.- Parameters:
- id- Identifier.
- Returns:
- the neuron associated with the given id.
- Throws:
- NoSuchElementException- if the neuron does not exist in the network.
 
 - 
getNeighbourspublic Collection<Neuron> getNeighbours(Iterable<Neuron> neurons) Retrieves the neurons in the neighbourhood of any neuron in theneuronslist.- Parameters:
- neurons- Neurons for which to retrieve the neighbours.
- Returns:
- the list of neighbours.
- See Also:
- getNeighbours(Iterable,Iterable)
 
 - 
getNeighbourspublic Collection<Neuron> getNeighbours(Iterable<Neuron> neurons, Iterable<Neuron> exclude) Retrieves the neurons in the neighbourhood of any neuron in theneuronslist. Theexcludelist allows to retrieve the "concentric" neighbourhoods by removing the neurons that belong to the inner "circles".- Parameters:
- neurons- Neurons for which to retrieve the neighbours.
- exclude- Neurons to exclude from the returned list. Can be- null.
- Returns:
- the list of neighbours.
 
 - 
getNeighbourspublic Collection<Neuron> getNeighbours(Neuron neuron) Retrieves the neighbours of the given neuron.- Parameters:
- neuron- Neuron for which to retrieve the neighbours.
- Returns:
- the list of neighbours.
- See Also:
- getNeighbours(Neuron,Iterable)
 
 - 
getNeighbourspublic Collection<Neuron> getNeighbours(Neuron neuron, Iterable<Neuron> exclude) Retrieves the neighbours of the given neuron.- Parameters:
- neuron- Neuron for which to retrieve the neighbours.
- exclude- Neurons to exclude from the returned list. Can be- null.
- Returns:
- the list of neighbours.
 
 
- 
 
-