本文整理汇总了Golang中github.com/maxxk/neurgo.Cortex.CreateNeuronInLayer方法的典型用法代码示例。如果您正苦于以下问题:Golang Cortex.CreateNeuronInLayer方法的具体用法?Golang Cortex.CreateNeuronInLayer怎么用?Golang Cortex.CreateNeuronInLayer使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类github.com/maxxk/neurgo.Cortex
的用法示例。
在下文中一共展示了Cortex.CreateNeuronInLayer方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Golang代码示例。
示例1: AddNeuronNonRecurrent
func AddNeuronNonRecurrent(cortex *ng.Cortex) (bool, MutateResult) {
numAttempts := len(cortex.AllNodeIds()) * 5
for i := 0; i < numAttempts; i++ {
nodeIdLayerMap := cortex.NodeIdLayerMap()
neuronLayerMap := cortex.NeuronLayerMap()
randomLayer := neuronLayerMap.ChooseRandomLayer()
upstreamNodeId := nodeIdLayerMap.ChooseNodeIdPrecedingLayer(randomLayer)
if upstreamNodeId == nil {
continue
}
downstreamNodeId := findDownstreamNodeId(cortex, nodeIdLayerMap, randomLayer)
if downstreamNodeId == nil {
continue
}
neuron := cortex.CreateNeuronInLayer(randomLayer)
neuronAddInlinkFrom(neuron, upstreamNodeId)
neuronAddOutlinkTo(neuron, downstreamNodeId)
return true, neuron
}
return false, nil
}
示例2: Outsplice
func Outsplice(cortex *ng.Cortex, chooseOutbound OutboundChooser) (bool, *ng.Neuron) {
numAttempts := len(cortex.AllNodeIds()) * 5
for i := 0; i < numAttempts; i++ {
neuronA := randomNeuron(cortex)
outbound := chooseOutbound(neuronA)
if outbound == nil {
continue
}
if neuronA.NodeId.UUID == outbound.NodeId.UUID {
continue
}
nodeIdB := outbound.NodeId
// figure out which layer neuronK will go in
nodeIdLayerMap := cortex.NodeIdLayerMap()
layerA := neuronA.NodeId.LayerIndex
layerB := nodeIdB.LayerIndex
layerK := nodeIdLayerMap.LayerBetweenOrNew(layerA, layerB)
// create neuron K
neuronK := cortex.CreateNeuronInLayer(layerK)
// disconnect neuronA <-> nodeB
nodeBConnector := cortex.FindInboundConnector(nodeIdB)
ng.DisconnectOutbound(neuronA, nodeIdB)
ng.DisconnectInbound(nodeBConnector, neuronA)
// connect neuronA -> neuronK
weights := randomWeights(1)
ng.ConnectOutbound(neuronA, neuronK)
ng.ConnectInboundWeighted(neuronK, neuronA, weights)
// connect neuronK -> nodeB
switch nodeIdB.NodeType {
case ng.NEURON:
neuronB := cortex.FindNeuron(nodeIdB)
ng.ConnectOutbound(neuronK, neuronB)
ng.ConnectInboundWeighted(nodeBConnector, neuronK, weights)
case ng.ACTUATOR:
actuatorB := cortex.FindActuator(nodeIdB)
ng.ConnectOutbound(neuronK, actuatorB)
ng.ConnectInbound(nodeBConnector, neuronK)
}
return true, neuronK
}
return false, nil
}
示例3: AddNeuronRecurrent
func AddNeuronRecurrent(cortex *ng.Cortex) (bool, MutateResult) {
numAttempts := len(cortex.AllNodeIds()) * 5
for i := 0; i < numAttempts; i++ {
nodeIdLayerMap := cortex.NodeIdLayerMap()
neuronLayerMap := cortex.NeuronLayerMap()
randomLayer := neuronLayerMap.ChooseRandomLayer()
inboundNodeId := findRecurrentInboundNodeId(cortex,
nodeIdLayerMap,
randomLayer)
if inboundNodeId == nil {
log.Printf("Warn: unable to find inbound node id")
continue
}
if randomLayer == inboundNodeId.LayerIndex {
continue
}
neuron := cortex.CreateNeuronInLayer(randomLayer)
outboundNodeId := findRecurrentOutboundNodeId(cortex,
nodeIdLayerMap,
randomLayer)
if outboundNodeId == nil {
log.Printf("Warn: unable to find outbound node id")
continue
}
neuronAddInlinkFrom(neuron, inboundNodeId)
neuronAddOutlinkTo(neuron, outboundNodeId)
return true, neuron
}
logg.LogTo("NEURVOLVE", "return false, nil")
return false, nil
}