24小时热门版块排行榜    

查看: 5412  |  回复: 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 的主题更新
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 工科材料085601 279求调剂 +3 困于星晨 2026-03-17 3/150 2026-03-17 14:08 by ms629
[考研] 一志愿南京大学,080500材料科学与工程,调剂 +4 Jy? 2026-03-16 4/200 2026-03-17 11:02 by gaoqiong
[考研] 332求调剂 +5 Zz版 2026-03-13 5/250 2026-03-17 11:01 by JineShine
[考研] 285化工学硕求调剂(081700) +9 柴郡猫_ 2026-03-12 9/450 2026-03-17 10:18 by Sammy2
[考研] 278求调剂 +3 Yy7400 2026-03-13 3/150 2026-03-17 08:24 by laoshidan
[考研] 化学工程321分求调剂 +10 大米饭! 2026-03-15 13/650 2026-03-17 06:57 by laoshidan
[考研] 318求调剂 +3 Yanyali 2026-03-15 3/150 2026-03-16 16:41 by houyaoxu
[考研] 304求调剂 +3 曼殊2266 2026-03-14 3/150 2026-03-16 16:39 by houyaoxu
[考研] 311求调剂 +5 26研0 2026-03-15 5/250 2026-03-16 16:21 by a不易
[考研] 材料与化工一志愿南昌大学327求调剂推荐 +7 Ncdx123456 2026-03-13 8/400 2026-03-16 12:15 by karry wen
[考研] 26考研一志愿中国石油大学(华东)305分求调剂 +3 嘉年新程 2026-03-15 3/150 2026-03-15 13:58 by 哈哈哈哈嘿嘿嘿
[考研] 085601材料工程315分求调剂 +3 yang_0104 2026-03-15 3/150 2026-03-15 10:58 by peike
[考研] 本科南京大学一志愿川大药学327 +3 麦田耕者 2026-03-14 3/150 2026-03-14 20:04 by 外星文明
[考研] 297求调剂 +4 学海漂泊 2026-03-13 4/200 2026-03-14 11:51 by 热情沙漠
[考研] 材料工程,326分,求调剂 +6 KRSLSR 2026-03-10 6/300 2026-03-13 23:47 by JourneyLucky
[考研] 301求调剂 +6 Liyouyumairs 2026-03-11 6/300 2026-03-13 20:11 by JourneyLucky
[考研] 【0856】化学工程(085602)313 分,本科学科评估A类院校化学工程与工艺,诚求调剂 +7 小刘快快上岸 2026-03-11 7/350 2026-03-13 16:06 by ruiyingmiao
[考研] 一志愿211化学学硕310分求调剂 +8 努力奋斗112 2026-03-12 9/450 2026-03-13 15:41 by JourneyLucky
[考研] 321求调剂(食品/专硕) +3 xc321 2026-03-12 6/300 2026-03-13 08:45 by xc321
[考研] 290求调剂 +3 柯淮然 2026-03-10 8/400 2026-03-11 13:48 by 柯淮然
信息提示
请填处理意见