89456418961 2022-02-28 16:33 采纳率: 84.6%
浏览 747
已结题

MATLAB fsolve:串联的矩阵的维度不一致,如何解决?

a=9;
d=0.6;
xr1=1;
xg1=1;
xb1=1.2;

x0=[2,2,2,2,2,2,0.6];      % 初始参考点

fun=@(x)[

(x(1)+x(2)+x(1)+2*x(7))-a ,...

(x(2)*3^0.5+d+(x(2)*3^0.5+d)/2)-a   ,...
   
(3^0.5*(x(1)*x(2)+x(2)*x(2)/2)/a/a)/(3^0.5*(x(3)*x(4)+x(4)*x(4)/2)/a/a)-xr1/xg1 ,...
(3^0.5*(x(3)*x(4)+x(4)*x(4)/2)/a/a)/(3^0.5*(x(5)*x(6)+x(6)*x(6)/2)/a/a)-xg1/xb1 ,...
(3^0.5*(x(1)*x(2)+x(2)*x(2)/2)/a/a)/(3^0.5*(x(5)*x(6)+x(6)*x(6)/2)/a/a)-xr1/xb1 ,...
    ];
x=fsolve(fun,x0);   %调用函数

Lr1=x(1)
Lr2=x(2)
Lg1=x(3)
Lg2=x(4)
Lb1=x(5)
Lb2=x(6)
Ld =x(7)

错误使用 vertcat
串联的矩阵的维度不一致。

出错 fsolve (line 230)
fuser = feval(funfcn{3},x,varargin{:});

出错 SIX (line 41)
x=fsolve(fun,x0); %调用函数

原因:
Failure in initial objective function evaluation.
FSOLVE cannot continue.

  • 写回答

1条回答 默认 最新

  • joel_1993 2022-02-28 19:11
    关注

    你好,把函数句柄里面的逗号改成分号就行

    a=9;
    d=0.6;
    xr1=1;
    xg1=1;
    xb1=1.2;
     
    x0=[2,2,2,2,2,2,0.6];      % 初始参考点
     
    fun=@(x)[
    (x(1)+x(2)+x(1)+2*x(7))-a ;...
    (x(2)*3^0.5+d+(x(2)*3^0.5+d)/2)-a   ;...
    (3^0.5*(x(1)*x(2)+x(2)*x(2)/2)/a/a)/(3^0.5*(x(3)*x(4)+x(4)*x(4)/2)/a/a)-xr1/xg1 ;...
    (3^0.5*(x(3)*x(4)+x(4)*x(4)/2)/a/a)/(3^0.5*(x(5)*x(6)+x(6)*x(6)/2)/a/a)-xg1/xb1 ;...
    (3^0.5*(x(1)*x(2)+x(2)*x(2)/2)/a/a)/(3^0.5*(x(5)*x(6)+x(6)*x(6)/2)/a/a)-xr1/xb1 ;...
        ]; % 把函数句柄里面的逗号改成分号就行
    x=fsolve(fun,x0);   %调用函数
     
    Lr1=x(1)
    Lr2=x(2)
    Lg1=x(3)
    Lg2=x(4)
    Lb1=x(5)
    Lb2=x(6)
    Ld =x(7)
    
    

    结果

    
    Lr1 =
    
       1.722973255909702
    
    
    Lr2 =
    
       3.117691453619087
    
    
    Lg1 =
    
       2.367819755812734
    
    
    Lg2 =
    
       2.738056112727723
    
    
    Lb1 =
    
       2.522158681936574
    
    
    Lb2 =
    
       3.038179617322688
    
    
    Ld =
    
       1.218181017277643
    

    有帮助望采纳哟,谢谢啦

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 3月9日
  • 已采纳回答 3月1日
  • 创建了问题 2月28日

悬赏问题

  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载
  • ¥15 c#逐行读取txt文本,但是每一行里面数据之间空格数量不同
  • ¥50 如何openEuler 22.03上安装配置drbd
  • ¥20 ING91680C BLE5.3 芯片怎么实现串口收发数据
  • ¥15 无线连接树莓派,无法执行update,如何解决?(相关搜索:软件下载)
  • ¥15 Windows11, backspace, enter, space键失灵