24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 351  |  回复: 1

wdphysics

金虫 (小有名气)

[交流] 【求助】如何调用此函数分解具体矩阵? 已有1人参与

对称矩阵的cholesky分解,a为矩阵,n为其维数。主要是不知道怎么弄调用接口!
void choldc(float **a, int n, float p[])
{
        void nrerror(char error_text[]);
        int i,j,k;
        float sum;
        for (i=1;i<=n;i++) {
                for (j=i;j<=n;j++) {
                        for (sum=a[j],k=i-1;k>=1;k--) sum -= a[k]*a[j][k];
                        if (i == j) {
                                if (sum <= 0.0)
                                        nrerror("choldc failed";
                                p=sqrt(sum);
                        } else a[j]=sum/p;
                }
        }
}
回复此楼

» 猜你喜欢

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

yalefield

金虫 (文坛精英)

老汉一枚

★ ★ ★ ★
小木虫(金币+0.5):给个红包,谢谢回帖交流
余泽成(金币+3):辛苦了! 2010-08-20 12:18:33
(1)
   a是指针的指针,在这里,它就是指向一个2维的数组
   C/C++里面,数组都是一维的,遇到二维数组,就把它“展开”成一维的。
   因此,你要指定二维数组中,那个第一维有多少个元素,也就是参数n
     第0到第n-1个,是二维数组中的前n个,也就是第一行(或列)
   p则是一维数组

(2)
   因此,要调用这个函数,需要准备好一个二维数组和一个一维数组
   例如:
   int f ()
    {
        float X[100][200];
        float Y[100];
        return choldc(X, 100, Y);
    }

(3)
   按照目前的写法,应该是:int choldc(float **a, int n, float *p)
   然后,返回1表示成功,返回0表示出错(或者相反)。
   在这样的函数里,直接调用错误输出,实在算不上的德艺双馨。
CODE:
int choldc(float **a, int n, float p[])
{
        int i, j, k;
        float sum = 0.0F;
        for (i=1; i<=n; i++)
        {
                for (j=i; j<=n; j++)
                {
                        for (sum=a[i][j], k=i-1; k>=1; k--)
                        {
                                sum -= a[i][k]*a[j][k];
                        }
                        if (i == j)
                        {
                                if (sum <= 0.0)
                                {
                                        return 0;
                                }
                                p[i]=sqrt(sum);
                        }
                        else
                        {
                                a[j][i]=sum/p[i];
                        }
                }
        }
        return 1;
}

-------------------
C语言九星大师,偶发三俗代码
2楼2010-08-20 11:20:52
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 wdphysics 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 366求调剂 +7 sbdnd 2026-04-03 7/350 2026-04-03 12:40 by cymywx
[考研] 材料调剂 +13 一样YWY 2026-04-02 13/650 2026-04-03 12:16 by xingguangj
[考研] 296材料专硕求调剂 +20 202451007219 2026-04-02 21/1050 2026-04-03 11:15 by wangjy2002
[考研] 286求调剂 +7 Faune 2026-03-30 7/350 2026-04-03 10:14 by linyelide
[考研] 求调剂 302分初试 0854 +5 伶可乐 2026-04-02 5/250 2026-04-02 17:53 by 笔落锦州
[考研] 一志愿085600中科院宁波所276分求调剂 +26 材料学257求调剂 2026-03-28 27/1350 2026-04-02 15:15 by chyhaha
[考研] 372求调剂 +3 jj涌77 2026-04-02 3/150 2026-04-02 09:57 by olim
[考研] 279求调剂 +6 学而思兮知 2026-04-01 6/300 2026-04-02 09:16 by vgtyfty
[考研] 265求调剂 +11 yelck 2026-04-01 12/600 2026-04-01 19:12 by 549790059
[考研] 调剂 +5 好好读书。 2026-03-28 7/350 2026-04-01 15:32 by 王亮_大连医科大
[考研] 求调剂 +4 图鉴212 2026-03-30 5/250 2026-04-01 15:32 by 图鉴212
[考研] 086000生物与医药298调剂求助 +4 元元青青 2026-03-31 6/300 2026-04-01 11:13 by syh9288
[考研] 085410人工智能 初试316分 求调剂 +3 残星拂曙 2026-03-31 3/150 2026-04-01 11:09 by 小熊raider
[考研] 考研材料工程351分调剂 +5 整个好的 2026-03-31 5/250 2026-04-01 09:36 by topgun2009
[考研] 一志愿北京科技大学085601材料工程英一数二初试总分335求调剂 +5 双马尾痞老板2 2026-03-31 5/250 2026-04-01 09:04 by oooqiao
[考研] 0856求调剂 +9 楒桉 2026-03-28 9/450 2026-03-31 19:06 by 暮泽12
[考研] 080500-315分复试调剂 +9 上岸3821 2026-03-31 9/450 2026-03-31 17:29 by 唐沐儿
[考研] 求调剂 +9 akdhjs 2026-03-31 10/500 2026-03-31 17:14 by zhyzzh
[考研] 一志愿西电085401数一英一299求调剂 六级521 +4 爱吃大鸭梨 2026-03-31 4/200 2026-03-31 11:51 by 搏击518
[考研] 085600,专业课化工原理,321分求调剂 +5 大馋小子 2026-03-28 5/250 2026-03-29 08:56 by qingfeng258
信息提示
请填处理意见