CyRhmU.jpeg
²é¿´: 2643  |  »Ø¸´: 10

ÊæÂíŵ

Òø³æ (³õÈëÎÄ̳)

[ÇóÖú] ´øÆ½·½¸ùµÄ£¨LLT£©CholeskyËã·¨·Ö½â¶Ô³ÆÕý¶¨¾ØÕó cÓïÑÔʵÏÖ

ÐÂÈË£¬²»¶®¹æ¾Ø£¬¼ûÁÂ

´óÉñÃǺã¬ÒªÇó
1ÏÈÅжÏÈÎÒâ¾ØÕóAÊÇ·ñΪÕý¶¨¶Ô³Æ¾ØÕ󣬷ñÔò£¬·µ»ØÊäÈë´íÎó
2ÈôÊäÈëΪÕý¶¨¶Ô³Æ¾ØÕó£¬Ôò½«Æä½øÐдøÆ½·½¸ùµÄ£¨LLT£©CholeskyËã·¨·Ö½â£¬¼´ÊµÏÖA=LL^T£¬ÆäÖÐLΪÏÂÈý½ÇÐξØÕó¡£

´óÖ¾ÍÕâÒâ˼£¬ÇóÖú

¶¨Àí
»Ø¸´´ËÂ¥

» ²ÂÄãϲ»¶

» ±¾Ö÷ÌâÏà¹Ø¼ÛÖµÌùÍÆ¼ö£¬¶ÔÄúͬÑùÓаïÖú:

ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû
»ØÌûÖ§³Ö ( ÏÔʾ֧³Ö¶È×î¸ßµÄǰ 50 Ãû )

xiuyouxu

Ìú¸Ëľ³æ (Ö°Òµ×÷¼Ò)

¡¾´ð°¸¡¿Ó¦Öú»ØÌû

¸Ðл²ÎÓ룬ӦÖúÖ¸Êý +1
½¨ÒéÕÒÒ»±¾ÊýÖµ·ÖÎöµÄÊé¿´Ò»ÏÂ,ÀïÃæÓоßÌåµÄËã·¨,ÎÒÒÔǰʵÏÖ¹ý,ÆäËûÓïÑÔµÄ,ûÓÐÓÃcÓïÑÔ×ö¹ý.
Íü¼Ç×Ô¼º,Íü¼ÇÒ»Çз³ÄÕ(»¶Ó­·ÃÎÊÎÒµÄÍøÕ¾Õ××Ö½Ú£ºhttp://www.mathbeta.com/)
2Â¥2012-05-03 21:28:11
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû
ÆÕͨ»ØÌû

ÊæÂíŵ

Òø³æ (³õÈëÎÄ̳)

ÒýÓûØÌû:
2Â¥: Originally posted by xiuyouxu at 2012-05-03 21:28:11:
½¨ÒéÕÒÒ»±¾ÊýÖµ·ÖÎöµÄÊé¿´Ò»ÏÂ,ÀïÃæÓоßÌåµÄËã·¨,ÎÒÒÔǰʵÏÖ¹ý,ÆäËûÓïÑÔµÄ,ûÓÐÓÃcÓïÑÔ×ö¹ý.

# include
# include
void main()
{
        float m,A[9];
float L[6];
        printf("请输入矩阵: \n ";
        scanf("%f %f %f\n%f %f %f\n%f %f %f\n",&A[0],&A[1],&A[2],&A[3],&A[4],&A[5],&A[6],&A[7],&A[8]);
        printf("请输入å…?许误差:m=";
scanf("%f",&m);
if
        A[0]>m&&(A[0]*A[4]-A[1]*A[3]>m)&&(A[6]*A[4]*A[2]+A[0]*A[7]*A[5]+A[1]*A[3]*A[8]-A[0]*A[4]*A[8]-A[1]*A[6]*A[5]-A[2]*A[3]*A[7]>m)&&(A[1]==A[3])&&(A[2]==A[6])&&(A[5]==A[7])
{
L[0]=sqrt(A[0]);
L[1]=A[3]/L[0];
L[3]=A[6]/L[0];
L[2]=sqrt(A[4]-L[1]*L[1]);
L[4]=(A[7]-L[3]*L[1])/L[2];
L[5]=sqrt(A[8]-L[3]*L[3]-L[4]*L[4]);
printf("所求矩阵为L=\n %f 0 0\n%f %f 0\n%f %f %f\n",L[0],L[1],L[2],L[3],L[4], L[5]);
}
else
printf("输入有误,请检查";
}
调试�行:
1>.\Debug\shiyan.exe.intermediate.manifest : general error c1010070: Failed to load and parse the manifest. {_~0p'1a@'7v par 1>Build log was saved at "file://e:\360data\��数�\桌�\shiyan\shiyan\Debug\BuildLog.htm"
1>shiyan - 1 error(s), 0 warning(s)
========== Rebuild All: 0 succeeded, 1 failed, 0 skipped ==========
工程无法建立

预期效果:
请输入矩阵:
1 2 3
2 4 5
3 5 6
请输入�许误差:m=1e-6
输入有误,请检查
请输入矩阵:
5 2 -4
2 1 -2
-4 -2 5
请输入�许误差:m=1e-6
所求矩阵L=
2.236068 0 0
0.894427 0.4472136 0
-1.788854 -0.894427 1




我的算法�行�通过啊,而且根本未能实现针对任�阶次的矩阵。。。求大神帮忙~
3Â¥2012-05-03 22:13:16
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

ÊæÂíŵ

Òø³æ (³õÈëÎÄ̳)

ÒýÓûØÌû:
2Â¥: Originally posted by xiuyouxu at 2012-05-03 21:28:11:
½¨ÒéÕÒÒ»±¾ÊýÖµ·ÖÎöµÄÊé¿´Ò»ÏÂ,ÀïÃæÓоßÌåµÄËã·¨,ÎÒÒÔǰʵÏÖ¹ý,ÆäËûÓïÑÔµÄ,ûÓÐÓÃcÓïÑÔ×ö¹ý.

# include
# include
void main()
{
        float m,A[9];
float L[6];
        printf("ÇëÊäÈë¾ØÕó: \n ";
        scanf("%f %f %f\n%f %f %f\n%f %f %f\n",&A[0],&A[1],&A[2],&A[3],&A[4],&A[5],&A[6],&A[7],&A[8]);
        printf("ÇëÊäÈëÔÊÐíÎó²î:m=";
scanf("%f",&m);
if
        A[0]>m&&(A[0]*A[4]-A[1]*A[3]>m)&&(A[6]*A[4]*A[2]+A[0]*A[7]*A[5]+A[1]*A[3]*A[8]-A[0]*A[4]*A[8]-A[1]*A[6]*A[5]-A[2]*A[3]*A[7]>m)&&(A[1]==A[3])&&(A[2]==A[6])&&(A[5]==A[7])
{
L[0]=sqrt(A[0]);
L[1]=A[3]/L[0];
L[3]=A[6]/L[0];
L[2]=sqrt(A[4]-L[1]*L[1]);
L[4]=(A[7]-L[3]*L[1])/L[2];
L[5]=sqrt(A[8]-L[3]*L[3]-L[4]*L[4]);
printf("ËùÇó¾ØÕóΪL=\n %f 0 0\n%f %f 0\n%f %f %f\n",L[0],L[1],L[2],L[3],L[4], L[5]);
}
else
printf("ÊäÈëÓÐÎó£¬Çë¼ì²é";
}

µ÷ÊÔÔËÐУº
1>.\Debug\shiyan.exe.intermediate.manifest : general error c1010070: Failed to load and parse the manifest. {_~0p'1a@'7v par 1>Build log was saved at "file://e:\360data\ÖØÒªÊý¾Ý\×ÀÃæ\shiyan\shiyan\Debug\BuildLog.htm"
1>shiyan - 1 error(s), 0 warning(s)
========== Rebuild All: 0 succeeded, 1 failed, 0 skipped ==========
¹¤³ÌÎÞ·¨½¨Á¢



ʧ°ÜÁË£¬¶øÇÒ´ï²»µ½Õë¶ÔÈÎÒâ½×´Î¾ØÕóµÄЧ¹û£¡
4Â¥2012-05-03 22:17:09
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

xiuyouxu

Ìú¸Ëľ³æ (Ö°Òµ×÷¼Ò)

¡¾´ð°¸¡¿Ó¦Öú»ØÌû

matlabÀïÃæÖ±½ÓÓÃrootº¯Êý¾Í¿ÉÒÔÁË, ÏÂÃæÊÇÎÒдµÄc++µÄ:
// ¶¨ÒåMatrixÀà(ÂÔ)
// m*n½×0¾ØÕó
void Matrix::zeros(int m,int n,double** a){
        for(int i=0;i                 for(int j=0;j                         a[j]=0;
                }
        }
}

// nΪ¾ØÕóµÄ½×
void Matrix::root(int n,double** A,double** L){
     zeros(n,n,L);
     for(int i=0;i              for(int j=0;j                      double sum=0;
                     for(int k=0;k                              sum+=L[k]*L[j][k];
                     }
                     L[j]=(A[j]-sum)/L[j][j];
             }
             double sum=0;
             for(int k=0;k                      sum+=L[k]*L[k];
             }
             L=sqrt(A-sum);// ÏÔÈ» A-sum<0ʱ²»ÊÇÕý¶¨¾ØÕó
     }
}
Íü¼Ç×Ô¼º,Íü¼ÇÒ»Çз³ÄÕ(»¶Ó­·ÃÎÊÎÒµÄÍøÕ¾Õ××Ö½Ú£ºhttp://www.mathbeta.com/)
5Â¥2012-05-03 22:29:03
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

ÊæÂíŵ

Òø³æ (³õÈëÎÄ̳)

ÒýÓûØÌû:
5Â¥: Originally posted by xiuyouxu at 2012-05-03 22:29:03:
matlabÀïÃæÖ±½ÓÓÃrootº¯Êý¾Í¿ÉÒÔÁË, ÏÂÃæÊÇÎÒдµÄc++µÄ:
// ¶¨ÒåMatrixÀà(ÂÔ)
// m*n½×0¾ØÕó
void Matrix::zeros(int m,int n,double** a){
        for(int i=0;i<m;i++){
                for(int j=0;j<n;j++){
                        a=0; ...

»¹ÊÇÔËÐв»Í¨¡£¡£¡£
6Â¥2012-05-03 23:00:27
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

xiuyouxu

Ìú¸Ëľ³æ (Ö°Òµ×÷¼Ò)

¡¾´ð°¸¡¿Ó¦Öú»ØÌû

ÔÎ,Õâ¸ö»Ø¸´¿ò²»ÄÜ·Å´úÂë°¡,ÓÐÒ»²¿·Ö´úÂë±»Ìæ»»µôÁË,´úÂëÀï²»ÄܳöÏÖ,»á±»Ìæ»»µô
Íü¼Ç×Ô¼º,Íü¼ÇÒ»Çз³ÄÕ(»¶Ó­·ÃÎÊÎÒµÄÍøÕ¾Õ××Ö½Ú£ºhttp://www.mathbeta.com/)
7Â¥2012-05-03 23:09:59
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

xiuyouxu

Ìú¸Ëľ³æ (Ö°Òµ×÷¼Ò)

¿´¿´ÕâÑùÐв»ÐÐ \[i\]
Íü¼Ç×Ô¼º,Íü¼ÇÒ»Çз³ÄÕ(»¶Ó­·ÃÎÊÎÒµÄÍøÕ¾Õ××Ö½Ú£ºhttp://www.mathbeta.com/)
8Â¥2012-05-03 23:10:36
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

xiuyouxu

Ìú¸Ëľ³æ (Ö°Òµ×÷¼Ò)

¡¾´ð°¸¡¿Ó¦Öú»ØÌû

void Matrix::zeros(int m,int n,double** a){
        for(int i=0;i                 for(int j=0;j                         a\[i\][j]=0;
                }
        }
}

void Matrix::root(int n,double** A,double** L){
     zeros(n,n,L);
     for(int i=0;i              for(int j=0;j                      double sum=0;
                     for(int k=0;k                              sum+=L\[i\][k]*L[j][k];
                     }
                     L[j]=(A[j]\[i\]-sum)/L[j][j];
             }
             double sum=0;
             for(int k=0;k                      sum+=L\[i\][k]*L\[i\][k];
             }
             L=sqrt(A\[i\]\[i\]-sum);
     }
}

°ÑÉÏÃæµÄÖÐÀ¨ºÅǰµÄ·´Ð±ÏßÈ¥µô¾ÍÐÐÁË
Íü¼Ç×Ô¼º,Íü¼ÇÒ»Çз³ÄÕ(»¶Ó­·ÃÎÊÎÒµÄÍøÕ¾Õ××Ö½Ú£ºhttp://www.mathbeta.com/)
9Â¥2012-05-03 23:12:39
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû

ÊæÂíŵ

Òø³æ (³õÈëÎÄ̳)

ÒýÓûØÌû:
7Â¥: Originally posted by xiuyouxu at 2012-05-03 23:09:59:
ÔÎ,Õâ¸ö»Ø¸´¿ò²»ÄÜ·Å´úÂë°¡,ÓÐÒ»²¿·Ö´úÂë±»Ìæ»»µôÁË,´úÂëÀï²»ÄܳöÏÖ,»á±»Ìæ»»µô

¶àл¸ßÊÖ°ïæÁË£¬ÈõÈõµÄÎÊÒ»¾äÄܲ»ÄÜ·¢µ½wuleileihappy@163.comÄØ£¿¸Ð¼¤²»¾¡
10Â¥2012-05-03 23:13:29
ÒÑÔÄ   ¹Ø×¢TA ¸øTA·¢ÏûÏ¢ ËÍTAºì»¨ TAµÄ»ØÌû
Ïà¹Ø°æ¿éÌø×ª ÎÒÒª¶©ÔÄÂ¥Ö÷ ÊæÂíŵ µÄÖ÷Ìâ¸üÐÂ
ÐÅÏ¢Ìáʾ
ÇëÌî´¦ÀíÒâ¼û