24小时热门版块排行榜    

CyRhmU.jpeg
南方科技大学公共卫生及应急管理学院2025级博士研究生招生报考通知
查看: 2413  |  回复: 11
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

加油大楠楠

铜虫 (小有名气)

[求助] 请教matlab用数组给参数矩阵赋值的问题

syms x y z d1 d2 d3 r l;n=1;%定义矩阵参数
a=1/l*[z+r-d1 0 0;0 -0.866*y-0.5*z+r-d2 0;0 0 0.866*y-0.5*z+r-d3];
b=[x y z+r-d1;x y-0.866*r+0.866*d2 z-0.5*r+0.5*d2;x y+0.866*r-0.866*d3 z-0.5*r+0.5*d3];
c=inv(a);
d=c*b;%d为我需要的比矩阵
到这一步矩阵的计算都不成问题
d=subs(d,{'r','l','x','y','z','d1','d2','d3'},{31.8,40.2,B(n,1),B(n,2),B(n,3),B(n,4),B(n,5),B(n,6)});
%给参数赋值,其中x y z d1 d2 d3是用B矩阵的第n行对应的列来赋值的
e = norm(d,'fro'); %求范数
f(n,1)=e;%将范数记录
n=n+1;
if n==101;%B数组有100行所以到一百终止
end

最后结果f数列中只有一个数 ,请帮忙
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

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

材料廖

木虫 (正式写手)

【答案】应助回帖

★ ★
jjdg: 金币+2, 辛苦了 2013-04-22 10:54:37
引用回帖:
6楼: Originally posted by 加油大楠楠 at 2013-04-21 10:17:29
程序中的吗,m,n就是xy,为了减少计算量我把z固定了是20,其实xyz是空间坐标...

开始那个由于你在rad中用了0,导致了出现了NAN,我照你的程序修改了下,可以出部分结果,程序如下:
j=1;z=20;r=32;
for l=32:34   %设定范围
    i=1;  tezheng=0;
    for rad=1:l; %这两个for的步长可以根据运算效率适当放大,此处我改成了从1开始
        for thea=0:pi/10:2*pi;
            
            x=rad*cos(thea);  %x
            y=rad*sin(thea);  %y
            d11=1/3*(3*r+3*x+sqrt(9*l^2-9*y^2-9*z^2));
            d12=1/3*(6*r-3*x+3*y*sqrt(3)+sqrt(36*l^2-27*x^2-18*x*y*sqrt(3)-9*y^2-36*z^2));
            d13=1/3*(6*r-3*x-3*y*sqrt(3)+sqrt(36*l^2-27*x^2+18*x*y*sqrt(3)-9*y^2-36*z^2));
            B(i,:)=[x,y,z,d11,d12,d13];
            a=(1/B(i,1))*[B(i,3)+r-B(i,4) 0 0;0 -0.866*B(i,2)-0.5*B(i,3)+...
                r-B(i,5) 0;0 0 0.866*B(i,2)-0.5*B(i,3)+r-B(i,6)];
            b=[B(i,1) B(i,2) B(i,3)+r-B(i,4);B(i,1) B(i,2)-0.866*r+...
                0.866*B(i,5) B(i,3)-0.5*r+0.5*B(i,5);B(i,1) B(i,2)+...
                0.866*r-0.866*B(i,6) B(i,3)-0.5*r+0.5*B(i,6)];
%             c=inv(a);
            d=a\b; %d为雅克比矩阵
            e = norm(d,'fro'); %2范数
            hh(i,1)=1/(eps+e);%把这个范数记录在hh中
            tezheng=hh(i,1)+tezheng;%相加对于相同l值的对应的范数
            i=i+1;
        end
    end
    tezheng1(j,:)=tezheng/(i-1+eps);%把不同l值对应的范数求和再除以相应的l值  存在数组tezheng1中
    j=j+1;
end

根据你说的和我理解的,我自己写了一个,运行速度理论上会快点,也可以把你计算过程中的大部分数据记录下来,程序如下:

%对于l我感觉你要是后面是求和的话,没有必要那样,你的求和在多重循环里面,重复了很多次,我就将l设成了你程序中的最大值,这个你自己再考虑下,看着修改吧。

j=1;r=32;l = 34;  %注意我把l设成了一个常数
for rad = 1:34
    %theta = 0:pi/10:2*pi
    x(rad,:) = rad*cos(0:pi/10:2*pi);  %x
    y(rad,:) = rad*sin(0:pi/10:2*pi);  %y
    z(rad,:) = 20*ones(size(0:pi/10:2*pi));
    d11(rad,:)=1/3*(3*r+3*x(rad,:)+sqrt(9*l^2-9*y(rad,:).^2-9*z(rad,:).^2));
    d12(rad,:)=1/3*(6*r-3*x(rad,:)+3*y(rad,:)*sqrt(3)+sqrt(36*l^2-...
        27*x(rad,:).^2-18*x(rad,:).*y(rad,:)*sqrt(3)-9*y(rad,:).^2-36*z(rad,:).^2));
    d13(rad,:)=1/3*(6*r-3*x(rad,:)-3*y(rad,:)*sqrt(3)+sqrt(36*l^2-...
        27*x(rad,:).^2+18*x(rad,:).*y(rad,:)*sqrt(3)-9*y(rad,:).^2-36*z(rad,:).^2));
    B(rad,1:21,1:6) = [(x(rad,:))',(y(rad,:))',(z(rad,:))',(d11(rad,:))',(d12(rad,:))',(d13(rad,:))'];
    n = length(B(rad,:,1));
    for k = 1:n
        a(:,:,rad,k) = (1/B(rad,k,1)).*[B(rad,k,3)+r-B(rad,k,4) 0 0;0 -0.866.*B(rad,k,2)-0.5.*B(rad,k,3)+...
            r-B(rad,k,5) 0;0 0 0.866.*B(rad,k,2)-0.5.*B(rad,k,3)+r-B(rad,k,6)];
        b(:,:,rad,k) = [B(rad,k,1) B(rad,k,2) B(rad,k,3)+r-B(rad,k,4);B(rad,k,1) B(rad,k,2)-0.866.*r+...
            0.866.*B(rad,k,5) B(rad,k,3)-0.5.*r+0.5.*B(rad,k,5);B(rad,k,1) B(rad,k,2)+...
            0.866.*r-0.866.*B(rad,k,6) B(rad,k,3)-0.5.*r+0.5.*B(rad,k,6)];
        d(:,:,rad,k)=a(:,:,rad,k)\b(:,:,rad,k); %雅克比矩阵
        e(rad,k) = norm(d(:,:,rad,k),'fro');  %二范数
    end
    hh = 1./e;  %同你程序中的hh,只是此处为一个矩阵,即所有你的hh都在这里
end
tezheng = sum((sum(hh)));%所有的hh求和
%到这里,求和都做了,所有的e,hh都有数据在里面,后面我不是很明白,你自己看着修改吧。

» 本帖已获得的红花(最新10朵)

7楼2013-04-21 18:10:57
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 12 个回答

材料廖

木虫 (正式写手)

【答案】应助回帖

感谢参与,应助指数 +1
你这个肯定只有n=1的值呀,都没有循环,你可以将你的这段程序
f(n,1)=e;%将范数记录
n=n+1;
if n==101;%B数组有100行所以到一百终止
end
改成:
for n = 1:100
f(n,1) = e;
end
这样应该就可以了!
2楼2013-04-15 12:12:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

加油大楠楠

铜虫 (小有名气)

引用回帖:
2楼: Originally posted by 材料廖 at 2013-04-15 12:12:41
你这个肯定只有n=1的值呀,都没有循环,你可以将你的这段程序
f(n,1)=e;%将范数记录
n=n+1;
if n==101;%B数组有100行所以到一百终止
end
改成:
for n = 1:100
f(n,1) = e;
end
这样应该就可以了!

不好意思回复晚了  那你再帮我看看这整段程序   我把上次的程序稍微改了下,就是对于每个l,我要求他xyx为不同值的时候的范数,然后相加,最后把每个l的范数和提取出来,十分感谢了  我运行总是报错
j=1;z=20;r=32;
for l=32:34   %设定范围
i=1;  tezheng=0;     
    for rad=0:l; %这两个for的步长可以根据运算效率适当放大
        for thea=0:pi/10:2*pi;

m=rad*cos(thea);
n=rad*sin(thea);
d11=1/3*(3*r+3*m+sqrt(9*l^2-9*n^2-9*z^2));
d12=1/3*(6*r-3*m+3*n*sqrt(3)+sqrt(36*l^2-27*m^2-18*m*n*sqrt(3)-9*n^2-36*z^2));
d13=1/3*(6*r-3*m-3*n*sqrt(3)+sqrt(36*l^2-27*m^2+18*m*n*sqrt(3)-9*n^2-36*z^2));
B(i,=[m,n,z,d11,d12,d13];
syms x1 y1 z1 d1 d2 d3 l1;
a=(1/l1)*[z1+r-d1 0 0;0 -0.866*y1-0.5*z1+r-d2 0;0 0 0.866*y1-0.5*z1+r-d3];
b=[x1 y1 z1+r-d1;x1 y1-0.866*r+0.866*d2 z1-0.5*r+0.5*d2;x1 y1+0.866*r-0.866*d3 z1-0.5*r+0.5*d3];
c=inv(a);
d=c*b;%d为雅克比矩阵
d=subs(d,{'l1','x1','y1','z1','d1','d2','d3'},{l,B(i,1),B(i,2),B(i,3),B(i,4),B(i,5),B(i,6)});
e = norm(d,'fro'); %2范数
hh(i,1)=1/e;%把这个范数记录在hh中
tezheng=hh(i,1)+tezheng;%相加对于相同l值的对应的范数
   i=i+1;
        end
    end
tezheng1(j,=tezheng/(i-1);%把不同l值对应的范数求和再除以相应的l值  存在数组tezheng1中
j=j+1;
end


错误信息是
clear
??? Error using ==> mupadmex
Error in MuPAD command: Out of memory

Error in ==> sym.horzcat at 25
    y = mupadmex('mllib::horzcat',strs{:});

Error in ==> jacobi at 16
a=(1/l1)*[z1+r-d1 0 0;0 -0.866*y1-0.5*z1+r-d2 0;0 0
0.866*y1-0.5*z1+r-d3];

>>
3楼2013-04-18 09:38:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

材料廖

木虫 (正式写手)

【答案】应助回帖

我还是不是很明白你要做什么,你这个程序写的我有点看不懂。但有点建议,一:你这个应该没有必要用符号计算,符号计算很慢。二:你这个程序编写的不怎样,基础不是很好,写的有C语言的感觉,可能你的想法你没用程序表达出来,要不你说说你要干啥吧,我看能不能帮你。话说直了点,望不怪。
下面是我没用符号计算程序,速度快了很多,但是还是存在错误,出不了结果,因为我还是没有理解你要干啥。
j=1;z=20;r=32;
for l=32:34   %设定范围
    i=1;  tezheng=0;
    for rad=0:l; %这两个for的步长可以根据运算效率适当放大
        for thea=0:pi/10:2*pi;
            
            m=rad*cos(thea);
            n=rad*sin(thea);
            d11=1/3*(3*r+3*m+sqrt(9*l^2-9*n^2-9*z^2));
            d12=1/3*(6*r-3*m+3*n*sqrt(3)+sqrt(36*l^2-27*m^2-18*m*n*sqrt(3)-9*n^2-36*z^2));
            d13=1/3*(6*r-3*m-3*n*sqrt(3)+sqrt(36*l^2-27*m^2+18*m*n*sqrt(3)-9*n^2-36*z^2));
            B(i,=[m,n,z,d11,d12,d13];
            a=(1/B(i,1))*[B(i,3)+r-B(i,4) 0 0;0 -0.866*B(i,2)-0.5*B(i,3)+r-B(i,5) 0;0 0 0.866*B(i,2)-0.5*B(i,3)+r-B(i,6)];
            b=[B(i,1) B(i,2) B(i,3)+r-B(i,4);B(i,1) B(i,2)-0.866*r+0.866*B(i,5) B(i,3)-0.5*r+0.5*B(i,5);B(i,1) B(i,2)+0.866*r-0.866*B(i,6) B(i,3)-0.5*r+0.5*B(i,6)];
%             c=inv(a);
            d=a\b;%d为雅克比矩阵
            e = norm(d,'fro'); %2范数
            hh(i,1)=1/e;%把这个范数记录在hh中
            tezheng=hh(i,1)+tezheng;%相加对于相同l值的对应的范数
            i=i+1;
        end
    end
    tezheng1(j,=tezheng/(i-1+eps);%把不同l值对应的范数求和再除以相应的l值  存在数组tezheng1中
    j=j+1;
end
4楼2013-04-19 18:36:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
信息提示
请填处理意见