功能MKPP将转变多项式使x = 0
将在你给它相应的范围的起点开始。在你的第一个例子中,多项式x^3
转移到范围[1 2]
,所以如果你想在不移位范围[0 1]
评价多项式,你就必须做到以下几点:
>> pp = mkpp(1:2,[1 0 0 0]); %# Your polynomial
>> ppval(pp,1.5+pp.breaks(1)) %# Shift evaluation point by the range start
ans =
3.3750 %# The answer you expect
在你的第二个例如,您有一个多项式x^3
已移至范围[1 1.5]
,另一个多项式x^3
已移至范围[1.5 2]
。在x = 1.5
处评估分段多项式给出的值为零,发生在第二个多项式的开始处。
它可以帮助您可视化都使得多项式如下:
x = linspace(0,3,100); %# A vector of x values
pp1 = mkpp([1 2],[1 0 0 0]); %# Your first piecewise polynomial
pp2 = mkpp([1 1.5 2],[1 0 0 0; 1 0 0 0]); %# Your second piecewise polynomial
subplot(1,2,1); %# Make a subplot
plot(x,ppval(pp1,x)); %# Evaluate and plot pp1 at all x
title('First Example'); %# Add a title
subplot(1,2,2); %# Make another subplot
plot(x,ppval(pp2,x)); %# Evaluate and plot pp2 at all x
axis([0 3 -1 8]) %# Adjust the axes ranges
title('Second Example'); %# Add a title
我在这个一直盯着这么久了...谢谢!如果我想在某些向量点评估它,我该怎么做?有比ppval更好的功能吗? – Xodarap 2010-11-16 16:53:54
@ Xodarap:您可以将点的向量传递给[PPVAL](http://www.mathworks.com/help/techdoc/ref/ppval.html),如上面的示例代码示例所示。 – gnovice 2010-11-16 17:01:26