非累贅取樣編碼
非累贅取樣編碼法
以下將探討兩類非累贅取樣編碼法:多項式預測器及多項式內插法
多項式預測器所採取的方法是:測試下一個取樣看看他是不是落在一個n次多項市所展開的範圍內。最常被使用的是0次及1次多項式。著名的串長編碼(run-length coding)則是0次多項式的一個特別版本。
多項式內插法與多項式預測器類似,唯一的不同是他允許的機動的改變其所展開的範圍。一次多項式內插法,又名善行演算法,是用許多線段來取代原波形。
多項式預測器
非累贅取樣壓縮法中多項是預測器算是相當早期的發明。早在60年代早期便有許多論文在討論他並且實際應用在許多實驗上,其中在常被使用到的是0階預測器及1階預測器。
在多項式預測器裏,下一個取樣被預測是在一個n次多項式的範圍內。數學上我們可以表示如下,其中 表示所預測的下一個取樣值, 為 之前的第 個取樣
式
其中
以此類推,並且
我們可以看出,不同階次的多項式會產生不同的預測值。如果下一個取樣值落在n次多項式之預測值得附近,那麼他將會被認為是多餘的、累贅的而不會被送出,否則他會被認為是非累贅取樣而將其送出。
以下我們將更詳細的介紹多項是預測器中最常見的兩種:0次預測器及1次預測器。
0次預測器
0次預測器的式子為:
換句話說,我們預測下一個取樣值是和前一個取樣值一樣。在實際的設計上,我們得在這個預測值的上下個加上一個誤差容忍範圍,亦即 這個預測值並不是單一個 值,而是介於 到 的一個範圍,其中 的值由設計人自行根據能容許的誤差程度及所需要的壓縮比來設定。只要 是落在 這個範圍之內, 便會被當成是累贅取樣。
以下為0次預測器之演算法:
演算法:0次預測器
第一步:儲存便傳送第一個取樣 : ← ;
第二步:讀入下一個取樣,
第三步:如果 則 ← ;回到第二步;否則儲存並傳送 ; ← ;回到第二步;
1次預測器
一次預測器的式子為:
其中 。請注意, 可以解釋為 與 所構成之線段的斜率(相鄰兩個取樣之間隔為1,因使分母可以省略)。一次預測器因此可以解釋為"假設斜率固定"。
實際上的演算法也必須加上一個誤差容忍範圍 。
演算法:1次預測器
第一步:儲存便傳送第一個取樣 : ;
第二步:儲存並傳送第二個取樣, ;
第三步:如果 ; ;讀入下一取樣 ;
第三步:若 ,則
;
讀入下一個取樣 並回到第四步;
否則
儲存並傳送 及其發生時間;
儲存並傳送 ;
回到第三步;
多項式內插法
我們也討論0次與1次的內插法。0次內插法與0次預測器除了前者的 可以改變外,其餘完全一樣。機動性調整 值可以讓累贅取樣更多。
一次內插法又稱為扇形演算法(fan algorithm),從60年代被提出以來即受到很大的注意,也有很多成功的應用。基本上他和一次預測器類似。不同的是他的 值根據取樣的情況而改變。
演算法:扇形演算法
第一步: ; ;
設定第一個取樣 為非累贅取樣:
第二步:以 為心向 及 展開一扇形;
第三步:如果 ; ;讀入下一取樣 ;
第三步:若 落在扇形內,則,則
;
回到第二步;
否則;
設定 為非累贅取樣;
; ;
回到第二步;
第四步:重複以上的步驟直到編碼完所有取樣點;
第五步:送出每個非累贅取樣及其發生時間;
第六步:接收端收到非累贅取樣後以線段將相鄰之非累贅取樣連起來即可。