Полиномиальное аппроксимирование кривыми

В этом примере показано, как соответствовать полиномиальной кривой к набору точек данных с помощью polyfit функция. Можно использовать polyfit найти коэффициенты полинома, который приспосабливает набор данных в смысле наименьших квадратов с помощью синтаксиса

p = polyfit(x,y,n),

где:

  • x и y векторы, содержащие x и y координаты точек данных

  • n степень полинома, чтобы соответствовать

Создайте некоторые x-y тестовые данные для пяти точек данных.

x = [1 2 3 4 5]; 
y = [5.5 43.1 128 290.7 498.4];

Используйте polyfit найти полином третьей степени, который приблизительно соответствует данным.

p = polyfit(x,y,3)
p = 1×4

   -0.1917   31.5821  -60.3262   35.3400

После того, как вы получаете полином для подходящей линии с помощью polyfit, можно использовать polyval оценивать полином в других точках, которые не могут быть включены в исходные данные.

Вычислите значения polyfit оцените по более прекрасной области и постройте оценку по действительным значениям данных для сравнения. Включайте аннотацию уравнения для подходящей линии.

x2 = 1:.1:5;
y2 = polyval(p,x2);
plot(x,y,'o',x2,y2)
grid on
s = sprintf('y = (%.1f) x^3 + (%.1f) x^2 + (%.1f) x + (%.1f)',p(1),p(2),p(3),p(4));
text(2,400,s)

Figure contains an axes object. The axes object contains 3 objects of type line, text.

Смотрите также

|

Похожие темы