⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 bsc_decode.py

📁 著名的ldpc编解码的资料及源代码
💻 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 + -