中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么利用Matlab實現迭代適應點算法

發布時間:2022-04-07 11:06:05 來源:億速云 閱讀:325 作者:iii 欄目:開發技術

本篇內容主要講解“怎么利用Matlab實現迭代適應點算法”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“怎么利用Matlab實現迭代適應點算法”吧!

道格拉斯-普克算法(Douglas–Peucker algorithm,亦稱為拉默-道格拉斯-普克算法、迭代適應點算法、分裂與合并算法)是將曲線近似表示為一系列點,并減少點的數量的一種算法。它的優點是具有平移和旋轉不變性,給定曲線與閾值后,抽樣結果一定。

1.算法描述

1.在曲線首尾兩點間虛連一條直線,求出其余各點到該直線的距離。

2.選其最大者與閾值相比較,若大于閾值,則離該直線距離最大的點保留,否則將直線兩端點間各點全部舍去。

3.依據所保留的點,將已知曲線分成兩部分處理,重復第1、2步操作,迭代操作,即仍選距離最大者與閾值比較,依次取舍,直到無點可舍去,最后得到滿足給定精度限差的曲線點坐標。 

怎么利用Matlab實現迭代適應點算法

怎么利用Matlab實現迭代適應點算法

Long Time Later

怎么利用Matlab實現迭代適應點算法

2.工具函數

為了代碼簡單易理解,這里使用了二分迭代,含詳細注釋代碼如下(代碼片可左右滑動)。

function nPntSet=dp(pntSet,TH)
% @author : slandarer
% pntSet  : 二維數據點
% TH      : 距離閾值

% 向量運算:計算所有點到首位兩點連線距離
vertV=[pntSet(end,2)-pntSet(1,2),-pntSet(end,1)+pntSet(1,1)];
baseL=abs(sum((pntSet-pntSet(1,:)).*vertV./norm(vertV),2));
if max(baseL)<TH 
    % 若距離小于閾值則返回首尾點
    nPntSet=[pntSet(1,:);pntSet(end,:)]; 
else
    % 若距離大于閾值則左右兩分支分別計算后拼接
    maxPos=find(baseL==max(baseL));maxPos=maxPos(1);
    L_PntSet=pntSet(1:maxPos,:);nL_PntSet=dp(L_PntSet,TH);
    R_PntSet=pntSet(maxPos:end,:);nR_PntSet=dp(R_PntSet,TH);
    nPntSet=[nL_PntSet;nR_PntSet(2:end,:)];
end
end

3.函數調用

給個demo:

% 構造一組數據
X=linspace(0,25,10)';
Y=randi([0,10],[10,1]);
pntSet=[X,Y];

% 閾值為2的dp算法
nPntSet=dp(pntSet,2);

% 坐標區域修飾
hold on
grid on
ax=gca;
ax.YLim=[0,10];
ax.DataAspectRatio=[1,1,1];
ax.Color=[1,1,1];
ax.XColor=[1,1,1].*.3;
ax.YColor=[1,1,1].*.3;
ax.LineWidth=1.5;
ax.FontName='cambria';
ax.GridLineStyle='--';

% 繪制原始數據曲線
plot(pntSet(:,1),pntSet(:,2),'Color',[0 0.4470 0.7410],'LineWidth',2,'Marker','*');
% 繪制新數據曲線
plot(nPntSet(:,1),nPntSet(:,2),'Color',[0.6350 0.0780 0.1840 .7],'LineWidth',2,'Marker','s');

legend('original-curve','feature-curve')

怎么利用Matlab實現迭代適應點算法

怎么利用Matlab實現迭代適應點算法

4.優勢與不足

對比與垂距法(Matlab利用垂距法實現提取離散坐標數據特征點),道格拉斯-普克算法(dp)不會出現下面這種情況,即雖然每次變化都不大,但是連著好幾次相同方向變化導致某些特征不會被提取出來:

怎么利用Matlab實現迭代適應點算法

但比較讓人頭疼的是,閾值需要自己選取,以下是不同閾值時對比圖像:

怎么利用Matlab實現迭代適應點算法

到此,相信大家對“怎么利用Matlab實現迭代適應點算法”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

五大连池市| 中西区| 庆安县| 临清市| 永康市| 永靖县| 彭泽县| 沙湾县| 灌南县| 肃南| 云浮市| 大名县| 丹江口市| 岳池县| 金堂县| 佛教| 应用必备| 阿拉善右旗| 乌兰浩特市| 昭通市| 班戈县| 崇仁县| 醴陵市| 通城县| 泰顺县| 南和县| 靖远县| 青海省| 甘泉县| 忻城县| 宁安市| 富平县| 逊克县| 五华县| 交口县| 凭祥市| 青阳县| 共和县| 灯塔市| 临武县| 岑巩县|