contributed by <
jouae
>
拜讀 Shannon 1948 的論文,筆記一下內容。部分證明摘錄自《熵 (Entropy)》李天岩教授著,刊於數學傳播十三卷三期。
The significant aspect is that the actual message is one selected from a set of possible messages. The system must be designed to operate for each possible selection, not just the one which will actually be chosen since this is unknown at the time of design.
使用 的好處:
通訊系統簡易的分成三類
離散型通訊系統有兩個例子,其一為電傳打字機(TTY),其二為博多式電報機。
一般而言,離散型通訊系統為一從有限符號集 選取排列的序列,該序列從一點傳遞至另一點。每個符號 對應至一持續時間 。
在電報(telegraphy)中假設有以下符號:
▄
點(dot)需要 個時間單位。▄▄▄
劃(dash)需要 個時間單位。
字母間隔(letter space)需要 個時間單位。
字間隔 (word space)需要 個時間單位。以博多式電報為例,藉由五個按鍵,總共有 種組合的按法,可以輸出 個符號。依照國際電報二號字母表(International Telegraph Alphabet No 2, ITA2)定義,博多式電報使用兩個字符集,每個字符集含有 個符號(symbols),其中一個字符集含有 個字母,其餘 個符號為控制字符(control characters) 包括 Carriage-return
、Line-feed
、Letter-shift
、Figure-shift
、Space
,及最後一個符號可以為 All-space
或 null
。
由於博多式電報發出的每個符號都是由 個按鍵組合出來的,所以每個符號有 位元的資訊。假設該離散型通訊系統每秒發出 個符號,則代表該通訊系統的最大上限通道容量(capacity)為 。
假設所有由符號 組成的序列都被允許傳送,且時長 各別對應同一下標符號的符號。例如,傳送一個符號 需要對應 長的單位時間。更具一體一點的例子,電報發送符號 ▄
點(dot)需要 個時間單位,發送 ▄▄▄
劃(dash)需要 個時間單位,發送由點和劃符號組成的序列 ▄ ▄ ▄ ▄▄▄ ▄▄▄ ▄▄▄ ▄ ▄ ▄
總共需要 個時間單位,該序列在摩斯密碼中代表的是 SOS
。
如果 表示持續時間為 的序列數量
該時間 內可允許訊號數量的總數等於以 符號結尾序列的序列數量之和,其中這些序列數量分別為 。
解釋一下為何要設計成遞迴式的形式計算總數。假設傳送符號的總時長為 單位時間,對於任意的兩個以上符號構成的序列且序列不超過總時長 單位時間,我們都可以拆成兩個子序列,其一為最後一個符號 的第一子序列,該第一子序列花費 單位時間;其二為原序列扣除最後一個符號的第二子序列,此第二子序列花費時長在 單位時間內,而這樣的第二子序列數量會有 個。再對該第二子序列,以第一序列中的符號為 ,其中 ,進行一樣的拆解動作,值至第一子序列與第二子序列皆只剩餘一個符號。整個計算序列數量的方式就是拆解成子序列在計算,過程就跟遞迴式一致。
回到遞迴式 ,我們要分析該遞迴式如何計算通道容量。假設 有解 則帶入該式子得到:
等式兩側同除 則得到一特徵方程式:
特徵方程的解有可能會有複數(complex number)但在此我們關心的實數特徵根行為,假設其實數特徵根可以表示為 對 且依照遞增排序 則其通解表示為:
當由於 為最大的實數特徵根,當 不斷增長時, 會以相對較快的速度大於其他特徵根。故當 大時,可以將 以近似的方式表示為:
舉個例子,假設有一線性遞迴關係:
其特徵方程可藉由假設其特徵解形式為 後得到
等式兩側同乘 則等價於
藉由公式解可以得到兩根
則原線性遞迴式可以表示為
以 表示最大實數特徵根近似
以下表格為近似值與實際解在不同 時的數值, 為兩者差的絕對值
1 | 1 | 1.62 | 0.62 |
2 | 3 | 2.62 | 0.38 |
3 | 4 | 4.24 | 0.24 |
4 | 7 | 6.85 | 0.15 |
5 | 11 | 11.09 | 0.09 |
可以觀察到在該例子中,隨著 越大近似值逐漸近似實際解,也就是說最大的實數特徵根在 大時,可以代表整個線性遞迴式的行為。
隨後將線性遞迴式 帶入通道容量的差分形式後,可得
假設 可以最大實數特徵根表示整個系統的行為,則此處我們將 以最大實數特徵根 替換,則
所以通道容量為 ,換言之通道的容量只要知道可允許訊號數量的最大實數特徵根即可。