使用matlab自带的卷积码编解码函数实现咬尾卷积码

本文提供了一个MATLAB演示程序,详细介绍了如何利用MATLAB内置的卷积码函数来实现咬尾卷积码的编码、打孔及解码过程。
摘要由CSDN通过智能技术生成

卷积码的原理这里就不说了,这里只是一个小的演示程序。主要解决的问题是如何使用matlab自带的卷积码编译码函数实现咬尾卷积码的编码,打孔以及译码。

%编码器输入48比特
signal = randi([0 1],1,48);
fprintf('信号长度%d\n',length(signal));
%1/2咬尾卷积码:先输入尾部的码6比特,再输入正常码48
c = [signal(end-(constLen-2):end), signal];
fprintf('补充尾部后信号长度%d\n',length(c));


%打孔器设计
%信号的长度必须是打孔向量长度的整数倍
%打孔长度本来为24*4 = 96比特,但是由于信号多输入了6比特,会多产生12比特,所以打孔向量的长度为96+12=108
%这12比特需要被被完全打掉
p = [1 1 ;1 0];
p =reshape(p,1,4);
for i = 1:23
    p = [p,1 1 1 0];
end
%前面补0是为了打孔时,将前面的尾部生成的比特打掉(尾部本来是应该放在初始状态中的)
p = [zeros(1,12),p];
fprintf('打孔器的长度为 %d\n',length(p))


% 卷积编码
C = convenc(c, convCode,p);
fprintf('卷积编码输出长度为 %d\n',length(C))


%解码部分
tbLen = length(C)/rateInv;
%为了能在译码时获得咬尾卷积码的初始状态,把接收到的码子拷贝两份译码,第一份译码完毕以后,编码器的状态就与咬尾卷积码的起始状态相同了
C = [C,C];
fprintf('双份比特的长度为%d\n',length(C))%144

%相应的,解
  • 5
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
咬尾卷积码(Tail-biting Convolutional Code)是一种卷积码的特殊形式,能够实现环形编码结构。在使用Matlab进行咬尾卷积码实现时,可以按照以下步骤进行操作。 首先,需要定义一个合适的生成多项式来构建咬尾卷积码编码器。生成多项式通常是使用约定多项式的形式表示,如g1(D) = 1 + D^2 + D^4和g2(D) = 1 + D + D^3 + D^4,这里D是延迟操作符。 接下来,使用convenc()函数来创建卷积码编码器。该函数可以使用生成多项式作为输入,并返回一个编码器对象。例如,编码器对象encoder = comm.ConvolutionalEncoder(g1,g2)可以创建一个具有g1和g2作为生成多项式的卷积码编码器。 然后,需要生成一系列的输入比特数据作为编码器的输入。这些输入比特可以是0和1的组合,表示待编码的信息。可以使用随机函数或手动输入数据。 接下来,使用编码器对象的step()函数,将输入比特数据输入到编码器中进行编码。例如,编码器的输出码字可以通过调用encoder_output = step(encoder, input_bits)来实现。 最后,可以通过PuncturePattern属性来设定编码器输出的截断模式。如果需要使用全部码字,可以设置PuncturePattern属性为'all'。也可以根据需要选择其他截断模式。 综上所述,通过以上步骤,可以使用Matlab实现咬尾卷积码编码。通过定义生成多项式、创建编码器对象、提供输入比特数据并获取编码器的输出码字,最终实现咬尾卷积码编码过程。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值