本文整理汇总了C#中Encog.Neural.Networks.BasicNetwork.GetLayerTotalNeuronCount方法的典型用法代码示例。如果您正苦于以下问题:C# BasicNetwork.GetLayerTotalNeuronCount方法的具体用法?C# BasicNetwork.GetLayerTotalNeuronCount怎么用?C# BasicNetwork.GetLayerTotalNeuronCount使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Encog.Neural.Networks.BasicNetwork
的用法示例。
在下文中一共展示了BasicNetwork.GetLayerTotalNeuronCount方法的8个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。
示例1: AnalyzeNetwork
//.........这里部分代码省略.........
num12 = network.GetWeight(num3, num10, num11);
goto Label_0127;
}
goto Label_00C3;
Label_0115:
values.Add(num12);
num2++;
if (0 == 0)
{
num11++;
if (((uint) num9) < 0)
{
goto Label_02BF;
}
goto Label_00FF;
}
goto Label_0184;
Label_0127:
if (!network.Structure.ConnectionLimited)
{
goto Label_014B;
}
Label_0134:
if (Math.Abs(num12) < network.Structure.ConnectionLimit)
{
num++;
if ((((uint) num8) - ((uint) num12)) >= 0)
{
goto Label_0167;
}
goto Label_000B;
}
Label_014B:
list.Add(num12);
if ((((uint) num7) & 0) == 0)
{
goto Label_0115;
}
Label_0167:
if ((((uint) num2) & 0) == 0)
{
goto Label_014B;
}
goto Label_0127;
Label_0184:
if (4 != 0)
{
goto Label_00C3;
}
goto Label_0057;
Label_01E8:
num11 = 0;
goto Label_00FF;
Label_01F2:
num8++;
Label_01F8:
if (num8 < layerNeuronCount)
{
goto Label_02BF;
}
num7++;
Label_0207:
if (num7 < num4)
{
num8 = 0;
goto Label_01F8;
}
if (((((uint) num8) | 1) != 0) && (num4 == layerTotalNeuronCount))
{
goto Label_0184;
}
num10 = num4;
goto Label_01E8;
Label_02BF:
num9 = network.GetWeight(num3, num7, num8);
if (0 == 0)
{
if (network.Structure.ConnectionLimited && (((((uint) num10) + ((uint) num)) < 0) || (Math.Abs(num9) < network.Structure.ConnectionLimit)))
{
num++;
}
list2.Add(num9);
}
values.Add(num9);
num2++;
goto Label_01F2;
Label_0317:
num4 = network.GetLayerNeuronCount(num3);
layerTotalNeuronCount = network.GetLayerTotalNeuronCount(num3);
if (((uint) num7) > uint.MaxValue)
{
goto Label_0134;
}
layerNeuronCount = network.GetLayerNeuronCount(num3 + 1);
num7 = 0;
if ((((uint) layerTotalNeuronCount) + ((uint) layerTotalNeuronCount)) >= 0)
{
}
goto Label_0207;
}
示例2: RandomizeSynapse
/// <summary>
/// Randomize the connections between two layers.
/// </summary>
/// <param name="network">The network to randomize.</param>
/// <param name="fromLayer">The starting layer.</param>
private void RandomizeSynapse(BasicNetwork network, int fromLayer)
{
int toLayer = fromLayer + 1;
int toCount = network.GetLayerNeuronCount(toLayer);
int fromCount = network.GetLayerNeuronCount(fromLayer);
int fromCountTotalCount = network.GetLayerTotalNeuronCount(fromLayer);
IActivationFunction af = network.GetActivation(toLayer);
double low = CalculateRange(af, Double.NegativeInfinity);
double high = CalculateRange(af, Double.PositiveInfinity);
double b = 0.7d * Math.Pow(toCount, (1d / fromCount)) / (high - low);
for (int toNeuron = 0; toNeuron < toCount; toNeuron++)
{
if (fromCount != fromCountTotalCount)
{
double w = RangeRandomizer.Randomize(-b, b);
network.SetWeight(fromLayer, fromCount, toNeuron, w);
}
for (int fromNeuron = 0; fromNeuron < fromCount; fromNeuron++)
{
double w = RangeRandomizer.Randomize(0, b);
network.SetWeight(fromLayer, fromNeuron, toNeuron, w);
}
}
}
示例3: Randomize
/// <summary>
/// Randomize one level of a neural network.
/// </summary>
///
/// <param name="network">The network to randomize</param>
/// <param name="fromLayer">The from level to randomize.</param>
public override void Randomize(BasicNetwork network, int fromLayer)
{
int fromCount = network.GetLayerTotalNeuronCount(fromLayer);
int toCount = network.GetLayerNeuronCount(fromLayer + 1);
for (int fromNeuron = 0; fromNeuron < fromCount; fromNeuron++)
{
for (int toNeuron = 0; toNeuron < toCount; toNeuron++)
{
double v = CalculateValue(toCount);
network.SetWeight(fromLayer, fromNeuron, toNeuron, v);
}
}
}
示例4: Randomize
/// <summary>
/// Randomize one level of a neural network.
/// </summary>
///
/// <param name="network">The network to randomize</param>
/// <param name="fromLayer">The from level to randomize.</param>
public virtual void Randomize(BasicNetwork network, int fromLayer)
{
int fromCount = network.GetLayerTotalNeuronCount(fromLayer);
int toCount = network.GetLayerNeuronCount(fromLayer + 1);
for (int fromNeuron = 0; fromNeuron < fromCount; fromNeuron++)
{
for (int toNeuron = 0; toNeuron < toCount; toNeuron++)
{
double v = network.GetWeight(fromLayer, fromNeuron, toNeuron);
v = Randomize(v);
network.SetWeight(fromLayer, fromNeuron, toNeuron, v);
}
}
}
示例5: Randomize
/// <summary>
/// Randomize one level of a neural network.
/// </summary>
///
/// <param name="network">The network to randomize</param>
/// <param name="fromLayer">The from level to randomize.</param>
public override void Randomize(BasicNetwork network, int fromLayer)
{
int fromCount = network.GetLayerTotalNeuronCount(fromLayer);
int toCount = network.GetLayerNeuronCount(fromLayer + 1);
for (int toNeuron = 0; toNeuron < toCount; toNeuron++)
{
double n = 0.0;
for (int fromNeuron = 0; fromNeuron < fromCount; fromNeuron++)
{
double w = network.GetWeight(fromLayer, fromNeuron, toNeuron);
n += w * w;
}
n = Math.Sqrt(n);
for (int fromNeuron = 0; fromNeuron < fromCount; fromNeuron++)
{
double w = network.GetWeight(fromLayer, fromNeuron, toNeuron);
w = _beta * w / n;
network.SetWeight(fromLayer, fromNeuron, toNeuron, w);
}
}
}
示例6: Randomize
public override void Randomize(BasicNetwork network, int fromLayer)
{
int num2;
int num3;
double num4;
int num5;
double num6;
int num7;
double num8;
int layerTotalNeuronCount = network.GetLayerTotalNeuronCount(fromLayer);
goto Label_00DF;
Label_0011:
if (num3 < num2)
{
num4 = 0.0;
num5 = 0;
}
else if ((((uint) num8) - ((uint) layerTotalNeuronCount)) >= 0)
{
return;
}
while (true)
{
if (num5 >= layerTotalNeuronCount)
{
num4 = Math.Sqrt(num4);
num7 = 0;
if ((((uint) num4) + ((uint) num2)) < 0)
{
break;
}
goto Label_0065;
}
num6 = network.GetWeight(fromLayer, num5, num3);
num4 += num6 * num6;
num5++;
}
Label_0044:
if ((((uint) fromLayer) + ((uint) num6)) > uint.MaxValue)
{
goto Label_00DF;
}
num7++;
Label_0065:
if (num7 < layerTotalNeuronCount)
{
num8 = network.GetWeight(fromLayer, num7, num3);
}
else
{
num3++;
goto Label_0011;
}
Label_009C:
num8 = (this._xd7d571ecee49d1e4 * num8) / num4;
network.SetWeight(fromLayer, num7, num3, num8);
goto Label_0044;
Label_00DF:
num2 = network.GetLayerNeuronCount(fromLayer + 1);
if (((uint) num8) > uint.MaxValue)
{
goto Label_009C;
}
num3 = 0;
goto Label_0011;
}
示例7: Randomize
public override void Randomize(BasicNetwork network, int fromLayer)
{
int num4;
double num5;
int layerTotalNeuronCount = network.GetLayerTotalNeuronCount(fromLayer);
int layerNeuronCount = network.GetLayerNeuronCount(fromLayer + 1);
int fromNeuron = 0;
if (((uint) fromLayer) < 0)
{
goto Label_0012;
}
Label_000E:
if (fromNeuron < layerTotalNeuronCount)
{
num4 = 0;
goto Label_0054;
}
Label_0012:
if (((uint) num5) > uint.MaxValue)
{
goto Label_0054;
}
if ((((uint) fromNeuron) + ((uint) fromNeuron)) >= 0)
{
return;
}
Label_003C:
num5 = this.x7417261f548b2c9b(layerNeuronCount);
network.SetWeight(fromLayer, fromNeuron, num4, num5);
num4++;
Label_0054:
if (num4 < layerNeuronCount)
{
goto Label_003C;
}
fromNeuron++;
goto Label_000E;
}
示例8: Randomize
public virtual void Randomize(BasicNetwork network, int fromLayer)
{
int num4;
double num5;
int layerTotalNeuronCount = network.GetLayerTotalNeuronCount(fromLayer);
int layerNeuronCount = network.GetLayerNeuronCount(fromLayer + 1);
int fromNeuron = 0;
goto Label_002C;
Label_000D:
fromNeuron++;
if ((((uint) fromNeuron) + ((uint) fromNeuron)) > uint.MaxValue)
{
goto Label_004B;
}
if (0 != 0)
{
goto Label_003C;
}
Label_002C:
if (fromNeuron < layerTotalNeuronCount)
{
goto Label_0067;
}
return;
Label_003C:
network.SetWeight(fromLayer, fromNeuron, num4, num5);
num4++;
Label_004B:
if (num4 < layerNeuronCount)
{
num5 = network.GetWeight(fromLayer, fromNeuron, num4);
if (((uint) num5) >= 0)
{
num5 = this.Randomize(num5);
goto Label_003C;
}
goto Label_000D;
}
if ((((uint) fromLayer) + ((uint) fromLayer)) >= 0)
{
goto Label_000D;
}
Label_0067:
num4 = 0;
goto Label_004B;
}