c#ncalc - 第1:1行'E'缺少EOF

时间:2015-11-05 21:39:28

标签: c# genetic-algorithm ncalc

我正在使用遗传算法来解决问题。 所以我发现这个名为NCAL的lib似乎是一个很好的方法。

所以我试图生成随机字符串,这些字符串将成为这样的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

0 个答案:

没有答案