matlab去掉两式的中间变量,如何使得两个子函数共用变量?

该博客探讨了如何在MATLAB中优化两个子函数,使其能够共用中间变量,以消除不必要的计算。通过示例展示了Newton迭代法的实现,其中`myfun`和`myJacobi`函数计算距离并生成雅可比矩阵,涉及符号运算和矩阵操作。文章讨论了如何调整代码结构以减少重复计算,提高效率。
摘要由CSDN通过智能技术生成

function  Newton()

format long

x0=[0;0;200;0;0;0];

x1=x0-inv(myJacobi(x0))*myfun(x0);

while norm(x1-x0)>1e-3

x0=x1;

x1=x0-inv(myJacobi(x0))*myfun(x0);

end

x1

end

function f=myfun(x)

syms x1 x2 x3 a b g

X=[x1;x2;x3];

RX=[1 0 0;0 cos(a) -sin(a);0 sin(a) cos(a)];

RY=[cos(b) 0 sin(b);0 1 0;-sin(b) 0 cos(b)];

RZ=[cos(g) -sin(g) 0;sin(g) cos(g) 0; 0 0 1];

R=RZ*RY*RX;

B1P1=[  121          -140       0  120         -20         0;  %初始参数矩阵%B1、P1

120         140         0  120         20          0;

61.243557   173.92305   0  -42.679489  113.92304   0;

-181.24356  33.92305    0  -77.320511  93.923042   0;

-181.24356  -33.92305   0  -77.320511  -93.923042  0;

61.243557   -173.92305  0  -42.679489  -113.92304  0];

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值