24小时热门版块排行榜    

查看: 325  |  回复: 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 的主题更新
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见