24小时热门版块排行榜    

Znn3bq.jpeg
查看: 5584  |  回复: 12

nuomandi521

金虫 (小有名气)

[求助] Matlab求解a和b分别是不同值时 f(a,b,x)=0 的解 已有1人参与

希望求解 f(a,b,x)=0 的方程,求解a和b分别是不同值时候,x的值(大概率是复数)。
Matlab 运行如下程序后,

clear all
syms a b x;
a=0.9;
b=0.3;
x=solve('4*x^2*(x^2-1)*a^2+8*x^2*((sin(x*pi/2))^2-x^2)*a*b+4*((sin(x*pi/2))^2-x^2)^2*b^2+(sin(x*pi))^2','x');
x=subs(x);

出现问题,

警告: Support of character vectors that are not valid variable names or
define a number will be removed in a future release. To create symbolic
expressions, first create symbolic variables and then use operations on
them.
> In sym>convertExpression (line 1559)
  In sym>convertChar (line 1464)
  In sym>tomupad (line 1216)
  In sym (line 179)
  In solve>getEqns (line 405)
  In solve (line 225)
警告: Do not specify equations and variables as character vectors.
Instead, create symbolic variables with syms.
> In solve>getEqns (line 445)
  In solve (line 225)
警告: Cannot find explicit solution.
> In solve (line 316)

多谢指教!
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
回帖支持 ( 显示支持度最高的前 50 名 )

独孤神宇

版主 (知名作家)

引用回帖:
11楼: Originally posted by nuomandi521 at 2018-10-24 17:08:56
其实我是想把f(x)=0时,x的值赋给z。
所以这个for循环的目标不太对。
仍然无比感谢!...

真是无语,你直接将问题描述清楚不就行了。。

clear;
a=-0.6;
b=-0.9;
x=-3:0.01:3;
f=4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
z=[];
j=0;
for i=1:length(x)
       if abs(f(i))==0
            j=j+1;
          z(j)=x(i);
       end
end
z

%%%%*************************

clear;
a=-0.6;
b=-0.9;
x=-3:0.01:3;
f=4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
z=[];
j=0;
for i=1:length(x)
       if abs(f(i))<0.0001
            j=j+1;
          z(j)=x(i);
       end
end
z
数值计算
12楼2018-10-24 18:47:01
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
普通回帖

独孤神宇

版主 (知名作家)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
nuomandi521: 金币+20, ★★★★★最佳答案 2018-10-23 09:19:47
clear;
f=@(a,b)@(x)4*x^2*(x^2-1)*a^2+8*x^2*((sin(x*pi/2))^2-x^2)*a*b+4*((sin(x*pi/2))^2-x^2)^2*b^2+(sin(x*pi))^2;
x0=fzero(f(0.3,0.9),2)

» 本帖已获得的红花(最新10朵)

数值计算
2楼2018-10-22 19:57:15
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

nuomandi521

金虫 (小有名气)

送红花一朵
引用回帖:
2楼: Originally posted by 独孤神宇 at 2018-10-22 19:57:15
clear;
f=@(a,b)@(x)4*x^2*(x^2-1)*a^2+8*x^2*((sin(x*pi/2))^2-x^2)*a*b+4*((sin(x*pi/2))^2-x^2)^2*b^2+(sin(x*pi))^2;
x0=fzero(f(0.3,0.9),2)

感谢回答,为什么要在2附近寻找零点呢,有没有可能拿到所有的解,包括复数解,多谢指教!
3楼2018-10-22 20:14:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

独孤神宇

版主 (知名作家)

好像x=0解是最好的,你可以将图形画出来看看

发自小木虫Android客户端
数值计算
4楼2018-10-22 20:41:10
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

nuomandi521

金虫 (小有名气)

引用回帖:
4楼: Originally posted by 独孤神宇 at 2018-10-22 20:41:10
好像x=0解是最好的,你可以将图形画出来看看

问题解决,非常感谢!
5楼2018-10-23 09:19:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

nuomandi521

金虫 (小有名气)

引用回帖:
4楼: Originally posted by 独孤神宇 at 2018-10-22 20:41:10
好像x=0解是最好的,你可以将图形画出来看看

想将图形画出来看一下,编写程序如下,
>> syms x y a b
a=-0.6;
b=-0.9;
y=4*x^2*(x^2-1)*a^2+8*x^2*((sin(x*pi/2))^2-x^2)*a*b+4*((sin(x*pi/2))^2-x^2)^2*b^2+(sin(x*pi))^2;
x = linspace(-3,3);
plot(x,y);

出现问题,
错误使用 plot
数据必须为可转换为双精度值的数值、日期时间、持续时间或数组。

请问怎么解决?
6楼2018-10-23 17:09:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

独孤神宇

版主 (知名作家)

引用回帖:
6楼: Originally posted by nuomandi521 at 2018-10-23 17:09:03
想将图形画出来看一下,编写程序如下,
&gt;&gt; syms x y a b
a=-0.6;
b=-0.9;
y=4*x^2*(x^2-1)*a^2+8*x^2*((sin(x*pi/2))^2-x^2)*a*b+4*((sin(x*pi/2))^2-x^2)^2*b^2+(sin(x*pi))^2;
x = linspace( ...

matlab 基础要好好学一下了。。

a=-0.6;
b=-0.9;
x = linspace(-3,3);
y=4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
plot(x,y);

» 本帖已获得的红花(最新10朵)

数值计算
7楼2018-10-23 17:59:03
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

nuomandi521

金虫 (小有名气)

送红花一朵
引用回帖:
7楼: Originally posted by 独孤神宇 at 2018-10-23 17:59:03
matlab 基础要好好学一下了。。

a=-0.6;
b=-0.9;
x = linspace(-3,3);
y=4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
plot(x,y);...

基础确实薄弱,无比感谢!
8楼2018-10-24 10:02:21
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

nuomandi521

金虫 (小有名气)

引用回帖:
7楼: Originally posted by 独孤神宇 at 2018-10-23 17:59:03
matlab 基础要好好学一下了。。

a=-0.6;
b=-0.9;
x = linspace(-3,3);
y=4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
plot(x,y);...

我希望解的精度再高一些,于是编写程序如下,
f=@(a,b)@(x)4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
x=-3:0.01:3;z=[];
for i=1:length(x)
       if abs(f(x(i)))<0.01
          z=[z x(i)];
       end
end
z

运行后出现问题,
未定义与 'function_handle' 类型的输入参数相对应的函数 'abs'。

请问如何解决?
9楼2018-10-24 10:28:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

独孤神宇

版主 (知名作家)

引用回帖:
9楼: Originally posted by nuomandi521 at 2018-10-24 10:28:26
我希望解的精度再高一些,于是编写程序如下,
f=@(a,b)@(x)4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
x=-3:0.01:3;z=[];
for i=1:length( ...

clear;
a=-0.6;
b=-0.9;
x=-3:0.01:3;
f=4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
z=[];
for i=1:length(x)
       if abs(f(i))<0.01
          z(i)=f(i);
       end
end
z;

%%%%**********************

clear;
a=-0.6;
b=-0.9;
x=-3:0.01:3;
f=4*x.^2.*(x.^2-1)*a^2+8*x.^2.*((sin(x*pi/2)).^2-x.^2)*a*b+4*((sin(x*pi/2)).^2-x.^2).^2*b^2+(sin(x*pi)).^2;
z=[];
j=0;
for i=1:length(x)
       if abs(f(i))<0.01
           j=j+1;
          z(j)=f(j);
       end
end
z;

» 本帖已获得的红花(最新10朵)

数值计算
10楼2018-10-24 10:50:44
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 nuomandi521 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考博] 化学专业申博 +3 赵子羊 2026-05-23 4/200 2026-05-24 18:10 by 工大学长
[基金申请] 评审有感 +16 popular289 2026-05-18 27/1350 2026-05-24 17:34 by hhs666
[教师之家] 论文撤稿了 +4 bjvtcliu 2026-05-24 7/350 2026-05-24 17:29 by bjvtcliu
[硕博家园] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +4 hvkbtfonbv 2026-05-23 4/200 2026-05-24 17:21 by 75ui6h7z2t
[博后之家] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 hvkbtfonbv 2026-05-23 3/150 2026-05-24 17:10 by 75ui6h7z2t
[考博] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 hvkbtfonbv 2026-05-23 3/150 2026-05-24 17:01 by 75ui6h7z2t
[考研] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 a2tycdlnq1 2026-05-23 5/250 2026-05-24 16:21 by hhx1yx9evi
[论文投稿] 售SCI一区T0P文章,我:8.O.5.5.1.O.5.4,科目齐全,可+急 +3 a2tycdlnq1 2026-05-23 4/200 2026-05-24 16:16 by hhx1yx9evi
[基金申请] 河北省自然科学基金 +6 Peterchao 2026-05-18 9/450 2026-05-24 16:02 by 130067131
[基金申请] 西安交大新媒学院副院长用撤稿论文结题 +3 bjvtcliu 2026-05-24 5/250 2026-05-24 10:16 by kudofaye
[教师之家] 某211大学教师把个人教师官方主页改成:我跑了我跑了我跑了!官宣跑路! +4 zju2000 2026-05-21 5/250 2026-05-24 09:35 by songwz
[基金申请] 青B发送上会通知了吗 +5 chemBioBro 2026-05-22 7/350 2026-05-23 12:35 by zhuifengzhy
[考博] 博士申请 +3 焦晓明 2026-05-21 3/150 2026-05-23 11:26 by mlc840311
[论文投稿] 投稿求助,期刊 +4 希冀,有书读 2026-05-20 8/400 2026-05-22 10:16 by 希冀,有书读
[文学芳草园] 献血感触 +7 呀呀好傻 2026-05-19 13/650 2026-05-21 20:15 by 呀呀好傻
[基金申请] 国自然评分 +4 无名者登山 2026-05-20 5/250 2026-05-21 16:35 by swuq
[基金申请] 国自然上会要求 +7 无名者登山 2026-05-18 11/550 2026-05-21 15:50 by draco1987
[基金申请] 提交了我也来说说感想 +9 fummck 2026-05-20 10/500 2026-05-21 14:17 by draco1987
[有机交流] 反应很差,大量原料没有反应 5+3 Mr.Zot 2026-05-19 8/400 2026-05-20 22:19 by Equinoxhua
[考博] 如果工作了想读博,可以边工作边读全日制嘛? 30+3 铁达火车 2026-05-18 5/250 2026-05-20 09:33 by tfang
信息提示
请填处理意见