USB音頻設備類的音頻信號同步解決方案
之前采用簡單的緩存門限控制方法判斷是否需要插值,即當緩存高于某門限時,丟棄一個PCM樣點。而當低于某一門限時,插入一個PCM樣點,由于時鐘速度差異的長期固有性,在插入/丟棄一個PCM樣點后,緩存數量仍然可能繼續減少或增加,從而造成程序無規律的爆發式的插入或丟棄數據操作,產生不可接受的噪音。
因而在算法設計時,重點考慮以下幾點。
操作的穩定性:不能有對數據突發性的操作。
操作的分散性:要盡量平均的控制信號,把插入/丟棄產生的失真平均化。
資源消耗量小:要適應嵌入式系統成本低廉、片上存儲、運算資源不是很富裕的客觀條件。
音頻的實時性:聲音對實時性要求較高,不能出現停頓、明顯延遲等情況。
因此,采用一種插入/丟棄樣本間隔平均化的自適應模糊控制算法進行設計。
針對兩次插值/丟棄操作之間的樣點數進行控制,而非對樣點本身,在每次插值/丟棄操作后進行速率匹配判斷,修改插值/丟棄間隔。由于通常這種時鐘差異在千分之一量級,插入/丟棄操作間隔也在千樣點量級,大大減少了頻繁的判斷操作。算法結構如圖3所示。

5 算法實現
由于每臺電腦以及每塊開發板的時鐘都有誤差,所以每次連接設備都需要檢查兩者時鐘速率關系,實現該功能的關鍵代碼如下:


評論