當前位置: 首頁>>代碼示例>>C#>>正文


C# Matrix.ValidateIsSymmetric方法代碼示例

本文整理匯總了C#中System.Matrix.ValidateIsSymmetric方法的典型用法代碼示例。如果您正苦於以下問題:C# Matrix.ValidateIsSymmetric方法的具體用法?C# Matrix.ValidateIsSymmetric怎麽用?C# Matrix.ValidateIsSymmetric使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在System.Matrix的用法示例。


在下文中一共展示了Matrix.ValidateIsSymmetric方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: Decompose

      /// <summary>
      /// Given a positive-definite symmetric matrix <c>A[0..n][0..n]</c>, 
      /// this routine constructs its Cholesky decomposition,  <c> A = L*(L^T) </c>. 
      /// </summary>
      /// <remarks>
      /// The operations count is <c>(N^3)/6</c> executions of the inner loop (consisting of 
      /// one multiply and one subtract), with also N square roots. 
      /// This is about a factor 2 better than LU decomposition of <c>A</c> 
      /// (where its symmetry would be ignored).
      /// </remarks>
      /// <param name="matrix">Square Symmetric Definite-defined matrix A. 
      /// </param>
      /// <exception cref="ArgumentNullException"><paramref name="matrix"/> is a null reference.</exception>
      /// <exception cref="ArgumentException"><paramref name="matrix"/> is a not Symmetric.</exception>
      /// <exception cref="ArgumentException"><paramref name="matrix"/> is a null Square.</exception>
      /// <returns> The Cholesky factor L is returned</returns>
      public void Decompose(Matrix matrix)
      {

         Guard.ArgumentNotNull(matrix, "a");


          matrix.ValidateIsSymmetric();
         

         var aRows = matrix.Rows;

         var res = new Matrix(aRows, aRows);

         for (var i = 0; i < aRows; i++)
         {
            int j;
            for (j = i; j < aRows; j++)
            {
               int k;
               double sum;
               for (sum = matrix[i, j], k = i - 1; k >= 0; k--)
               {
                  sum -= res[i, k] * res[j, k];
               }

               if (i == j)
               {
                  if (sum <= 0)
                  {
                      throw new ArgumentException(isNotPositiveDefinite);
                  }

                   res[i, i] = Math.Sqrt(sum);
               }
               else
               {
                  res[j, i] = sum / res[i, i];
               }
            }
         }
         LeftFactorMatrix = res;
      }
開發者ID:Ivan-Dimitrov-bg,項目名稱:.Net-framework,代碼行數:58,代碼來源:CholeskyDecomposition.cs

示例2: QuickSolveLinearEquation

        public static double[] QuickSolveLinearEquation(Matrix a, double[] b)
        {
            #region Validation

             Guard.ArgumentNotNull(a, "a");
             Guard.ArgumentNotNull(b, "b");

             #endregion

              a.ValidateIsSymmetric();

             var aRowCount = a.Rows;

             if (b.Length != aRowCount)
             {
             throw new ArgumentException(haveNonMatchingDimensions);
             }

              //L is a Cholesky Decomposition
             var decomposeMatrix = QuickDecompose(a);
             var x = new double[aRowCount];
             int k;
             double sum;
             for (var i = 0; i < aRowCount; i++)
             {
            // Solve <c>L * y = b</c>, storing y in x.
            for (sum = b[i], k = i - 1; k >= 0; k--)
            {
               sum -= decomposeMatrix[i, k] * x[k];
            }
            x[i] = sum / decomposeMatrix[i, i];
             }

             for (var i = aRowCount - 1; i >= 0; i--)
             {
            // Solve L^T * x = y.
            for (sum = x[i], k = i + 1; k < aRowCount; k++)
            {
               sum -= decomposeMatrix[k, i] * x[k];
            }
            x[i] = sum / decomposeMatrix[i, i];
             }

             return x;
        }
開發者ID:GTuritto,項目名稱:ngenerics,代碼行數:45,代碼來源:CholeskyDecomposition.cs

示例3: QuickDecompose

        public static Matrix QuickDecompose(Matrix a)
        {
            Guard.ArgumentNotNull(a, "a");

              a.ValidateIsSymmetric();

             var aRowCount = a.Rows;

             var res = new Matrix(aRowCount, aRowCount);

             for (var i = 0; i < aRowCount; i++)
             {
            int j;
            for (j = i; j < aRowCount; j++)
            {
               int k;
               double sum;
               for (sum = a[i, j], k = i - 1; k >= 0; k--)
               {
                  sum -= res[i, k] * res[j, k];
               }

               if (i == j)
               {
                  if (sum <= 0)
                  {
                      throw new ArgumentException(isNotPositiveDefinite);
                  }

                  res[i, i] = Math.Sqrt(sum);
               }
               else
               {
                  res[j, i] = sum / res[i, i];
               }
            }
             }
             return res;
        }
開發者ID:GTuritto,項目名稱:ngenerics,代碼行數:39,代碼來源:CholeskyDecomposition.cs


注:本文中的System.Matrix.ValidateIsSymmetric方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。