我的代码有一些问题。
lambdaz = 1.2;
n = 24;
mu = 0.00055e9;
lambda = sym('lambda','clear');
W = (((2.*mu)./n.^2)).*((lambda.^n)+(lambdaz.^n)+((lambda.^-n).*(lambdaz.^-n))-3);
dW_dlambda = diff(W, lambda);
W2=(((2.*mu)./n.^2).*(lambda.^n))+(((2.*mu)./n.^2).*(lambdaz.^n))+(((2.*mu)./n.^2).*((lambda.^-n).*(lambdaz.^-n)))-(3.*((2.*mu)./n.^2))
dW2_dlambda=diff(W2,lambda)
x=((((lambda.^2).*(lambdaz))-1).^-1).*(dW_dlambda);
x2=((((lambda.^2).*(lambdaz))-1).^-1).*(dW2_dlambda)
P2 = int(x2,lambda)
P=int(x,lambda);
P=(0:1000:26700)
plot(lambda,P)
当我尝试对p绘制lambda时,我得到"从sym转换到double是不可能的"错误消息。我不是特别擅长Matlab,所以任何帮助都会非常感激!
plot
函数只适用于数字输入。lambda
和P
都是符号表达式(至少在将P
改写为积分后的向量之前),不能直接转换为浮点数。如果尝试double(sym('exp(x)'))
,你会得到同样的错误。你有两个选择。第一个是符号工具箱中的ezplot
函数:
...
P = int(x,lambda);
ezplot(P,[-5 5]); % Plot's P from lambda = -5 to lambda = 5
或者您可以使用subs
函数:
...
P = int(x,lambda);
lambda = -5:0.01:5;
plot(lambda,real(subs(P,'lambda',lambda)))
axis([lambda(1) lambda(end) -1e15 1e15])
我使用real
来抑制lambda
为负值的警告。