24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 2857  |  回复: 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的回帖
相关版块跳转 我要订阅楼主 舒马诺 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 专硕304找调剂,一线城市最好 +3 李lsl李 2026-04-05 3/150 2026-04-06 12:16 by ffffjjjj
[考研] 求调剂 +11 xzghyuj 2026-04-04 11/550 2026-04-06 11:49 by lijunpoly
[考研] 一志愿武汉理工大学-085601材料工程(专硕)-总分353求调剂 +3 2626262626li 2026-04-02 3/150 2026-04-06 09:08 by 无际的草原
[考研] 315求调剂 +14 欣喜777 2026-04-04 15/750 2026-04-06 06:25 by houyaoxu
[考研] 086000生物与医药求调剂 +3 老天眷顾之人 2026-03-31 3/150 2026-04-05 22:24 by syh9288
[考研] 求调剂 +11 熊二想上岸 2026-04-04 11/550 2026-04-05 22:21 by 醉翁wl
[考研] 338求调剂 +3 我想上岸ii 2026-04-05 3/150 2026-04-05 19:59 by nepu_uu
[考研] 295求调剂 +8 FZAC123 2026-04-03 8/400 2026-04-05 17:46 by 蓝云思雨
[考研] 工科277分求调剂材料 +8 上了上了上哦 2026-04-05 9/450 2026-04-05 13:05 by wwytracy
[考研] 271分求调剂学校 +12 zph158488! 2026-04-02 13/650 2026-04-05 10:13 by lqwchd
[考研] 315求调剂 +13 小羊小羊_ 2026-04-02 14/700 2026-04-04 20:30 by 蓝云思雨
[论文投稿] 求文献 5+3 ys879651$ 2026-04-02 3/150 2026-04-04 17:22 by bobvan
[考研] 一志愿沪985,326分求调剂 +3 刘墨墨 2026-04-03 3/150 2026-04-04 11:16 by 悲伤的芋头
[考研] 283分材料与化工求调剂 +29 罗KAKA 2026-04-02 29/1450 2026-04-03 23:56 by userper
[考研] 288求调剂 一志愿哈工大 材料与化工 +39 洛神哥哥 2026-03-31 41/2050 2026-04-03 21:51 by qlm5820
[考研] 学硕288调剂!!! +3 小王xw123 2026-04-03 3/150 2026-04-03 21:20 by 啵啵啵0119
[考研] 一志愿华东理工大学,080500学硕,317分,求调剂 +13 s1145 2026-03-31 15/750 2026-04-03 11:44 by msi123
[考研] 0703一志愿南师大334求调剂 +4 seven7yu 2026-03-30 4/200 2026-04-01 16:10 by oooqiao
[考研] 调剂申请 +8 张张张张zy 2026-03-31 9/450 2026-04-01 08:29 by zjbkx
[考研] 一志愿中海洋320化学工程与技术学硕求调剂 +8 披星河 2026-03-30 8/400 2026-03-31 08:53 by lbsjt
信息提示
请填处理意见