当前位置: 首页>>代码示例>>C#>>正文


C# Vector.Multiply方法代码示例

本文整理汇总了C#中Vector.Multiply方法的典型用法代码示例。如果您正苦于以下问题:C# Vector.Multiply方法的具体用法?C# Vector.Multiply怎么用?C# Vector.Multiply使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Vector的用法示例。


在下文中一共展示了Vector.Multiply方法的9个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: CalculateTrueResidual

        /// <summary>
        /// Calculates the <c>true</c> residual of the matrix equation Ax = b according to: residual = b - Ax
        /// </summary>
        /// <param name="matrix">Instance of the <see cref="Matrix"/> A.</param>
        /// <param name="residual">Residual values in <see cref="Vector"/>.</param>
        /// <param name="x">Instance of the <see cref="Vector"/> x.</param>
        /// <param name="b">Instance of the <see cref="Vector"/> b.</param>
        private static void CalculateTrueResidual(Matrix matrix, Vector residual, Vector x, Vector b)
        {
            // -Ax = residual
            matrix.Multiply(x, residual);
            residual.Multiply(-1, residual);

            // residual + b
            residual.Add(b, residual);
        }
开发者ID:nyurik,项目名称:mathnet-numerics,代码行数:16,代码来源:GpBiCg.cs

示例2: CalculateTrueResidual

        /// <summary>
        /// Calculates the <c>true</c> residual of the matrix equation Ax = b according to: residual = b - Ax
        /// </summary>
        /// <param name="matrix">Instance of the <see cref="Matrix"/> A.</param>
        /// <param name="residual">Residual values in <see cref="Vector"/>.</param>
        /// <param name="x">Instance of the <see cref="Vector"/> x.</param>
        /// <param name="b">Instance of the <see cref="Vector"/> b.</param>
        private static void CalculateTrueResidual(Matrix matrix, Vector residual, Vector x, Vector b)
        {
            // -Ax = residual
            matrix.Multiply(x, residual);
            
            // Do not use residual = residual.Negate() because it creates another object
            residual.Multiply(-1, residual);

            // residual + b
            residual.Add(b, residual);
        }
开发者ID:EricGT,项目名称:mathnet-numerics,代码行数:18,代码来源:BiCgStab.cs

示例3: SimpleMultiply

        public void SimpleMultiply()
        {
            Vector vector1 = new Vector(new double[] { 1.0, 2.0 });
            Vector vector2 = new Vector(new double[] { 3.0, 4.0 });

            Matrix matrix = vector1.Multiply(vector2);

            Assert.AreEqual(new Matrix(new double[][] { new double[] { 1.0 * 3.0, 1.0 * 4.0 }, new double[] { 2.0 * 3.0, 2.0 * 4.0 } }), matrix);
        }
开发者ID:ajlopez,项目名称:MathelSharp,代码行数:9,代码来源:VectorTests.cs

示例4: SimpleMultiplyByNumber

        public void SimpleMultiplyByNumber()
        {
            Vector vector1 = new Vector(new double[] { 1.0, 2.0, 3.0 });
            Vector vector2 = new Vector(new double[] { 1.0 * 3.0, 2.0 * 3.0, 3.0 * 3.0 });

            Vector vector = vector1.Multiply(3.0);
            Assert.AreEqual(vector2, vector);
        }
开发者ID:ajlopez,项目名称:MathelSharp,代码行数:8,代码来源:VectorTests.cs

示例5: _initializeVertices

        /// <summary>
        /// Construct an initial simplex, given starting guesses for the constants, and
        /// initial step sizes for each dimension
        /// </summary>
        /// <param name="simplexConstants"></param>
        /// <returns></returns>
        private static Vector[] _initializeVertices(SimplexConstant[] simplexConstants)
        {
            int numDimensions = simplexConstants.Length;
            Vector[] vertices = new Vector[numDimensions + 1];

            // define one point of the simplex as the given initial guesses
            Vector p0 = new Vector(numDimensions);
            for (int i = 0; i < numDimensions; i++)
            {
                p0[i] = simplexConstants[i].Value;
            }

            // now fill in the vertices, creating the additional points as:
            // P(i) = P(0) + Scale(i) * UnitVector(i)
            vertices[0] = p0;
            for (int i = 0; i < numDimensions; i++)
            {
                double scale = simplexConstants[i].InitialPerturbation;
                Vector unitVector = new Vector(numDimensions);
                unitVector[i] = 1;
                vertices[i + 1] = p0.Add(unitVector.Multiply(scale));
            }
            return vertices;
        }
开发者ID:ricksladkey,项目名称:Dirichlet,代码行数:30,代码来源:NelderMeadSimplex.cs

示例6: _computeCentroid

 /// <summary>
 /// Compute the centroid of all points except the worst
 /// </summary>
 /// <param name="vertices"></param>
 /// <param name="errorProfile"></param>
 /// <returns></returns>
 private static Vector _computeCentroid(Vector[] vertices, ErrorProfile errorProfile)
 {
     int numVertices = vertices.Length;
     // find the centroid of all points except the worst one
     Vector centroid = new Vector(numVertices - 1);
     for (int i = 0; i < numVertices; i++)
     {
         if (i != errorProfile.HighestIndex)
         {
             centroid = centroid.Add(vertices[i]);
         }
     }
     return centroid.Multiply(1.0d / (numVertices - 1));
 }
开发者ID:ricksladkey,项目名称:Dirichlet,代码行数:20,代码来源:NelderMeadSimplex.cs

示例7: Normalize

 public void Normalize(Vector vector)
 {
     vector.Sub(avgs, vector);       // shift
     vector.Multiply(istds, vector); // scale
 }
开发者ID:pxqr,项目名称:nanon,代码行数:5,代码来源:Normalization.cs

示例8: AlphaFunction

 /// <summary>
 ///     Альфа-функция
 /// </summary>
 /// <param name="alpha"></param>
 /// <param name="dir"></param>
 /// <returns></returns>
 public double AlphaFunction(double alpha, Vector<double> dir)
 {
     return Y(Point + dir.Multiply(alpha));
 }
开发者ID:OlegFilimonov,项目名称:optimisation,代码行数:10,代码来源:FunctionHolder.cs

示例9: AlphaDiffFunction

 /// <summary>
 ///     Альфа-функция дифференцирования
 /// </summary>
 /// <param name="alpha"></param>
 /// <param name="dir"></param>
 /// <returns></returns>
 public double AlphaDiffFunction(double alpha, Vector<double> dir)
 {
     return DiffFunction(Point + dir.Multiply(alpha), dir);
 }
开发者ID:OlegFilimonov,项目名称:optimisation,代码行数:10,代码来源:FunctionHolder.cs


注:本文中的Vector.Multiply方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。