MATLAB插值

weixin_33766168發表於2017-11-21

轉自原文 MATLAB插值

插值問題

在應用領域中,由有限個已知資料點,構造一個解析表示式,由此計算資料點之間的函式值,稱之為插值。

例項:海底探測問題

某公司用聲納對海底進行測試,在5×5海里的座標點上測得海底深度的值,希望通過這些有限的資料瞭解更多處的海底情況。並繪出較細緻的海底曲面圖。

一、一元插值

一元插值是對一後設資料點(xi,yi)進行插值。

1.  線性插值:由已知資料點連成一條折線,認為相臨兩個資料點之間的函式值就在這兩點之間的連線上。一般來說,資料點數越多,線性插值就越精確。

呼叫格式:yi=interp1(x,y,xi,’linear’)  %線性插值

zi=interp1(x,y,xi,’spline’)  %三次樣條插值

wi=interp1(x,y,xi,’cubic’)  %三次多項式插值

說明:yi、zi、wi為對應xi的不同型別的插值。x、y為已知資料點。

例1已知資料:

x

0

.1

.2

.3

.4

.5

.6

.7

.8

.9

1

y

.3

.5

1

1.4

1.6

1.9

.6

.4

.8

1.5

2

求當xi=0.25時的yi的值。

程式:

x=0:.1:1;

y=[.3 .5 1 1.4 1.6 1 .6 .4 .8 1.5 2];

yi0=interp1(x,y,0.025,'linear')

xi=0:.02:1;

yi=interp1(x,y,xi,'linear');

zi=interp1(x,y,xi,'spline');

wi=interp1(x,y,xi,'cubic');

plot(x,y,'o',xi,yi,'r+',xi,zi,'g*',xi,wi,'k.-')

legend('原始點','線性點','三次樣條','三次多項式')

結果:yi0 =  0.3500

MATLAB插值與擬合 - 飛揚 Youth - 澆灌一處綠色的風景

 

要得到給定的幾個點的對應函式值,可用:

xi =[ 0.2500  0.3500  0.4500]

yi=interp1(x,y,xi,'spline')

結果:

yi =1.2088  1.5802  1.3454

(二) 二元插值

二元插值與一元插值的基本思想一致,對原始資料點(x,y,z)構造見世面函式求出插值點資料(xi,yi,zi)。

一、單調節點插值函式,即x,y向量是單調的。

呼叫格式1:zi=interp2(x,y,z,xi,yi,’linear’)

‘liner’ 是雙線性插值 (預設)

呼叫格式2:zi=interp2(x,y,z,xi,yi,’nearest’)

’nearest’ 是最近鄰域插值

呼叫格式3:zi=interp2(x,y,z,xi,yi,’spline’)

‘spline’是三次樣條插值

說明:這裡x和y是兩個獨立的向量,它們必須是單調的。z是矩陣,是由x和y確定的點上的值。z和x,y之間的關係是z(i,:)=f(x,y(i)) z(:,j)=f(x(j),y) 即:當x變化時,z的第i行與y的第i個元素相關,當y變化時z的第j列與x的第j個元素相關。如果沒有對x,y賦值,則預設x=1:n, y=1:m。n和m分別是矩陣z的行數和列數。

例2已知某處山區地形選點測量座標資料為:

x=0  0.5  1  1.5  2  2.5  3  3.5  4  4.5  5

y=0  0.5  1  1.5  2  2.5  3  3.5  4  4.5  5  5.5  6

海拔高度資料為:

z=89 90 87 85 92 91 96 93 90 87 82

   92 96 98 99 95 91 89 86 84 82 84

   96 98 95 92 90 88 85 84 83 81 85

   80 81 82 89 95 96 93 92 89 86 86

   82 85 87 98 99 96 97 88 85 82 83

   82 85 89 94 95 93 92 91 86 84 88

   88 92 93 94 95 89 87 86 83 81 92

   92 96 97 98 96 93 95 84 82 81 84

   85 85 81 82 80 80 81 85 90 93 95

   84 86 81 98 99 98 97 96 95 84 87

   80 81 85 82 83 84 87 90 95 86 88

   80 82 81 84 85 86 83 82 81 80 82

   87 88 89 98 99 97 96 98 94 92 87

其地貌圖為:

MATLAB插值與擬合 - 飛揚 Youth - 澆灌一處綠色的風景

對資料插值加密形成地貌圖。

程式:

x=0:.5:5;

y=0:.5:6;

z=[89 90 87 85 92 91 96 93 90 87 82

   92 96 98 99 95 91 89 86 84 82 84

   96 98 95 92 90 88 85 84 83 81 85

   80 81 82 89 95 96 93 92 89 86 86

   82 85 87 98 99 96 97 88 85 82 83

   82 85 89 94 95 93 92 91 86 84 88

   88 92 93 94 95 89 87 86 83 81 92

   92 96 97 98 96 93 95 84 82 81 84

   85 85 81 82 80 80 81 85 90 93 95

   84 86 81 98 99 98 97 96 95 84 87

   80 81 85 82 83 84 87 90 95 86 88

   80 82 81 84 85 86 83 82 81 80 82

   87 88 89 98 99 97 96 98 94 92 87];

mesh(x,y,z)  %繪原始資料圖

xi=linspace(0,5,50);  %加密橫座標資料到50個

yi=linspace(0,6,80);  %加密縱座標資料到60個

[xii,yii]=meshgrid(xi,yi);  %生成網格資料

zii=interp2(x,y,z,xii,yii,'cubic');  %插值

mesh(xii,yii,zii)  %加密後的地貌圖

hold on     % 保持圖形

[xx,yy]=meshgrid(x,y);  %生成網格資料

plot3(xx,yy,z+0.1,'ob')  %原始資料用‘O’繪出

MATLAB插值與擬合 - 飛揚 Youth - 澆灌一處綠色的風景

 

2、二元非等距插值

呼叫格式:zi=griddata(x,y,z,xi,yi,’指定插值方法’)

插值方法有: linear          % 線性插值   (預設)

            bilinear     % 雙線性插值

            cubic        % 三次插值

            bicubic      % 雙三次插值

            nearest      % 最近鄰域插值

例:用隨機資料生成地貌圖再進行插值

程式:

x=rand(100,1)*4-2;

y=rand(100,1)*4-2;

z=x.*exp(-x.^2-y.^2);

ti=-2:.25:2;

[xi,yi]=meshgrid(ti,ti); % 加密資料

zi=griddata(x,y,z,xi,yi);% 線性插值

mesh(xi,yi,zi)

hold on

plot3(x,y,z,'o' 

 

沒有整理與歸納的知識,一文不值!高度概括與梳理的知識,才是自己真正的知識與技能。 永遠不要讓自己的自由、好奇、充滿創造力的想法被現實的框架所束縛,讓創造力自由成長吧! 多花時間,關心他(她)人,正如別人所關心你的。理想的騰飛與實現,沒有別人的支援與幫助,是萬萬不能的。






    本文轉自wenglabs部落格園部落格,原文連結:http://www.cnblogs.com/arxive/p/7063516.html,如需轉載請自行聯絡原作者



相關文章