基于CCSDS标准的LDPC译码的GPU运行程序设计。c++开发

上传者: ccsss22 | 上传时间: 2022-04-15 18:02:14 | 文件大小: 10.62MB | 文件类型: RAR
基于 GPU 的 LDPC 码(Low-Density Parity-Check codes,低密度 奇偶校验码)软件译码器优化设计方法。选用了适用于 GPU 架构的基于最小和算 法的分层迭代译码方法开展译码器的设计工作。在并行译码方式上分别给出了码字间 和码字内并行处理方案,并基于 CUDA(Compute Unified Device Architecture)多线程 模型优化了码字映射规则。为提升译码内核执行效率,提出的优化方法包括:设计满 足负载平衡的合理资源分配、针对最小和算法中的并行规约数值求解以及译码层更新 的分支优化,实现对 GPU 硬件资源的高效利用;通过对 LDPC 码校验矩阵优化存储结 构以及多种译码信息量化方式合并存储策略的设计,提升译码过程中的数据访问效率。 其二,本文给出了基于 GPU 的卷积码软件译码器优化设计方法

文件下载

资源详情

[{"title":"( 73 个子文件 10.62MB ) 基于CCSDS标准的LDPC译码的GPU运行程序设计。c++开发","children":[{"title":"LDPC(CCSDS)_TDMP_MSA_GPU","children":[{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720","children":[{"title":"randn.h <span style='color:#111;'> 2.97KB </span>","children":null,"spread":false},{"title":"BER&FER.txt <span style='color:#111;'> 18.08KB </span>","children":null,"spread":false},{"title":"vc120.pdb <span style='color:#111;'> 1.12MB </span>","children":null,"spread":false},{"title":"CPU_func.cpp <span style='color:#111;'> 10.35KB </span>","children":null,"spread":false},{"title":"kernel.cu <span style='color:#111;'> 19.24KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.vcxproj <span style='color:#111;'> 9.13KB </span>","children":null,"spread":false},{"title":"coded.dat <span style='color:#111;'> 0B </span>","children":null,"spread":false},{"title":"source.dat <span style='color:#111;'> 0B </span>","children":null,"spread":false},{"title":"decoded.dat <span style='color:#111;'> 8.00KB </span>","children":null,"spread":false},{"title":"CPU_func.h <span style='color:#111;'> 183B </span>","children":null,"spread":false},{"title":"GPU_decode_code2.cuh <span style='color:#111;'> 12.82KB </span>","children":null,"spread":false},{"title":"GPU_decode_code1_16bit.cuh <span style='color:#111;'> 18.03KB </span>","children":null,"spread":false},{"title":"G_matrix_code2_4096_3072.txt <span style='color:#111;'> 24.00MB </span>","children":null,"spread":false},{"title":"x64","children":[{"title":"Release","children":[{"title":"kernel.cu.cache <span style='color:#111;'> 1.10KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.Build.CppClean.log <span style='color:#111;'> 2.62KB </span>","children":null,"spread":false},{"title":"kernel.cu.deps <span style='color:#111;'> 24.00KB </span>","children":null,"spread":false},{"title":"kernel.cu.obj <span style='color:#111;'> 593.79KB </span>","children":null,"spread":false},{"title":"LDPC(CCS.7017EABD.tlog","children":[{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.lastbuildstate <span style='color:#111;'> 315B </span>","children":null,"spread":false},{"title":"CL.write.1.tlog <span style='color:#111;'> 1.03KB </span>","children":null,"spread":false},{"title":"CL.read.1.tlog <span style='color:#111;'> 11.24KB </span>","children":null,"spread":false},{"title":"cl.command.1.tlog <span style='color:#111;'> 1.18KB </span>","children":null,"spread":false},{"title":"link.write.1.tlog <span style='color:#111;'> 1.38KB </span>","children":null,"spread":false},{"title":"link.command.1.tlog <span style='color:#111;'> 2.92KB </span>","children":null,"spread":false},{"title":"link.read.1.tlog <span style='color:#111;'> 4.63KB </span>","children":null,"spread":false}],"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.log <span style='color:#111;'> 50.26KB </span>","children":null,"spread":false}],"spread":false},{"title":"Debug","children":[{"title":"vc120.pdb <span style='color:#111;'> 92.00KB </span>","children":null,"spread":false},{"title":"kernel.cu.cache <span style='color:#111;'> 1.06KB </span>","children":null,"spread":false},{"title":"kernel.cu.deps <span style='color:#111;'> 23.46KB </span>","children":null,"spread":false},{"title":"vc120.idb <span style='color:#111;'> 195.00KB </span>","children":null,"spread":false},{"title":"kernel.cu.obj <span style='color:#111;'> 517.17KB </span>","children":null,"spread":false},{"title":"CPU_func.obj <span style='color:#111;'> 177.68KB </span>","children":null,"spread":false},{"title":"LDPC(CCS.7017EABD.tlog","children":[{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.lastbuildstate <span style='color:#111;'> 204B </span>","children":null,"spread":false},{"title":"CL.write.1.tlog <span style='color:#111;'> 1020B </span>","children":null,"spread":false},{"title":"CL.read.1.tlog <span style='color:#111;'> 10.97KB </span>","children":null,"spread":false},{"title":"cl.command.1.tlog <span style='color:#111;'> 1002B </span>","children":null,"spread":false},{"title":"link.write.1.tlog <span style='color:#111;'> 1.23KB </span>","children":null,"spread":false},{"title":"link.command.1.tlog <span style='color:#111;'> 2.41KB </span>","children":null,"spread":false},{"title":"link.read.1.tlog <span style='color:#111;'> 3.48KB </span>","children":null,"spread":false}],"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.log <span style='color:#111;'> 23.55KB </span>","children":null,"spread":false}],"spread":false}],"spread":false},{"title":"GPU_decode_code1.cuh <span style='color:#111;'> 15.93KB </span>","children":null,"spread":false},{"title":"GPU_decode_code2_16bit.cuh <span style='color:#111;'> 24.60KB </span>","children":null,"spread":false},{"title":"totalDefine.h <span style='color:#111;'> 2.62KB </span>","children":null,"spread":false},{"title":"G_matrix_code1_4096_6144.txt <span style='color:#111;'> 48.00MB </span>","children":null,"spread":false},{"title":"cuda_helper.cuh <span style='color:#111;'> 6.91KB </span>","children":null,"spread":false},{"title":"Debug","children":[{"title":"vc120.pdb <span style='color:#111;'> 116.00KB </span>","children":null,"spread":false},{"title":"kernel.cu.cache <span style='color:#111;'> 1.05KB </span>","children":null,"spread":false},{"title":"kernel.cu.deps <span style='color:#111;'> 23.46KB </span>","children":null,"spread":false},{"title":"vc120.idb <span style='color:#111;'> 203.00KB </span>","children":null,"spread":false},{"title":"kernel.cu.obj <span style='color:#111;'> 487.38KB </span>","children":null,"spread":false},{"title":"CPU_func.obj <span style='color:#111;'> 174.35KB </span>","children":null,"spread":false},{"title":"LDPC(CCS.7017EABD.tlog","children":[{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.lastbuildstate <span style='color:#111;'> 206B </span>","children":null,"spread":false},{"title":"CL.write.1.tlog <span style='color:#111;'> 996B </span>","children":null,"spread":false},{"title":"CL.read.1.tlog <span style='color:#111;'> 11.09KB </span>","children":null,"spread":false},{"title":"cl.command.1.tlog <span style='color:#111;'> 998B </span>","children":null,"spread":false},{"title":"link.write.1.tlog <span style='color:#111;'> 1.19KB </span>","children":null,"spread":false},{"title":"link.command.1.tlog <span style='color:#111;'> 2.36KB </span>","children":null,"spread":false},{"title":"link.read.1.tlog <span style='color:#111;'> 3.42KB </span>","children":null,"spread":false}],"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.log <span style='color:#111;'> 23.23KB </span>","children":null,"spread":false}],"spread":false}],"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.v12.suo <span style='color:#111;'> 124.00KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.sdf <span style='color:#111;'> 9.56MB </span>","children":null,"spread":false},{"title":"x64","children":[{"title":"Release","children":[{"title":"cudart64_65.dll <span style='color:#111;'> 298.00KB </span>","children":null,"spread":false},{"title":"cudart32_65.dll <span style='color:#111;'> 242.00KB </span>","children":null,"spread":false}],"spread":true},{"title":"Debug","children":[{"title":"cudart64_65.dll <span style='color:#111;'> 298.00KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.ilk <span style='color:#111;'> 579.60KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.pdb <span style='color:#111;'> 787.00KB </span>","children":null,"spread":false},{"title":"cudart32_65.dll <span style='color:#111;'> 242.00KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.exe <span style='color:#111;'> 709.00KB </span>","children":null,"spread":false}],"spread":true}],"spread":true},{"title":"Debug","children":[{"title":"cudart64_65.dll <span style='color:#111;'> 298.00KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.ilk <span style='color:#111;'> 550.46KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.pdb <span style='color:#111;'> 827.00KB </span>","children":null,"spread":false},{"title":"cudart32_65.dll <span style='color:#111;'> 242.00KB </span>","children":null,"spread":false},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.exe <span style='color:#111;'> 727.00KB </span>","children":null,"spread":false}],"spread":true},{"title":"LDPC(CCSDS)_TDMP_MSA_GPU_20150720.sln <span style='color:#111;'> 1.36KB </span>","children":null,"spread":false}],"spread":true}],"spread":true}]

评论信息

免责申明

【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明