循环构造函数约束

A191919

我正在使用cord.math来求解具有非线性约束的系统。在此示例中,约束具有4个变量,, x => x[0] + x[1] + x[2] + x[3] <= 1但是如果约束应包括50个变量,该怎么办。如何建立, x => x[0] + x[1] + x[2] + ...+ x[50] <= 1周期?

namespace ConsoleApplication21
{
class Program
{
    static void Main(string[] args)
    {

        var f = new NonlinearObjectiveFunction(4, x => 0.010 * x[0] - 0.000543 * x[1] - 0.003440 * x[2] + 0.000292 * x[3]);

        var constraints = new[]
        {
           new NonlinearConstraint(4, x => x[0] + x[1] + x[2] + x[3] <= 1),
           new NonlinearConstraint(4, x => x[0] + x[1] + x[2] + x[3] >= 1),

        };

        var cobyla = new Cobyla(f, constraints);

        bool success = cobyla.Maximize();
        double minimum = cobyla.Value;        
        double[] solution = cobyla.Solution;
        Console.WriteLine(minimum);
    }
}
}
谢尔盖·卡里尼琴科(Sergey Kalinichenko)

如果您需要的是数组中所有值的总和,则可以使用LINQ的Sum()方法,如下所示:

new NonlinearConstraint(x.Length, x => x.Sum() >= 1)

通常,您可以将循环替换为LINQ的Enumerable.Range例如,要x[first]通过添加x[first+count-1],请使用以下表达式:

new NonlinearConstraint(
    x.Length
,   x => Enumerable.Range(first, count).Select(i => x[i]).Sum() >= 1
)

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章