clear all
x0=[0 0.5 1 1.5 2 2.5 3 7 8 9 10 11.82 13 14 15 16 17.73 19 20 21 22 23.64 26 27 28 29 29.55];
y0=[1.892e9 1.89e9 1.87e9 1.86e9 1.85e9 1.84e9 1.83e9 3e5 3e5 3.1e5 3e5 2.9e5 2.4e5 2.3e5 2e5 2.2e5 2e5 1.85e5 1.8e5 1.78e5 1.75e5 1.7e5 1.62e5 1.65e5 1.6e5 1.55e5 1.5e5];
p3=polyfit(x0,y0,18);
vpa(poly2sym(p3),5)
x=0:0.1:29.6;
y1=polyval(p3,x);
>> plot(x,y1,x0,y0,'o')
grid on
得到如下函数:
y=1.604*10^(-9)*x^18 - 4.4275*10^(-7)*x^17 + 0.000056159*x^16 - 0.0043377*x^15 + 0.22791*x^14 - 8.6173*x^13 + 241.87*x^12 - 5123.9*x^11 + 82462.0*x^10 - 1.0064*10^6*x^9 + 9.2252*10^6*x^8 - 6.2331*10^7*x^7 + 3.0125*10^8*x^6 - 9.9516*10^8*x^5 + 2.1031*10^9*x^4 - 2.5932*10^9*x^3 + 1.6075*10^9*x^2 - 3.7944*10^8*x + 1.8927*10^9
我再输入
clear all
x=0:0.1:30;
y=1.604e-9*x.^18 - 4.4275e-7*x.^17 + 0.000056159*x.^16 - 0.0043377*x.^15 + 0.22791*x.^14 - 8.6173*x.^13 + 241.87*x.^12 - 5123.9*x.^11 + 82462.0*x.^10 - 1.0064e6*x.^9 + 9.2252e6*x.^8 - 6.2331e7*x.^7 + 3.0125e8*x.^6 - 9.9516e8*x.^5 + 2.1031e9*x.^4 - 2.5932e9*x.^3 + 1.6075e9*x.^2 - 3.7944e8*x+ 1.8927e9;
plot(x,y)
为什么曲线会不一样,我仔细看过只有曲线前一部分会是相同的大概在x小于5.5内是相同的,之后就完全不一样了。。。。请教给位了。。。。。求帮帮忙,实在不明白为什么了。
主要是这个得到的曲线,一部分小于0,我是希望把常数项再变大一些,使得曲线完全在x轴上方。。。哪知道画出来的曲线完全不是那么回事。。。
可是我拟合完看到了它的曲线已经能较好的拟合了。。。。关键是再拿这个函数做图时 曲线完全不一样了。。。。
追答我也不知道了,觉得好像也是最后那个回答的人的问题样
额。。。不是逆过程啊?难道那个拟合得到的函数跟画出来的曲线不是对应的。。。。。不是吧。。那matlab给我那个函数有何用。。。
追答比如说拟合,只是有限的点用某种方法拟合,拟合出某条曲线;然后你用这个曲线上的若干个点,假设这些新取的点与原来的点不完全相同,拟合方法相同,拟合出的就一定是同一条曲线么?答案应该是否定的吧