## 實驗結果圖:

(波形圖及模擬完成截圖)



## 程式運作流程:

(簡單說明波形變化的意義)





- 1. 當 clock 由正轉負,檢查 reset,若為正 reg 們重設;若為負往下執行
- 2. total\_num 累加 1, 且輸入 X 傳給 X9, Xn 依序傳給 Xn-1, 並將 X2-9 與 X 加總為 avg\_dividend 做為子 module calc 的輸入,計算 average
- 3. 當 avg\_dividend 或 average 發生變化時,計算距離 average 最近的 Xn 值 (approximate),將其\*9 加上 avg\_dividend,輸入 calc module 算出 Y\_keep\_w
- 4. 當 clock 由負轉正且判斷 total\_num >= 9 的時候,由 Y\_keep\_w 給到輸出 Y
- 5. 當 calc module 取得除數及被除數,開始執行

6. 進行 10 個迴圈計算(輸入最大可能為 10 位數),被除數每回合向左 lbit,與除數比較大小,若大於或等於除數,兩者相減,並加上 lbit, 作為新的被除數;若小於除數,保留原被除數。若 i = 10,結束迴圈, 並輸出商數