声振论坛

 找回密码
 我要加入

QQ登录

只需一步,快速开始

查看: 1284|回复: 3

[编程技巧] 求大神指点 Matlab程序出现错误

[复制链接]
发表于 2011-4-12 17:39 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?我要加入

x
clc
clear
%format short
syms W;   
L=1;   %梁的长度
d=0.02;   %梁的直径
E=2.1e11;
p=7800;        %密度
n=10;
I=pi*d^4/64;
m=p*pi*L*(d/2)^2/n;
C=1;
l=L/n;
c_point=[1 0 0 0;0 1 0 0;0 0 1 0;m*W 0 0 1];
c_chang=[1 l l^2/(2*E*I) l^3/(6*E*I);0 1 l/(E*I) l^2/(2*E*I);0 0 1 l;0 0 0 1];
C_product=c_point*(c_chang^n);
for i=1:1:n
    C[i]=C_product*C;
  for W=1:1:10
T[i]=[C(3,3) C(3,4);C(4,3) C(4,4)];
f=det(T[i]);
W=solve(f,W);
    w=sqrt(W);
double(w)
  end
end
在for循环里面我想给W 赋予不同的值  从1-10  然后输出这个矩阵中右下角的四个元素的不同行列式值    哪错误了?    C[i]=C_product*C; 个地方说有错误   哪错了呢  希望专家指点
回复
分享到:

使用道具 举报

 楼主| 发表于 2011-4-12 18:02 | 显示全部楼层
clc
clear
%format short
syms W;   
L=1;   %梁的长度
d=0.02;   %梁的直径
E=2.1e11;
p=7800;        %密度
n=10;
I=pi*d^4/64;
m=p*pi*L*(d/2)^2/n;
l=L/n;
c_point=[1 0 0 0;0 1 0 0;0 0 1 0;m*W 0 0 1];
c_chang=[1 l l^2/(2*E*I) l^3/(6*E*I);0 1 l/(E*I) l^2/(2*E*I);0 0 1 l;0 0 0 1];
C_product=c_point*(c_chang^n);
for i=1:1:n
    C=C_product;
  for W=1:1:10
T=[C(3,3) C(3,4);C(4,3) C(4,4)];
f=det(T);
W=solve(f,W);
    w=sqrt(W);
double(w)
  end
end
我这样改过之后  运行的结果 出现很多一样的值   可是我的W是从1-10   应该输出10个不同的值啊   哪错了呢
 楼主| 发表于 2011-4-12 18:09 | 显示全部楼层
clc
clear
%format short
syms W;   
L=1;   %梁的长度
d=0.02;   %梁的直径
E=2.1e11;
p=7800;        %密度
n=10;
I=pi*d^4/64;
m=p*pi*L*(d/2)^2/n;
l=L/n;
c_point=[1 0 0 0;0 1 0 0;0 0 1 0;m*W 0 0 1];
c_chang=[1 l l^2/(2*E*I) l^3/(6*E*I);0 1 l/(E*I) l^2/(2*E*I);0 0 1 l;0 0 0 1];
C_product=c_point*(c_chang^n);
for i=1:1:n
    C=C_product;
  for W=1:1:10
T=[C(3,3) C(3,4);C(4,3) C(4,4)];
f=det(T);
double(f)
  end
end
这样改过  输出不同的f值   这里double(f)有错误  哪错了?
发表于 2011-4-12 23:02 | 显示全部楼层
回复 3 # yuxinglong 的帖子

大概看了下你的程序,感觉你算出来的f值是符号变量吧,用 for W=1:1:10应该不能给W赋值吧,建议你看下matlab中的符号运算!
您需要登录后才可以回帖 登录 | 我要加入

本版积分规则

QQ|小黑屋|Archiver|手机版|联系我们|声振论坛

GMT+8, 2024-11-25 18:27 , Processed in 0.051320 second(s), 18 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表