24小时热门版块排行榜    

Znn3bq.jpeg
查看: 6949  |  回复: 6

Cabird

新虫 (初入文坛)

[求助] Matlab数值积分结果是虚数

小木虫的各位童鞋们,我现在调试matlab程序遇到一个问题。一个很复杂的关于角度theta的数值积分,我调用自带的quadl函数,结果出现虚数。我后来又根据变步长的simpson算法编了一个数值积分程序,结果还是有虚数,而且我的积分程序和quadl算出的结果还有一些误差。积分函数包含了很多三角函数,还有e的指数函数在里面,但是积分过程中并无傅里叶变换等可以带来虚数的过程,不知道虚数是怎么来的。我把积分函数曲线都画出来了,波动比较大,但是作为一个面积,怎么会出现虚数呢?我把我的八个积分函数表达式以及各自的函数曲线贴出来,希望大神们帮我看看,给点意见。论文卡在这里,一直得不到解决。
%========function group of theta=====================
    function F1=Ff1(theta)
%======== basic formula=============================
% TO identify whether the rotating axis is inside the circle
if rrat<=0
    rm=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp((theta-theta0)*tan(phi)));
     R=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp((theta-theta0)*tan(phi)));
else
    rm=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp(-(theta-theta0)*tan(phi)));
     R=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp(-(theta-theta0)*tan(phi)));
end

a=sin(theta0)/sin(theta)-rm;
F1=2*cos(theta)*(((R^2-a^2)^(1/2))*(0.125*R^2*a-0.25*a^3-0.5*a*rm^2+(R^2-a^2)*rm)...
    +(0.5*pi-asin(a/R))*(0.125*R^4+0.5*rm^2*R^2));
    end

    function F2=Ff2(theta)
%========basic formula=============================
% TO identify whether the rotating axis is inside the circle
if rrat<=0
    rm=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp((theta-theta0)*tan(phi)));
     R=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp((theta-theta0)*tan(phi)));
else
rm=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp(-(theta-theta0)*tan(phi)));
R=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp(-(theta-theta0)*tan(phi)));
end
d=sin(betaS+thetah)/sin(betaS+theta)*exp((thetah-theta0)*tan(phi))-rm;
F2=2*cos(theta)*(((R^2-d^2)^(1/2))*(0.125*R^2*d-0.25*d^3-0.5*d*rm^2+(R^2-d^2)*rm)...
    +(0.5*pi-asin(d/R))*(0.125*R^4+0.5*rm^2*R^2));  
    end

    function G1=Gf1(theta)
%========= basic formula=============================
% TO identify whether the rotating axis is inside the circle
if rrat<=0
    rm=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp((theta-theta0)*tan(phi)));
     R=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp((theta-theta0)*tan(phi)));
else
rm=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp(-(theta-theta0)*tan(phi)));
R=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp(-(theta-theta0)*tan(phi)));
end
a=sin(theta0)/sin(theta)-rm;
G1=(rm^2*(R-a)+rm*(R^2-a^2)+(1/3)*(R^3-a^3))*cos(theta);
    end

    function G2=Gf2(theta)
%=========basic formula=============================
% TO identify whether the rotating axis is inside the circle
if rrat<=0
    rm=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp((theta-theta0)*tan(phi)));
     R=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp((theta-theta0)*tan(phi)));
else
rm=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp(-(theta-theta0)*tan(phi)));
R=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp(-(theta-theta0)*tan(phi)));
end
d=sin(betaS+thetah)/sin(betaS+theta)*exp((thetah-theta0)*tan(phi))-rm;
G2=(rm^2*(R-d)+rm*(R^2-d^2)+(1/3)*(R^3-d^3))*cos(theta);  
    end

    function E1=Ef1(theta)
%=========basic formula=============================
% TO identify whether the rotating axis is inside the circle
if rrat<=0
    rm=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp((theta-theta0)*tan(phi)));
     R=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp((theta-theta0)*tan(phi)));
else
rm=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp(-(theta-theta0)*tan(phi)));
R=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp(-(theta-theta0)*tan(phi)));
end
a=sin(theta0)/sin(theta)-rm;
E1=(cos(theta)/(sin(theta))^3)*(R^2-a^2)^(1/2);  
    end

    function E2=Ef2(theta)
%========= basic formula=============================
% TO identify whether the rotating axis is inside the circle
if rrat<=0
    rm=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp((theta-theta0)*tan(phi)));
     R=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp((theta-theta0)*tan(phi)));
else
rm=0.5*(exp((theta-theta0)*tan(phi))+rrat*exp(-(theta-theta0)*tan(phi)));
R=0.5*(exp((theta-theta0)*tan(phi))-rrat*exp(-(theta-theta0)*tan(phi)));
end
d=sin(betaS+thetah)/sin(betaS+theta)*exp((thetah-theta0)*tan(phi))-rm;
E2=cos(theta+betaS)/((sin(theta+betaS))^3)*(R^2-d^2)^(1/2);
    end

    function H1=Hf1(theta)
%===========basic formula=============================
H1=cos(theta)/(sin(theta))^3;
    end

    function H2=Hf2(theta)
%========= basic formula=============================
H2=cos(theta+betaS)/(sin(theta+betaS))^3;
    end
==========computational parameters==================
d2r=pi/180;
theta0=20*d2r;thetah=100*d2r;rrat=0.6;brat=0.5;
betaS=45*d2r; phi=30*d2r;
A1=sin(betaS+thetah)/sin(theta0)*exp((thetah-theta0)*tan(phi));
B1=cos(betaS);
C1=sin(betaS);
thetaB=acot((A1-B1)/C1);
%===========numerical integration for W and D==============

Wd1=quadl(@Ff1,theta0,thetaB);
Wd2=quadl(@Ff2,thetaB,thetah);
Wd=Wd1+Wd2;

Wp1=quadl(@Gf1,theta0,thetaB);
Wp2=quadl(@Gf2,thetaB,thetah);
Wp=Wp1+Wp2;

Kd1=quadl(@Ef1,theta0,thetaB);
Kd2=quadl(@Ef2,thetaB,thetah);
Dd=-2*cot(phi)*(sin(theta0))^2*Kd1...
    -2*cot(phi)*exp(2*(thetah-theta0)*tan(phi))*(sin(thetah+betaS))^2*Kd2;

Kp1=quadl(@Hf1,theta0,thetaB);
Kp2=quadl(@Hf2,thetaB,thetah);
Dp=-cot(phi)*(sin(theta0))^2*Kp1...
    -cot(phi)*exp(2*(thetah-theta0)*tan(phi))*(sin(thetah+betaS))^2*Kp2;

disp('[Wd1,Wd2,Wp1,Wp2,Kd1,Kd2,Kp1,Kp2]=');
disp([Wd1,Wd2,Wp1,Wp2,Kd1,Kd2,Kp1,Kp2]');

八个被积函数曲线.jpg
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

solar0913

至尊木虫 (著名写手)

【答案】应助回帖

感谢参与,应助指数 +1
问题出在开根号里,根号下的值为负数,所以导致有虚数。

[ 发自手机版 http://muchong.com/3g ]
2楼2013-03-21 00:09:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

Cabird

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by solar0913 at 2013-03-21 00:09:03
问题出在开根号里,根号下的值为负数,所以导致有虚数。

很多天没上木虫,才看到你的回复。发帖的第二天帮师兄调程序发现根号问题反应过来了,忘记删帖了。
3楼2013-04-08 16:59:41
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

gyp0901911

新虫 (初入文坛)

您好!问题解决了吗?我也遇到同样的困难
4楼2013-04-08 17:00:46
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

匿名

用户注销 (正式写手)

本帖仅楼主可见
5楼2013-04-08 23:02:32
已阅   申请EPI   回复此楼   编辑   查看我的主页

左思之一

铁虫 (小有名气)

用dde23求解时滞微分方程,没有负数开放方情况,出现虚数解,怎么回事?
今天天是蓝的
6楼2015-04-17 10:52:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

左思之一

铁虫 (小有名气)

引用回帖:
4楼: Originally posted by gyp0901911 at 2013-04-08 17:00:46
您好!问题解决了吗?我也遇到同样的困难

您的问题解决了吗?用dde23求解时滞微分方程,没有负数开放方情况,出现虚数解,合理吗?
今天天是蓝的
7楼2015-04-17 10:53:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 Cabird 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 复试调剂,一志愿郑州大学材料与化工289分 +16 硕星赴 2026-04-08 16/800 2026-04-09 07:38 by 5268321
[考研] 工科 267求调剂 +6 wanwan00 2026-04-02 8/400 2026-04-08 22:09 by 朱云虎202
[考研] 0703化学调剂 348分 +14 唉我超真没招了 2026-04-06 15/750 2026-04-08 19:16 by 我减肥1
[考研] 一志愿郑州大学085600求调剂 +21 吃的不少 2026-04-05 24/1200 2026-04-08 16:47 by sunhuadong
[考研] 求调剂,现在还能填的 +3 上岸小莹加油 2026-04-08 3/150 2026-04-08 14:30 by zhq0425
[考研] 材料调剂 +19 一样YWY 2026-04-02 20/1000 2026-04-08 11:02 by 不吃魚的貓
[考研] 312 化工或制药调剂 +9 小小墨123 2026-04-02 10/500 2026-04-08 10:30 by screening
[考研] 362求调剂 +8 我要考大 2026-04-06 12/600 2026-04-08 00:32 by JourneyLucky
[考研] 388求调剂 +6 四川王涛 2026-04-07 8/400 2026-04-08 00:17 by JourneyLucky
[考研] 机械调剂 +3 zzzbcb 2026-04-07 3/150 2026-04-07 22:19 by hemengdong
[考研] 338求调剂 +5 小猪红色 678 2026-04-06 6/300 2026-04-07 21:18 by 乔哒哒哒
[考研] 调剂 +4 mcbbc 2026-04-06 5/250 2026-04-07 12:33 by upczlm1989
[考研] 372分材料与化工(085600)英二数二求调剂 +4 蓝笺片 2026-04-06 4/200 2026-04-07 12:30 by dongzh2009
[考研] 333求调剂 +6 合乘杨习夕 2026-04-06 6/300 2026-04-07 09:44 by 猪会飞
[考研] 308求调剂 +3 终不似从前 2026-04-05 3/150 2026-04-05 22:23 by hemengdong
[考研] 272分求调剂 +4 wangyile2233 2026-04-02 4/200 2026-04-05 22:21 by 286640313
[考研] 278求调剂 +3 依旧! 2026-04-02 4/200 2026-04-04 20:27 by 蓝云思雨
[考研] 293求调剂 +5 末未mm 2026-04-02 6/300 2026-04-03 15:20 by 王保杰33
[考研] 机械专硕297 +3 Afksy 2026-04-03 3/150 2026-04-03 14:24 by 1753564080
[考研] 求调剂 +3 usbdndj 2026-04-03 3/150 2026-04-03 14:10 by dxiaoxin
信息提示
请填处理意见