EDA365电子论坛网

标题: 为什么Matlab计算结果和单片机相差非常大? [打印本页]

作者: I_believe    时间: 2022-8-24 13:56
标题: 为什么Matlab计算结果和单片机相差非常大?

遇到一个很奇怪的问题,下边这个公式使用Matlab和EXCEL计算结果相同且正确

使用单片机和csharp测试又是另一个结果

-(2*L^4*b - L^4*c + 8*L^2*b^3 + 2*L^2*c^3 + 8*c^3*h^2 - 4*L^2*b*c^2 - 4*L^2*b^2*c - 8*L^2*b*h^2 - 4*L^2*c*h^2 + 2*L*h*((L + c)*(L - c)*(L^2 - 4*b^2 + 4*h^2)*(L^2 - 4*b^2 + 8*b*c - 4*c^2 + 4*h^2))^(1/2))/(4*(4*L^2*b^2 - 4*L^2*b*c + L^2*c^2 - 4*L^2*h^2 + 4*c^2*h^2))

单片机和csharp计算a=-9.58444976;

double L =    270;$ D- [) d  K* \6 J- k4 t, l9 m
double b =    14.33;
. N9 ~8 E8 v7 _" I3 X0 w; adouble c =    20.25;2 @" W% i2 u' L. z
double h =    120.21;

a =  -(2*pow(L,4.00)*b - pow(L,4.00)*c + 8.00*pow(L,2)*pow(b,3.00) + 2*pow(L,2.00)*pow(c,3.00) + 8*pow(c,3)*pow(h,2) - 4*pow(L,2)*b*pow(c,2) - 4*pow(L,2)*pow(b,2)*c - 8*pow(L,2)*b*pow(h,2) - 4*pow(L,2)*c*pow(h,2) + 2*L*h*pow(((L + c)*(L - c)*(pow(L,2) - 4*pow(b,2) + 4*pow(h,2))*(pow(L,2) - 4*pow(b,2) + 8*b*c - 4*pow(c,2) + 4*pow(h,2))),(1/2)))/(4*(4*pow(L,2)*pow(b,2) - 4*pow(L,2)*b*c + pow(L,2)*pow(c,2) - 4*pow(L,2)*pow(h,2) + 4*pow(c,2)*pow(h,2)))
+ @, W' b6 V& h0 ^! Q4 O;. v3 Y+ ?* [  y( [6 v

EXCEL和Matlab计算a=126.3747;

270    L
7 _3 k9 l. Q6 s14.33    b# z2 a% A6 `* ?
20.25    c; b. y4 n$ j* K- n4 S6 G
120.21    h

= -(2*A1^4*A2 - A1^4*A3 + 8*A1^2*A2^3 + 2*A1^2*A3^3 + 8*A3^3*A4^2 - 4*A1^2*A2*A3^2 - 4*A1^2*A2^2*A3 - 8*A1^2*A2*A4^2 - 4*A1^2*A3*A4^2 + 2*A1*A4*((A1 + A3)*(A1 - A3)*(A1^2 - 4*A2^2 + 4*A4^2)*(A1^2 - 4*A2^2 + 8*A2*A3 - 4*A3^2 + 4*A4^2))^(1/2))/(4*(4*A1^2*A2^2 - 4*A1^2*A2*A3 + A1^2*A3^2 - 4*A1^2*A4^2 + 4*A3^2*A4^2))


% y+ p" u" `/ W% P

不知道这个问题是怎么产生的,正在找原因。


+ z: J3 b: i5 _! b
作者: I_believe    时间: 2022-8-24 14:33
问题找到, 里边有一个(1/2)改成(1.00/2.00)后解决$ n' P  m* z5 h, p8 H
解决方法是把公式分解,一段一段对比
作者: Get_W    时间: 2022-8-24 14:40
会不会溢出了
作者: I_believe    时间: 2022-8-24 14:59
问题找到,是2个整数相除结果的小数部分被舍掉了




欢迎光临 EDA365电子论坛网 (https://bbs.eda365.com/) Powered by Discuz! X3.2