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


C# GeneralMatrix.GetElement方法代码示例

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


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

示例1: displayMatrix

 //display specified matrix
 static void displayMatrix(GeneralMatrix displayMat)
 {
     for (int i = 0; i < displayMat.RowDimension; i++)
     {
         for (int j = 0; j < displayMat.ColumnDimension; j++)
         {
             Console.Write(displayMat.GetElement(i, j) + ",");
         }
         Console.WriteLine();
     }
 }
开发者ID:b-esf,项目名称:Crypto,代码行数:12,代码来源:Program.cs

示例2: Hessian

 public void Hessian()
 {
     double eps = 1e-5;
     double[] vector = {0,0,0};
     double[][] result = {new double[]{10.0, 2.0, -2.0},
                             new double[]{ 2.0, 4.0,  2.0},
                             new double[]{-2.0, 2.0,  4.0}};
     GeneralMatrix expectedMatrix = new GeneralMatrix(result);
     TestFunction f = new TestFunction();
     GeneralMatrix hessian = f.CalculateHessian(vector);
     for (int i=0;i<3; i++)
         for (int j=0;j<3; j++)
             Assert.IsTrue(System.Math.Abs(hessian.GetElement(i,j)-expectedMatrix.GetElement(i,j))<eps);
 }
开发者ID:kriskniaz,项目名称:pCode,代码行数:14,代码来源:Derivatives.cs

示例3: PCalc

        /// <summary>
        /// Average values of the priority matrix over sum of columns.
        /// set values of sum of averaged rows into a new matrix
        /// </summary>
        /// <param name="argMatrix"></param>
        /// <param name="selection"></param>
        public void PCalc(GeneralMatrix argMatrix, GeneralMatrix selection)
        {
            int n = argMatrix.ColumnDimension;
            GeneralMatrix sMatrix = new GeneralMatrix(argMatrix.ArrayCopy);

            double c=0.0;
            int i,j;

            for (i=0;i<sMatrix.ColumnDimension; i++)
            {
                c=0.0;
                for (j=0; j<sMatrix.RowDimension; j++)
                    c+=sMatrix.GetElement(j,i);
                selection.SetElement(i,0,c);
            }

            for (i=0;i<sMatrix.ColumnDimension; i++)
            {
                for (j=0; j<sMatrix.RowDimension; j++)
                    sMatrix.SetElement(j,i,sMatrix.GetElement(j,i)/selection.GetElement(i,0));

            }

            for (i=0;i<sMatrix.RowDimension; i++)
            {
                c=0.0;
                for (j=0; j<sMatrix.ColumnDimension; j++)
                    c+=sMatrix.GetElement(i,j);
                selection.SetElement(i,0,c/n);
            }
        }
开发者ID:kriskniaz,项目名称:pCode,代码行数:37,代码来源:PrioritiesSelector.cs

示例4: SetMatrix

 /// <summary>
 ///   Set a submatrix.
 /// </summary>
 /// <param name = "r">   Array of row indices.
 /// </param>
 /// <param name = "j0">  Initial column index
 /// </param>
 /// <param name = "j1">  Final column index
 /// </param>
 /// <param name = "x">   A(r(:),j0:j1)
 /// </param>
 /// <exception cref = "System.IndexOutOfRangeException"> Submatrix indices
 /// </exception>
 public virtual void SetMatrix(int[] r, int j0, int j1, GeneralMatrix x)
 {
     try
     {
         for (int i = 0; i < r.Length; i++)
         {
             for (int j = j0; j <= j1; j++)
             {
                 _a[r[i]][j] = x.GetElement(i, j - j0);
             }
         }
     }
     catch (IndexOutOfRangeException e)
     {
         throw new IndexOutOfRangeException("Submatrix indices", e);
     }
 }
开发者ID:firestrand,项目名称:DotNetMatrix,代码行数:30,代码来源:Matrix.cs

示例5: SetMatrix

 /// <summary>Set a submatrix.</summary>
 /// <param name="i0">  Initial row index
 /// </param>
 /// <param name="i1">  Final row index
 /// </param>
 /// <param name="c">   Array of column indices.
 /// </param>
 /// <param name="X">   A(i0:i1,c(:))
 /// </param>
 /// <exception cref="System.IndexOutOfRangeException">  Submatrix indices
 /// </exception>
 public virtual void SetMatrix(int i0, int i1, int[] c, GeneralMatrix X)
 {
     try
     {
         for (int i = i0; i <= i1; i++)
         {
             for (int j = 0; j < c.Length; j++)
             {
                 A[i][c[j]] = X.GetElement(i - i0, j);
             }
         }
     }
     catch (System.IndexOutOfRangeException e)
     {
         throw new System.IndexOutOfRangeException("Submatrix indices", e);
     }
 }
开发者ID:kriskniaz,项目名称:pCode,代码行数:28,代码来源:GeneralMatrix.cs

示例6: CalculateNextPoint

        private double[] CalculateNextPoint(double[] pX, double[] pGrad, GeneralMatrix hessian)
        {
            int i=0;
            double xmin=0;
            double step = _step;
            GeneralMatrix alfaX = new GeneralMatrix(_nDim,1);
            GeneralMatrix prevX = new GeneralMatrix(pX,_nDim);
            GeneralMatrix prevGrad = new GeneralMatrix(pGrad,_nDim);
            double[] intermediate = new double[_nDim];;

            alfaX = hessian.Multiply(prevGrad);

            //doing a line search to minimize alpha
            OneDWrapper wrapper = new OneDWrapper(_f,prevX,alfaX);
            LineSearch search = new LineSearch();
            double[] interval = new double[Constants.BRACKET_POINTS];
            int it1 = search.FindMinInterval(wrapper,_alpha,step,50,ref interval);
            int it2 = search.FindMinimumViaBrent(wrapper,interval[0],interval[1],interval[2],50,_epsilon, ref xmin);

            for (i=0;i<_nDim; i++)
                intermediate[i] = prevX.GetElement(i,0) - xmin*alfaX.GetElement(i,0);

            _alpha = xmin;

            return intermediate;
        }
开发者ID:kriskniaz,项目名称:pCode,代码行数:26,代码来源:Optimizer.cs

示例7: ConstructionFromAPackedArrayDoesNotAltersOriginalArrayValues

 public void ConstructionFromAPackedArrayDoesNotAltersOriginalArrayValues()
 {
     double[] packedColumns = new[] { 1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0, 12.0 };
     int numRows = 3; /* leading dimension of intended test Matrices */
     var b = new GeneralMatrix(packedColumns, numRows); //B still references array underneath
     var temp = b.GetElement(0, 0);
     packedColumns[0] = 0.0;
     Assert.IsTrue((temp - b.GetElement(0, 0)) == 0.0);
 }
开发者ID:firestrand,项目名称:DotNetMatrix,代码行数:9,代码来源:MatrixTests.cs

示例8: Substraction

        public void Substraction()
        {
            double[] columnwise = new double[]{1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0, 11.0, 12.0};
            double[][] avals = {new double[]{1.0, 4.0, 7.0, 10.0}, new double[]{2.0, 5.0, 8.0, 11.0}, new double[]{3.0, 6.0, 9.0, 12.0}};

            int validld = 3; /* leading dimension of intended test Matrices */

            //one dimensional array of doubles packed by columns ala Fortran
            //is passed to the constructor
            //the integer value tell the constructor how to
            //breakup one domensional value into mulidimensional column
            GeneralMatrix A = new GeneralMatrix(columnwise, validld);
            GeneralMatrix B = new GeneralMatrix(avals);
            double tmp = B.GetElement(0, 0);
            avals[0][0] = 0.0;
            GeneralMatrix C = B.Subtract(A);
            avals[0][0] = tmp;
            B = GeneralMatrix.Create(avals);
            tmp = B.GetElement(0, 0);
            avals[0][0] = 0.0;
            Assert.IsTrue(tmp==B.GetElement(0, 0));
        }
开发者ID:kriskniaz,项目名称:pCode,代码行数:22,代码来源:GeneralTests.cs

示例9: TestChoiceMatrix

        public void TestChoiceMatrix()
        {
            double[][] mat1 = new double[][]
                                {
                                    new double[] {1,2,3,4},
                                    new double[] {0,1,2,5},
                                    new double[] {0,0,1,5},
                                    new double[] {0,0,0,1}
                                };

            GeneralMatrix gmat1 = new GeneralMatrix(mat1);
            gmat1 = AHPModel.ExpandUtility(gmat1);

            double[][] mat2 = new double[][]
                                {
                                    new double[] {1,2,3,1},
                                    new double[] {0,1,2,3},
                                    new double[] {0,0,1,9},
                                    new double[] {0,0,0,1}
                                };
            GeneralMatrix gmat2 = new GeneralMatrix(mat2);
            gmat2 = AHPModel.ExpandUtility(gmat2);

            double[][] mat3 = new double[][]
                                {
                                    new double[] {1,4,2,2},
                                    new double[] {0,1,2,4},
                                    new double[] {0,0,1,4},
                                    new double[] {0,0,0,1}
                                };

            GeneralMatrix gmat3 = new GeneralMatrix(mat3);
            gmat3 = AHPModel.ExpandUtility(gmat3);

            //3 criteria 4 choices
            AHPModel model = new AHPModel(3,4);

            model.AddCriterionRatedChoices(0,mat1);
            model.AddCriterionRatedChoices(1,mat2);
            model.AddCriterionRatedChoices(2,mat3);

            GeneralMatrix matrix = model.ChoiceMatrix;

            GeneralMatrix nmat1 = matrix.GetMatrix(0,3,0,3);
            GeneralMatrix nmat2 = matrix.GetMatrix(0,3,4,7);
            GeneralMatrix nmat3 = matrix.GetMatrix(0,3,8,11);

            bool alarm = false;

            int i,j;

            for (i=0;i<nmat1.ColumnDimension;i++)
                for (j=0;j<nmat1.RowDimension;j++)
                    if (nmat1.GetElement(i,j)!=gmat1.GetElement(i,j))
                        alarm=true;

            for (i=0;i<nmat2.ColumnDimension;i++)
                for (j=0;j<nmat2.RowDimension;j++)
                    if (nmat2.GetElement(i,j)!=gmat2.GetElement(i,j))
                        alarm=true;

            for (i=0;i<nmat3.ColumnDimension;i++)
                for (j=0;j<nmat3.RowDimension;j++)
                    if (nmat3.GetElement(i,j)!=gmat3.GetElement(i,j))
                        alarm=true;

            Assert.IsFalse(alarm);
        }
开发者ID:kriskniaz,项目名称:pCode,代码行数:68,代码来源:TestAHP.cs

示例10: ConstructionFromAnArrayAltersOriginalArrayValues

 public void ConstructionFromAnArrayAltersOriginalArrayValues()
 {
     double[][] array = avals;
     var b = new GeneralMatrix(array); //B still references avals underneath
     var temp = b.GetElement(0, 0);
     array[0][0] = 0.0;
     Assert.IsTrue((temp - b.GetElement(0, 0)) != 0.0);
 }
开发者ID:firestrand,项目名称:DotNetMatrix,代码行数:8,代码来源:MatrixTests.cs

示例11: init

        /// <summary>Initializes this Metric object from metric matrix (called by constructor) </summary>
        /// <param name="m">The NxN metric matrix</param> 
        private void init(DotNetMatrix.GeneralMatrix m)
        {
            if (!Util.IsSymmetric(m))
                throw new Exception("The metric matrix must be symmetric");

            m_matrix = m.Copy();

            //            System.Console.WriteLine("m_matrix: " + Util.ToString(m_matrix));

            // compute eigen value decomposition
            m_eig = new DotNetMatrix.EigenvalueDecomposition(m_matrix);

            //            System.Console.WriteLine("m_eig: " + Util.ToString(m_eig.GetV()));

            m_invEigMatrix = m_eig.GetV().Transpose();

            m_eigenMetric = m_eig.RealEigenvalues;

            //            {
              //              DotNetMatrix.GeneralMatrix D = Util.Diagonal(m_eigenMetric);
            //            DotNetMatrix.GeneralMatrix tmp = m_eig.GetV().Multiply(D).Multiply(m_invEigMatrix);
            //                System.Console.WriteLine("input_matrix = " + Util.ToString(tmp));
              //      }

            m_isDiagonal = Util.IsDiagonal(m_matrix);
            if (!m_isDiagonal)
            {
                m_isEuclidean = m_isAntiEuclidean = false;
            }
            else
            {
                m_isEuclidean = m_isAntiEuclidean = true;
                for (int i = 0; i < m.RowDimension; i++)
                {
                    if (m_matrix.GetElement(i, i) != 1.0)
                        m_isEuclidean = false;
                    if (m_matrix.GetElement(i, i) != -1.0)
                        m_isAntiEuclidean = false;
                }
            }
        }
开发者ID:Sciumo,项目名称:gaigen,代码行数:43,代码来源:Metric.cs

示例12: GetSVs

 // Take SV columns from the U matrix
 private static GeneralMatrix GetSVs(GeneralMatrix matrix, int sv)
 {
     GeneralMatrix toPass = new GeneralMatrix(matrix.RowDimension, sv);
     for (int j = 0; j < sv; j++) {
         for (int i = 0; i < matrix.RowDimension; i++) {
             toPass.SetElement(i, j, matrix.GetElement(i, j));
         }
     }
     return toPass;
 }
开发者ID:Samangan,项目名称:automatic-galaxy-classification-tool,代码行数:11,代码来源:Logic.cs

示例13: PrintMatrix

 void PrintMatrix(GeneralMatrix matrix, StreamWriter output)
 {
     for (int j = 0; j < matrix.ColumnDimension; j++) {
         for (int i = 0; i < matrix.RowDimension; i++) {
             output.Write(matrix.GetElement(i, j) + ", ");
         }
         output.Write("\n");
     }
     output.Write("\n");
 }
开发者ID:Samangan,项目名称:automatic-galaxy-classification-tool,代码行数:10,代码来源:Logic.cs

示例14: GetElement

 public void GetElement()
 {
     double[][] avals = {new double[]{1.0, 4.0, 7.0, 10.0}, new double[]{2.0, 5.0, 8.0, 11.0}, new double[]{3.0, 6.0, 9.0, 12.0}};
     GeneralMatrix B = new GeneralMatrix(avals);
     Assert.AreEqual(B.GetElement(B.RowDimension-1,B.ColumnDimension-1),avals[B.RowDimension-1][B.ColumnDimension-1]);
 }
开发者ID:kriskniaz,项目名称:pCode,代码行数:6,代码来源:GeneralTests.cs

示例15: SetElementCorrectlySetsAMatrixElement

 public void SetElementCorrectlySetsAMatrixElement()
 {
     var matrix = new GeneralMatrix(avals);
     matrix.SetElement(ib,jb,0.0);
     Assert.AreEqual(0.0,matrix.GetElement(ib,jb));
 }
开发者ID:firestrand,项目名称:DotNetMatrix,代码行数:6,代码来源:MatrixTests.cs


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