「已注销」 2021-10-15 23:27 采纳率: 100%
浏览 680
已结题

matlab悬链线微分方程

给定两点距离 悬链线长度,怎么用matlab解微分方程求出最低点到两点间的竖直高度

  • 写回答

1条回答 默认 最新

  • 技术专家团-Joel 2021-10-16 11:07
    关注

    你好同学,这个就是利用已知的数据获得悬链线方程的参数a,从而得到最低点到两点的竖直高度。代码供参考,这里我选取的是长度为10,距离为8,举了个例子
    该注释的地方都注释了:

    % y = a*(cosh(x/a)-1); % 过原点的悬链线方程
    % 现在已知悬链线长度s和两悬挂点的距离d, 求a
    % 从而获取悬挂点高度h
    % y对x的导数y'=sinh(x/a)
    s = 10;%给定悬链线长度
    d = 8;%给定两固定点距离
    ds = @(x,a)sqrt(1+sinh(x/a).^2);% ds=sqrt(1+(dy/dx)^2)*dx
    fun = @(a) integral(@(x)ds(x,a), -d/2, d/2) - s;%求解这个方程获取参数a
    a = fsolve(fun, 100*rand(1));%fsolve来求解
    a = abs(a); % 有可能a是负的但是负数画出来就是倒着的,不太好看
    eq = @(x)a*(cosh(x/a)-1);%获取最后悬链线方程,a是已知了
    x = linspace(-d/2, d/2, 101);%画图用的x从-d/2到d/2
    y = eq(x);
    plot(x,y,'r-','linewidth',2); title('悬链线示意图');axis equal
    h = a*(cosh(d/2/a)-1);%获取x=d/2时的高度,就是悬链线底部到固定点的高度
    fprintf('最低点到两点间的竖直高度=%f\n',h); %输出高度
    

    这个例子的悬链线底部到两个固定点高度输出为:

    最低点到两点间的竖直高度=2.654375
    

    悬链线形状

    img

    如有帮助,还望点个右上角的采纳支持一下哟

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

报告相同问题?

问题事件

  • 系统已结题 10月25日
  • 已采纳回答 10月17日
  • 创建了问题 10月15日

悬赏问题

  • ¥15 远程桌面文档内容复制粘贴,格式会变化
  • ¥15 关于#java#的问题:找一份能快速看完mooc视频的代码
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题