my312318 2021-10-02 19:49 采纳率: 50%
浏览 57
已结题

Matlab解微分方程组

img

  • 写回答

1条回答 默认 最新

  • 技术专家团-Joel 2021-10-02 22:33
    关注

    你好,答案仅供参考,一般符号求解和数值计算均可以这样做

    syms x1(t) x2(t) 
    syms a b real
    eq = [diff(x1)==a*x1+b*x2; diff(x2)==-b*x1+a*x2];
    conds = [x1(0)==1; x2(0)==1];
    [x1,x2] = dsolve(eq,conds);
    % (1) 四个解析解
    x1_sol1 = subs(x1, [a,b], [0.1,1])
    x2_sol1 = subs(x2, [a,b], [0.1,1])
    x1_sol2 = subs(x1, [a,b], [0.1,-1])
    x2_sol2 = subs(x2, [a,b], [0.1,-1])
    x1_sol3 = subs(x1, [a,b], [-0.1,1])
    x2_sol3 = subs(x2, [a,b], [-0.1,1])
    x1_sol4 = subs(x1, [a,b], [-0.1,-1])
    x2_sol4 = subs(x2, [a,b], [-0.1,-1])
    % (2)数值解:
    a_arr = [0.1, -0.1];
    b_arr = [1,-1];
    count = 0;
    figure(1);clf;
    for i = 1:1:numel(a_arr)
        for j = 1:1:numel(b_arr)
            a = a_arr(i); b = b_arr(j);
            count = count + 1;
            subplot(2,2, count)
            odefun = @(t,x) [a*x(1)+b*x(2); -b*x(1)+a*x(2)];
            [t,x] = ode45(odefun, [0, 10*pi], [1;1]);
            plot(x(:,1),x(:,2));%画相图
            title(['a=',num2str(a),',b=',num2str(b)])
        end
    end
    
    

    最后表达式

    x1_sol1 =
     
    exp(t/10)*cos(t) + exp(t/10)*sin(t)
     
     
    x2_sol1 =
     
    exp(t/10)*cos(t) - exp(t/10)*sin(t)
     
     
    x1_sol2 =
     
    exp(t/10)*cos(t) - exp(t/10)*sin(t)
     
     
    x2_sol2 =
     
    exp(t/10)*cos(t) + exp(t/10)*sin(t)
     
     
    x1_sol3 =
     
    exp(-t/10)*cos(t) + exp(-t/10)*sin(t)
     
     
    x2_sol3 =
     
    exp(-t/10)*cos(t) - exp(-t/10)*sin(t)
     
     
    x1_sol4 =
     
    exp(-t/10)*cos(t) - exp(-t/10)*sin(t)
     
     
    x2_sol4 =
     
    exp(-t/10)*cos(t) + exp(-t/10)*sin(t)
    
    

    相图

    img

    可知
    最终相图都是螺旋进入原点,且ab的正负决定了相图螺旋的方向

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月11日
  • 已采纳回答 10月3日
  • 创建了问题 10月2日

悬赏问题

  • ¥15 腾讯云如何建立同一个项目中物模型之间的联系
  • ¥30 VMware 云桌面水印如何添加
  • ¥15 用ns3仿真出5G核心网网元
  • ¥15 matlab答疑 关于海上风电的爬坡事件检测
  • ¥88 python部署量化回测异常问题
  • ¥30 酬劳2w元求合作写文章
  • ¥15 在现有系统基础上增加功能
  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码