士郎小天使 2021-10-26 02:07 采纳率: 81.1%
浏览 327
已结题

MATLAB如何实现带等式和不等式约束条件的最小二乘法拟合多元多项式

多元多项式的公式如图,现在有n个数据(x,y,f(x,y))来拟合这个多项式,用最小二乘法,具体程序如下面的代码

img

Z=xlsread('Linton.xlsx');
x=Z(:,1);%x的数据,为风速,范围是0到40
y=Z(:,2);%y的数据,为风向,范围是0到360
z=Z(:,3);%频率数据
n = 7; % n为多项式的阶数,参数一共为(n+1)²个
p = length(x); q = length(y);
[X,Y,i1,i2] = ndgrid(x,y,0:n,0:n);
F = X.^i1.*Y.^i2;
F = reshape(F, p*q, (n+1)^2); %这一段是最小二乘法的左边矩阵,F矩阵具体形式如下图
A = F'*F;
b = F'*z;
a = A\b;%最小二乘法

img

然后现在就是得加入2个约束条件,一个是x在0到40,y在0到360,f(x,y)的积分等于1,然后f(x,y)永远大于0这两个约束条件。积分为1这个约束可以用拉格朗日乘子法来写。如果是下图的普通多项式,可以加下面一段代码解决积分为1

img

G = 1./(n+1:-1:1).*40.^(n+1:-1:1);% 这段是上图的普通多项式积分为1,直接写出了积分形式然后用拉格朗日乘子法
%现在需要对最上面的多元多项式积分为1,需要改成x在040,y在0360的二重积分为1
aa = [A, F'; F, 0]\[b;1];%拉格朗日乘子法

现在是得把G矩阵写成二重积分,想问下这种多元多项式进行二重积分的代码应该怎么写。再就是f(x,y)永远大于0的约束要如何加上,以前只写过一维数据,然后普通多项式MATLAB也有代码,这个多元多项式得自己编写

  • 写回答

2条回答 默认 最新

      报告相同问题?

      相关推荐 更多相似问题

      问题事件

      • 系统已结题 11月4日
      • 已采纳回答 10月27日
      • 请采纳用户回复 10月26日
      • 创建了问题 10月26日

      悬赏问题

      • ¥15 苹果手机删除了qq软件,qq文件怎么恢复
      • ¥20 用mips 人力编程排序问题(能在mars按要求运行)
      • ¥15 Verilog小型神经网络(单层反馈神经网络)
      • ¥15 设计一个数字钟,实现时分秒的显示
      • ¥15 Clion使用头文件链接两个cpp
      • ¥15 51单片机无法触发外部中断问题
      • ¥15 基于半监督,无监督的调制识别
      • ¥15 cst求 阵列 rcs 时候 频域 时域求解器 应该怎样设置 才让两者 计算结果 相似 请附图
      • ¥15 关于#51单片机#的问题:大家帮我看一下为什么我的计时器数字一直不稳定
      • ¥15 Qt 在应用程序里总是有[PREVIEW] recv window msg, name:(Qt5QWindowIcon) hwd:(287097a)等信息不断输出,怎么解决