0

方程式を解くための遺伝的アルゴリズムをいじっています。それで、私は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

4

0 に答える 0