gama = alfa+beta.*1i; g=gama; %%%----------------------------------- i = 1; M = zeros(1, 991); while(i <= 991) % 逐一读取Z数据 z = Z_data2(1, i); % 给Z(f)赋值 F0 = z * exp(-2 * gama * x); % 被积函数F(f, x) h = int(F0, x, 1e6, 100e6); % 对f积分的F(x) result = vpa(h, 6); M(i) = result; % 结果写入M i = i + 1; end使M(I)
时间: 2023-11-02 13:06:28 浏览: 81
根据你提供的代码,我猜测你的意图是要求解一个积分,并将结果存储在M数组中。在这段代码中,gama是一个复数,由alfa和beta构成,g的值与gama相同。
然而,我注意到代码中的两个变量(alfa和beta)并未定义,因此无法判断代码的实际目的和背景。如果你能提供更多的代码和背景信息,我可以更好地帮助你。
相关问题
load Z_data2.mat %加载Z数据 i=1; % %%%--------------------------------- f = 1e6:1e5:100e6; r=3.9904e-3; D=15.8e-3; mu_c=12.5664e-7; sigma_c=5.8e7; epslon=8.85e-12; tdelta = -5.7e-10.*f+0.075; delta = sqrt(1./pi./f./mu_c./sigma_c); R_solid = 1./pi./r./delta./sigma_c; R = (D./2./r)./sqrt((D./2./r).^2-1).*R_solid; Ls = R./2./pi./f; Lm = mu_c/pi*acosh(D/2/r); L = Ls+Lm; C = pi*epslon/acosh(D/2/r); G = 2.*pi.*f.*C.*tdelta; temp_a = complex(R, 2.*pi.*f.*L); temp_b = complex(G, 2.*pi.*f.*C); gama = sqrt(temp_a.*temp_b); z0 = sqrt(L./C); alfa = R./2./z0+G.*z0./2; beta = 2.*pi.*f.*sqrt(L.*C); gama = alfa+beta.*1i; F0=zeros(1,991); g=gama; %给γh赋值 %%%----------------------------------- M = zeros(1, 991); % 创建1x991的矩阵M,初始值为0 i = 1; %%%--------------------------------------- syms f F0=zeros(1,991); for x=0:100/991:100 for i=1:991 f0=Z_data2.*exp(-2.*gama.*x);%被积函数f0(f,x) F0=int(f0,f,1e6,100e6);%对f积分的F(x) end end figure(1) %图像1 xout = 0:100/991:100; yout = double(subs(F0,x,xout)); plot(xout,F0) xlabel('x') ylabel('h(x)') title('h(x)关于x的二维曲线')该程序中有什么问题
在程序中存在以下问题:
1. 在第一行加载数据文件Z_data2.mat时,应该加上文件名的引号,即改为load('Z_data2.mat')。
2. 在第38行,应该将F0的初始值设为一个与xout相同大小的矩阵,即F0=zeros(size(xout))。
3. 在第14行,gama的计算公式中,应该将beta的计算公式改为beta = 2.*pi.*f.*sqrt(L.*C)。
4. 在第30行,应该将gama的计算公式改为gama = sqrt(temp_a.*temp_b)。
5. 在第32行,应该将z0的计算公式改为z0 = sqrt(L./C)。
6. 在第33行,应该将alfa和beta的计算公式改为alfa = R./2./z0+G.*z0./2; beta = 2.*pi.*f.*sqrt(L.*C)。
7. 在第34行,gama的计算公式已经在第30行中计算了,无需再次计算。
8. 在第36行,将gama的值赋给g时,应该取gama的实部和虚部,即g = real(gama) + imag(gama)*1i。
9. 在第48行,应该将xout和F0的顺序颠倒,即plot(F0, xout),才能正确绘制出关于x的二维曲线。
10. 在第20行,应该将f0的计算公式中的x改为i,即f0=Z_data2.*exp(-2.*gama.*i)。
11. 在第21行,应该将int函数的参数f改为符号变量f,即F0=int(f0,f,1e6,100e6)。
12. 在第38行,应该将yout的计算公式改为yout = double(subs(F0,xout))。
综上所述,修正后的程序如下:
```
load('Z_data2.mat') % 加载Z数据
f = 1e6:1e5:100e6;
r = 3.9904e-3;
D = 15.8e-3;
mu_c = 12.5664e-7;
sigma_c = 5.8e7;
epslon = 8.85e-12;
tdelta = -5.7e-10.*f+0.075;
delta = sqrt(1./pi./f./mu_c./sigma_c);
R_solid = 1./pi./r./delta./sigma_c;
R = (D./2./r)./sqrt((D./2./r).^2-1).*R_solid;
Ls = R./2./pi./f;
Lm = mu_c/pi*acosh(D/2/r);
L = Ls+Lm;
C = pi*epslon/acosh(D/2/r);
G = 2.*pi.*f.*C.*tdelta;
temp_a = complex(R, 2.*pi.*f.*L);
temp_b = complex(G, 2.*pi.*f.*C);
gama = sqrt(temp_a.*temp_b);
z0 = sqrt(L./C);
alfa = R./2./z0+G.*z0./2;
beta = 2.*pi.*f.*sqrt(L.*C);
g = real(gama) + imag(gama)*1i; % 给g赋值
M = zeros(1, 991); % 创建1x991的矩阵M,初始值为0
F0 = zeros(size(xout)); % 给F0赋初值
for x = 0:100/991:100
for i = 1:991
syms f
f0 = Z_data2(i).*exp(-2.*g.*x); % 被积函数f0(f,x)
F0(i) = int(f0, f, 1e6, 100e6); % 对f积分的F(x)
end
end
figure(1) % 图像1
xout = 0:100/991:100;
yout = double(subs(F0, xout));
plot(yout, xout)
xlabel('x')
ylabel('h(x)')
title('h(x)关于x的二维曲线')
```
import numpy as np from math import * def Pnm(Phi, Degree): P = np.zeros([Degree + 2, Degree + 2]) # 跨阶次正规化勒让德系数 P[1][1] = 1 P[2][1] = sin(Phi) * 3 ** 0.5 P[2][2] = sqrt(3 * (1 - sin(Phi) ** 2)) for j in range(1, 3): for i in range(3, Degree + 2): l = i - 1 m = j - 1 a = sqrt((4 * l ** 2 - 1) / (l ** 2 - m ** 2)) b = sqrt((2 * l + 1) / (2 * l - 3)) * sqrt(((l - 1) ** 2 - m ** 2) / (l ** 2 - m ** 2)) P[i][j] = a * sin(Phi) * P[i - 1][j] - b * P[i - 2][j] for j in range(3, Degree + 1): for i in range(j, j + 2): l = i - 1 m = j - 1 if (m == 2): beta = sqrt(2 * (2 * l + 1) * (l + m - 2) * (l + m - 3) / (2 * l - 3) / (l + m) / (l + m - 1)) gama = sqrt(2 * (l - m + 1) * (l - m + 2) / (l + m) / (l + m - 1)) else: beta = sqrt((2 * l + 1) * (l + m - 2) * (l + m - 3) / (2 * l - 3) / (l + m) / (l + m - 1)) gama = sqrt((l - m + 1) * (l - m + 2) / (l + m) / (l + m - 1)) P[i][j] = beta * P[i - 2][j - 2] - gama * P[i][j - 2] if ((j + 2) < Degree + 2): for i in range(j + 2, Degree + 2): l = i - 1 m = j - 1 alpha = sqrt((2 * l + 1) * (l - m) * (l - m - 1) / (2 * l - 3) / (l + m) / (l + m - 1)) if (m == 2): beta = sqrt(2 * (2 * l + 1) * (l + m - 2) * (l + m - 3) / (2 * l - 3) / (l + m) / (l + m - 1)) gama = sqrt(2 * (l - m + 1) * (l - m + 2) / (l + m) / (l + m - 1)) else: beta = sqrt((2 * l + 1) * (l + m - 2) * (l + m - 3) / (2 * l - 3) / (l + m) / (l + m - 1)) gama = sqrt((l - m + 1) * (l - m + 2) / (l + m) / (l + m - 1)) P[i][j] = alpha * P[i - 2][j] + beta * P[i - 2][j - 2] - gama * P[i][j - 2] l = Degree m = Degree beta = sqrt((2 * l + 1) * (l + m - 2) * (l + m - 3) / (2 * l - 3) / (l + m) / (l + m - 1)) gama = sqrt((l - m + 1) * (l - m + 2) / (l + m) / (l + m - 1)) P[l + 1][m + 1] = beta * P[l + 1 - 2][m + 1 - 2] - gama * P[l + 1][m + 1 - 2] return P def P_final(theta, n, m, Degree=360): Phi = pi / 2 - theta res = Pnm(Phi, Degree) return res a = P_final(radians(58), 360, 360) print(a)
for n in range(Degree): for m in range(n, Degree): if n == m: P[n, m] = sqrt((2 - 1) / 2 * factorial(n) / (4 * pi * factorial(n))) * cos(m * Phi) else: P[n, m] = sqrt((2 * n + 1) / (2 * n * (n + 1)) *
阅读全文