24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1758  |  回复: 5
当前只显示满足指定条件的回帖,点击这里查看本话题的所有回帖

cologate007

新虫 (初入文坛)

[求助] matlab对含贝塞尔函数的超越方程求根 已有1人参与

有一个含有贝塞尔函数的超越方程,用solve函数求解,输入matlab直接给出了一个复数结果,但是实际上超越方程是有很多个根的,不知道给出的这个解是第几阶的?怎么样才能得到它的第n(任意的)阶根呢?采用牛顿迭代法给定不同的初值可以计算得到不同的根,但是也不能确定是第几阶。不知道论坛里有没有朋友有更好的计算方法?函数就不贴了,下面是牛顿迭代法的matlab程序,函数见里面的f。请了解的朋友给点意见,感谢!

clc;clear;close all;
r0=0.0125;
r=r0;
fre=1000;
z=0;
l=0.122;
r0=0.0125;
r=r0;
rou0=1000;
a0=1500;
pi=3.1415926;
k0=2*pi*f/a0;
Zw=1800000*(1+i);
%牛顿迭代法
syms f kr;
f=subs('besselj(0,kr*r0)-kr*r0*i*Zw/(rou0*a0*k0*r0)*besselj(1,kr*r0)');
df=diff(f);
kr0=0.1-0.1*i;
e1=0.1e-10;
e2=0.000005;
N=100;
k=1;
while (k<N)
  kr=kr0;
if abs(eval(f))<e1
fprintf('奇异!\nkr=%.6f\n迭代次数为:%d\n',kr0,k)
break
else
kr1=kr0-eval(f)/eval(df);
if abs(kr1-kr0)<e2
fprintf('kr=%.6f\n迭代次数为:%d\n',kr1,k)
break
else
kr0=kr1;
k=k+1;
end
end
end
if k>=N
fprintf('失败\n')
end
回复此楼

» 猜你喜欢

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

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

cologate007

新虫 (初入文坛)

引用回帖:
4楼: Originally posted by mathstudy at 2015-03-24 09:44:38
超越方程的根是迭代出来的,既然是迭代算法,一般是要给定迭代的初值或者初始区间的。但是楼主说的第几阶根,我就不甚明白了?可以是任意阶?...

这个我知道,迭代算法计算一次是只能得到给定初值附近的根,假设我想要就是第一阶根就可以了,由于计算的是复数,所以我想知道怎样确定得到的就是第一阶根?这个第一阶就是所有的根(给定不同的初值迭代得到的)中幅值最小的那个吗?
5楼2015-03-24 14:20:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
查看全部 6 个回答

mathstudy

金虫 (正式写手)

【答案】应助回帖

★ ★
感谢参与,应助指数 +1
cologate007: 金币+2, 有帮助 2015-03-23 14:15:56
方程 的可以从小到大以此排列到无穷大,至于直接求第n个根确实不好求, 而且迭代法求出的根也难免漏掉....建议楼主从网上搜索相关程序,有高手分享类似的Mathematica程序  求解超越方程在任意区间的根
2楼2015-03-23 09:33:06
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

cologate007

新虫 (初入文坛)

引用回帖:
2楼: Originally posted by mathstudy at 2015-03-23 09:33:06
方程 的可以从小到大以此排列到无穷大,至于直接求第n个根确实不好求, 而且迭代法求出的根也难免漏掉....建议楼主从网上搜索相关程序,有高手分享类似的Mathematica程序  求解超越方程在任意区间的根

谢谢您的回复,你说的从小到大排列也要先求出这些根来,那么这个求解是要在给定范围内慢慢的迭代算出来吗?而且我有点不清楚,这个第几阶的根是根据复数的幅值的大小来判断的吗?
3楼2015-03-23 14:15:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

mathstudy

金虫 (正式写手)

引用回帖:
3楼: Originally posted by cologate007 at 2015-03-23 14:15:33
谢谢您的回复,你说的从小到大排列也要先求出这些根来,那么这个求解是要在给定范围内慢慢的迭代算出来吗?而且我有点不清楚,这个第几阶的根是根据复数的幅值的大小来判断的吗?...

超越方程的根是迭代出来的,既然是迭代算法,一般是要给定迭代的初值或者初始区间的。但是楼主说的第几阶根,我就不甚明白了?可以是任意阶?
4楼2015-03-24 09:44:38
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 308求调剂 +7 墨墨漠 2026-03-27 7/350 2026-03-28 07:43 by 热情沙漠
[考研] 266分,求材料冶金能源化工等调剂 +6 哇呼哼呼哼 2026-03-27 8/400 2026-03-28 07:15 by mmm just
[考研] 求调剂 +6 白QF 2026-03-21 7/350 2026-03-28 00:42 by 白QF
[有机交流] 高温高压反应求助 10+4 chibby 2026-03-25 4/200 2026-03-27 21:08 by BT20230424
[考研] 266求调剂 +11 阳阳哇塞 2026-03-27 12/600 2026-03-27 17:56 by yu221
[考研] 材料292调剂 +12 橘颂思美人 2026-03-23 12/600 2026-03-27 15:44 by caszguilin
[考研] 274求调剂 +17 顾九笙要谦虚 2026-03-24 23/1150 2026-03-27 15:16 by caszguilin
[考研] 269专硕求调剂 +10 金恩贝 2026-03-21 10/500 2026-03-27 15:10 by caszguilin
[考研] 305求调剂 +5 哇卢卡库 2026-03-26 5/250 2026-03-27 14:01 by laoshidan
[考研] 一志愿陕师大生物学071000,298分,求调剂 +5 SYA! 2026-03-23 5/250 2026-03-27 09:29 by 不吃魚的貓
[考研] 327求调剂 +7 prayer13 2026-03-23 7/350 2026-03-26 20:48 by 不吃魚的貓
[考研] 一志愿北京化工大学材料与化工(085600)296求调剂 +9 稻妻小编 2026-03-26 9/450 2026-03-26 16:16 by 不吃魚的貓
[考研] 284求调剂 +15 Zhao anqi 2026-03-22 15/750 2026-03-25 12:51 by wht0531
[考研] 一志愿北化315 求调剂 +3 akrrain 2026-03-24 3/150 2026-03-24 19:35 by 了了了了。。
[考研] 求调剂 +6 研研,接电话 2026-03-24 7/350 2026-03-24 17:01 by barlinike
[考研] 材料考研调剂生 +3 黄粱一梦千年 2026-03-24 3/150 2026-03-24 17:00 by barlinike
[考研] 080500求调剂 +3 zzzzfan 2026-03-24 3/150 2026-03-24 16:38 by barlinike
[考研] 求调剂一志愿武汉理工大学材料工程(085601) +5 WW.' 2026-03-23 7/350 2026-03-24 14:50 by sprinining
[考研] 333求调剂 +3 ALULU4408 2026-03-23 3/150 2026-03-23 19:04 by macy2011
[考研] 293求调剂 +3 涛涛Wjt 2026-03-22 5/250 2026-03-22 22:21 by jiangpengfei
信息提示
请填处理意见