24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1317  |  回复: 5

小指甲123

新虫 (小有名气)

[求助] 提示矩阵维数必须一致,不清楚在哪里编程出现了错误,求指教已有1人参与

function ff4
clc
Data=[ 303.15      0.7766      0.02522
   313.15      0.7702      0.02548
   323.15      0.7605      0.02683
   333.15      0.7534      0.02740];
T=Data(:,1);
x11=Data(:,2);
x12=Data(:,3);
[A,fval]=fminsearch(@func3,[1,1],[],T,x11,x12)
x11cal=func1(A,T,x11,x12)
x12cal=func2(A,T,x11,x12)
end

function y=func1(A,T,x11,x12)
A12=A(1);
A21=A(2);
alfa=0.2;
R=8.314;
tao12=A12./R./T;
tao21=A21./R./T;
G12=exp(-alfa*tao12);
G21=exp(-alfa*tao21);
x21=1-x11;
x22=1-x12;
gama11=exp(x21.^2.*(tao21.*(G21./(x11+x21.*G21)).^2+tao12.*G12./(x21+x11.*G12).^2));
gama12=exp(x22.^2.*(tao21.*(G21./(x12+x22.*G21)).^2+tao12.*G12./(x22+x12.*G12).^2));
gama21=exp(x11.^2.*(tao12.*(G12./(x21+x11.*G12)).^2+tao21.*G21./(x11+x21.*G21).^2));
gama22=exp(x12.^2.*(tao12.*(G12./(x22+x12.*G12)).^2+tao21.*G21./(x12+x22.*G21).^2));
y=(gama12.*gama22)/(gama11.*gama22-gama12.*gama21)-(gama12.*gama21)/(gama11.*gama22-gama12.*gama21);
end
function y=func2(A,T,x11,x12)
A12=A(1);
A21=A(2);
alfa=0.2;
R=8.314;
tao12=A12./R./T;
tao21=A21./R./T;
G12=exp(-alfa*tao12);
G21=exp(-alfa*tao21);
x21=1-x11;
x22=1-x12;
gama11=exp(x21.^2.*(tao21.*(G21./(x11+x21.*G21)).^2+tao12.*G12./(x21+x11.*G12).^2));
gama12=exp(x22.^2.*(tao21.*(G21./(x12+x22.*G21)).^2+tao12.*G12./(x22+x12.*G12).^2));
gama21=exp(x11.^2.*(tao12.*(G12./(x21+x11.*G12)).^2+tao21.*G21./(x11+x21.*G21).^2));
gama22=exp(x12.^2.*(tao12.*(G12./(x22+x12.*G12)).^2+tao21.*G21./(x12+x22.*G21).^2));
y=(gama11.*gama22)/(gama11.*gama22-gama12.*gama21)-(gama11.*gama21)/(gama11.*gama22-gama12.*gama21);
end
function y=func3(A,T,x11,x12)
x11cal=func1(A,T,x11,x12);
x12cal=func2(A,T,x11,x12);
sigma=sum((x11-x11cal).^2+(x12-x12cal).^2);
y=sigma;
format long g
end
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hytao2012

铁杆木虫 (正式写手)

木头虫子

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
小指甲123: 金币+30, ★★★★★最佳答案 2014-11-02 12:55:13
貌似是因为你的func3中x11和和x11cal的形式不同,不能直接相减。比如一个1*2的向量减去1*3的向量就会出现这种问题

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

2楼2014-11-02 09:49:16
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

小指甲123

新虫 (小有名气)

送红花一朵
引用回帖:
2楼: Originally posted by hytao2012 at 2014-11-02 09:49:16
貌似是因为你的func3中x11和和x11cal的形式不同,不能直接相减。比如一个1*2的向量减去1*3的向量就会出现这种问题

还是不太清楚,因为理论上x11cal计算都是X11一一对应求出的,不知在哪个地方写的有问题,它内部计算不是按照我们想的那样计算,得到的维数就 不一样了呢,很纠结,还麻烦你如果有时间给仔细瞧一眼,谢谢啦
3楼2014-11-02 10:57:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hytao2012

铁杆木虫 (正式写手)

木头虫子

引用回帖:
3楼: Originally posted by 小指甲123 at 2014-11-02 10:57:12
还是不太清楚,因为理论上x11cal计算都是X11一一对应求出的,不知在哪个地方写的有问题,它内部计算不是按照我们想的那样计算,得到的维数就 不一样了呢,很纠结,还麻烦你如果有时间给仔细瞧一眼,谢谢啦...

如果吧fun3改成下面的(当然只是为了找问题,这样得到的结果应该不是你要的),程序就可以运行了,说明的确是你求的x11cal大小有问题。
运行以后从结果里可以看出,x11cal是4*4的。
问题应该就是这个了,因为不知道你程序的目的,看不懂。。。所以不会改。。。
function y=func3(A,T,x11,x12)
x11cal=func1(A,T,x11,x12);
x12cal=func2(A,T,x11,x12);
sigma=sum((x11).^2+(x12).^2);
y=sigma;
format long g
end
4楼2014-11-02 11:33:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

小指甲123

新虫 (小有名气)

是这样的,我找到问题了 ,忘了点除,非常感谢你

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

5楼2014-11-02 12:52:58
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

hytao2012

铁杆木虫 (正式写手)

木头虫子

送红花一朵
引用回帖:
5楼: Originally posted by 小指甲123 at 2014-11-02 12:52:58
是这样的,我找到问题了 ,忘了点除,非常感谢你

还是你自己找到问题的所在啊
6楼2014-11-02 15:01:27
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 小指甲123 的主题更新
信息提示
请填处理意见