方程式を解くための遺伝的アルゴリズムをいじっています。それで、私はNCALと呼ばれるこのライブラリを見つけました。これは良い方法だと思われます。
そこで、次のような NCALC 式になるいくつかのランダムな文字列を生成しようとしました。
private Expression getRandomExpression(int i)
{
string expression = ""; ;
double nr = random.NextDouble() * random.Next(100);
int sign = 1;
if (random.Next(2) > 0)
{
sign = -1;
}
Console.WriteLine("sign: " + sign + " i: " + i);
switch (i)
{
case 1:
expression = (sign.ToString() + "*" + nr.ToString() + "x");
break;
case 2:
expression = (sign.ToString() + nr.ToString() + "/x");
break;
case 3:
expression = (sign.ToString() + "x/" + nr.ToString());
break;
case 4:
expression = (sign.ToString() + "Pow(x," + nr.ToString()+")");
break;
default:
expression = (sign.ToString() + "*" + nr.ToString());
break;
}
return new Expression(expression);
}
次に、これらの要素をループして、合計をゴール関数と照合します。次のようにします。
public double calculateFitness(double[] goalFunction)
{
double fitness = 0.0;
for (int i = 1; i < goalFunction.Length; i++)
{
foreach (var element in genome)
{
try
{
element.Parameters["x"] = i;
var value = (double)element.Evaluate();
fitness += Math.Abs(goalFunction.ElementAt(i) - value);
}catch(Exception ex)
{
throw ex;
}
}
}
return fitness;
}
簡単に思えますが、「行 1:1 の 'x' に EOF がありません」という例外が発生し続けます。これを解決する方法について何か提案はありますか? または、より簡単な方法。:) ゴール関数を表す方程式を見つけたいです。
br