非累贅取樣編碼

非累贅取樣編碼法

以下將探討兩類非累贅取樣編碼法:多項式預測器及多項式內插法

多項式預測器所採取的方法是:測試下一個取樣看看他是不是落在一個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年代被提出以來即受到很大的注意,也有很多成功的應用。基本上他和一次預測器類似。不同的是他的 值根據取樣的情況而改變。


演算法:扇形演算法

第一步:  
設定第一個取樣 為非累贅取樣: 第二步: 為心向  展開一扇形;
第三步:如果  ;讀入下一取樣 
第三步: 落在扇形內,則,則
 
回到第二步;
否則;
設定 為非累贅取樣;   
回到第二步;
第四步:重複以上的步驟直到編碼完所有取樣點;
第五步:送出每個非累贅取樣及其發生時間;
第六步:接收端收到非累贅取樣後以線段將相鄰之非累贅取樣連起來即可。