24小时热门版块排行榜    

北京石油化工学院2026年研究生招生接收调剂公告
查看: 1757  |  回复: 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的回帖
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 266分,求材料冶金能源化工等调剂 +5 哇呼哼呼哼 2026-03-27 7/350 2026-03-27 21:41 by lbsjt
[考研] 070300求调剂306分 +3 26要上岸 2026-03-27 3/150 2026-03-27 17:57 by arrow8852
[考研] 287求调剂 +10 land xuxu 2026-03-26 10/500 2026-03-27 15:33 by 帕尔马拉特
[考研] 269专硕求调剂 +10 金恩贝 2026-03-21 10/500 2026-03-27 15:10 by caszguilin
[考研] 0703化学338求调剂! +6 Zuhui0306 2026-03-26 7/350 2026-03-27 10:35 by shangxh
[考研] 329求调剂 +7 钮恩雪 2026-03-25 7/350 2026-03-27 04:28 by wxiongid
[考研] 321求调剂 +6 wasdssaa 2026-03-26 6/300 2026-03-26 20:57 by sanrepian
[考研] 【双一流院校新能源、环境材料,材料加工与模拟招收大量调剂】 +4 Higraduate 2026-03-22 8/400 2026-03-26 20:34 by Higraduate
[考研] 286求调剂 +13 Faune 2026-03-21 13/650 2026-03-26 19:52 by peike
[考研] 340求调剂 +3 Amber00 2026-03-26 3/150 2026-03-26 18:57 by 不吃魚的貓
[考研] 271求调剂 +6 生如夏花… 2026-03-22 6/300 2026-03-26 16:48 by 张凯十八号
[考研] 297求调剂 +6 田洪有 2026-03-26 6/300 2026-03-26 15:55 by 不吃魚的貓
[考研] 总分293求调剂 +6 加一一九 2026-03-25 8/400 2026-03-26 13:30 by yujianx
[考研] 材料与化工304求B区调剂 +3 邱gl 2026-03-25 3/150 2026-03-25 19:03 by Ainin_
[考研] 0703化学求调剂 +6 奶油草莓. 2026-03-22 7/350 2026-03-25 10:00 by shangxh
[考研] 340求调剂 +5 话梅糖111 2026-03-24 5/250 2026-03-25 06:53 by ilovexiaobin
[有机交流] 有机合成求助 20+3 FENGSHUJEI 2026-03-23 5/250 2026-03-24 19:31 by 88817753
[考研] 361求调剂 +3 Glack 2026-03-22 3/150 2026-03-23 22:03 by fuyu_
[考研] 接收2026硕士调剂(学硕+专硕) +4 allen-yin 2026-03-23 6/300 2026-03-23 15:04 by 汪!?!
[考研] 一志愿070300浙大化学358分,求调剂! +4 酥酥鱼.. 2026-03-21 4/200 2026-03-23 08:12 by Iveryant
信息提示
请填处理意见