📄 bsc_decode.py
字号:
"""This file creates an LDPC code, generates a randombinary vector, puts it through a binary symmetric channel and tries todecode."""import pycodes, pycodes.pyLDPCfrom pycodes.utils import channels, encoders, CodeMaker######################################################################## You can set the following parameters as desired.#######################################################################col_w = 3row_w = 6N=1200numIter = 20noiseDensity = .058######################################################################## You probably should not need to change anything below this point.#######################################################################K=N*col_w/row_wE=(N-K)*row_wL=CodeMaker.make_H_gallager(N,col_w,row_w)code = pycodes.pyLDPC.LDPCCode(N,K,E,L)c = [0]*Nev = channels.BSCOutput(c,noiseDensity)code.setevidence(ev,alg='default')for i in range(numIter): code.decode()beliefs = code.getbeliefs()bitDiffs = reduce(lambda x,y: x+y,map(lambda z: z > 0.5,beliefs))print `bitDiffs` + ' bits wrong after ' + `numIter` + ' iterations.'ev = channels.BSCOutput(c,noiseDensity)code.setevidence(ev,alg='default')for i in range(numIter): code.decode()beliefs = code.getbeliefs()bitDiffs = reduce(lambda x,y: x+y,map(lambda z: z > 0.5,beliefs))print `bitDiffs` + ' bits wrong after ' + `numIter` + ' iterations.'
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -