单极性非归零码

单极性非归零码使用电平1来表示二元信息中的“1”,用电平0来表示二元信息中的“0”,电平在整个码元的时间里不变单极性非归零码的优点是实现简单,但由于含有直流分量,对在带限信道中的传输不利,另外当出现连续的0或连续的1时。电平长时间保持一个值,不利于提取时间信息以便获得同步。

function y = snrz(x)

%本函数实现将输入的一段二进制代码编为相应的单极性非归零码输出

%输入x为二进制码,输出y为编出的单极性非归零码

t0 = 300;

t = 0:1/t0:length(x);

for i = 1:length(x)     %计算码元的值

if(x(i) == 1)       %如果信息为1

for j = 1:t0    %改码元对应的点值为1

y((i-1)*t0+j) = 1;

end

else

for j = 1:t0    %反之,信息为0,码元对应点值取0

y((i-1)*t0+j) = 0;

end

end

end

y = [y,x(i)];

M = max(y);

m = min(y);

subplot(2,1,1);

plot(t,y);grid;

axis([0,i,m-0.1,M+0.1]);

%使用title命令标记各码元对应的二元信息
title('1 0 0 1 1 0 0 0 0 1 0 1');
ylabel('单极性非归零码');

单极性归零码

单极性归零码输入信息为1时,给出的码元前半时间为1,后半时间为0,输入0则完全相同。单极性归零码部分解决了传输问题,直流分量减小,但遇到连续长0时同样无法给出定时信息。

function y = srz(x)

%本函数实现将输入的一段二进制代码编为相应的单极性归零码输出

%输入x为二进制码,输出y为编出的单极性归零码

t0 = 300;

t = 0:1/t0:length(x);   %给出相应的时间序列

for i = 1:length(x)     %进行码型变换

if(x(i) == 1)       %若输入信息为1

for j = 1:t0/2

y(t0/2*(2*i-2)+j) = 1;  %定义前半时间值为1

y(t0/2*(2*i-1)+j) = 0;  %定义后半时间值为0

end

else

for j = 1:t0/2          %反之,输入信息为0

y(t0*(i-1)+j) = 0;   %定义所有时间值为0

end

end

end

y = [y,x(i)];

M = max(y);

m = min(y);

subplot(2,1,1);

plot(t,y);grid;

axis([0,i,m-0.1,M+0.1]);

%使用title命令标记各码元对应的二元信息
title('1 0 0 1 1 0 0 0 0 1 0 1');
ylabel('单极性归零码');

双极性非归零码

%双极性非归零码与单极性非归零码类似,区别仅在于双极性使用电平-1来表示信息0

function y = dnrz(x)

%本函数实现将输入的一段二进制代码编为相应的双极性非归零码输出

%输入x为二进制码,输出y为编出的双极性非归零码

t0 = 300;

t = 0:1/t0:length(x);

for i = 1:length(x)

if(x(i) == 1)

for j = 1:t0

y((i-1)*t0+j) = 1;

end

else

for j = 1:t0

y((i-1)*t0+j) = -1;

end

end

end

y = [y,x(i)];

M = max(y);

m = min(y);

subplot(2,1,1);

plot(t,y);grid;

axis([0,i,m-0.1,M+0.1]);

%使用title命令标记各码元对应的二元信息
title('1 0 0 1 1 0 0 0 0 1 0 1');
ylabel('双极性非归零码');

双极性归零码

双极性归零码比较特殊,它使用前半时间1后半时间0来表示信息1;采用前半时间-1后半间0来表示信息0.因此它具有三个电平,严格来说是一种三元码。双极性归零码包含了丰富的时间信息,每一个码元都有一个跳变沿,便于接收方定时。同时对随机信号,信息1和0出现的概率相同,所以此种码元几乎没有直流分量。

function y = drz(x)

%本函数实现将输入的一段二进制代码编为相应的双极性归零码输出

%输入x为二进制码,输出y为编出的双极性归零码

t0 = 300;

t = 0:1/t0:length(x);

for i = 1:length(x)

if(x(i) == 1)

for j = 1:t0/2

y(t0/2*(2*i-2)+j) = 1;  %定义前半时间值为1

y(t0/2*(2*i-1)+j) = 0;  %定义后半时间值为0

end

else

for j = 1:t0/2              %反之,输入信息0

y(t0/2*(2*i-2)+j) = -1; %定义前半时间值为-1

y(t0/2*(2*i-1)+j) = 0;  %定义后半时间值为0

end

end

end

y = [y,x(i)];                       %给序列y加上最后一位,便于作图

M = max(y);

m = min(y);

subplot(2,1,1);

plot(t,y);grid;

axis([0,i,m-0.1,M+0.1]);

AMI码

AMI码全称是传号交替反转码,其编码规则是将消息码的1交替的变换为+1和-1,而0保持不变。

AMI码的优点是没有直流成分,且高低频分量少,能量集中在频率为1/2码速处;编解码电路简单,且可利用传号极性交替这一规律观察误码情况;

AMI码的缺点是当原码出现长连0时,信号电平长时间不跳变,造成提取定时信号的困难。

function y = ami(x)

%本函数实现将输入的一段二进制代码编为相应的AMI码输出

%输入x为二进制码,输出y为编出的AMI码

t0 = 300;

t = 0:1/t0:length(x);

m = 1;  %符号标记

for i = 1:length(x)     %计算码元的值

if(x(i) == 1) m=-m;      %如果信息为1

for j = 1:t0    %改码元对应的点值为1

if(m == -1)

y((i-1)*t0+j) = +1;

else y((i-1)*t0+j) = -1;

end

end

else

for j = 1:t0    %反之,信息为0,码元对应点值取0

y((i-1)*t0+j) = 0;

end

end

end

y = [y,x(i)];

M = max(y);

m = min(y);

subplot(2,1,1);

plot(t,y);grid;

axis([0,i,m-0.1,M+0.1]);

%使用title命令标记各码元对应的二元信息
title('1 0 0 1 1 0 0 0 0 1 0 1');
ylabel('AMI码');

本次操作激励t=[1 0 0 1 1 0 0 0 0 1 0 1];

以下是生成的信号波形图:

基于MATLAB的数字基带信号的各种码型的产生的更多相关文章

  1. 数字图像处理:基于MATLAB的车牌识别项目 标签: 图像处理matlab算法 2017-06-24 09:17 98人阅读 评论(0)

    学过了数字图像处理,就进行一个综合性强的小项目来巩固一下知识吧.前阵子编写调试了一套基于MATLAB的车牌识别的项目的代码.今天又重新改进了一下代码,识别的效果好一点了,也精简了一些代码.这里没有使用 ...

  2. 基于小波变换的数字图像处理(MATLAB源代码)

    基于小波变换的数字图像处理(MATLAB源代码) clear all; close all; clc;M=256;%原图像长度N=64; %水印长度[filename1,pathname]=uiget ...

  3. 基于MATLAB的中值滤波均值滤波以及高斯滤波的实现

    基于MATLAB的中值滤波均值滤波以及高斯滤波的实现 作者:lee神 1.   背景知识 中值滤波法是一种非线性平滑技术,它将每一像素点的灰度值设置为该点某邻域窗口内的所有像素点灰度值的中值. 中值滤 ...

  4. Hya.io – 基于 Web 的数字音频工作站

    Hya.io 是基于 Web 的音频应用程序,通过 Web MIDI ,音频合成器,音序以及大量的插件来支持硬件 MIDI .您可以添加插件到工作区,将其连接到路由音频,进行播放和实验. HYA 支持 ...

  5. Matlab.NET混合编程技巧之——直接调用Matlab内置函数(附源码)

    原文:[原创]Matlab.NET混合编程技巧之--直接调用Matlab内置函数(附源码) 在我的上一篇文章[原创]Matlab.NET混编技巧之——找出Matlab内置函数中,已经大概的介绍了mat ...

  6. 基于MATLAB边缘检测算子的实现

    基于MATLAB边缘检测算子的实现 作者:lee神 1.   概述 边缘检测是图像处理和计算机视觉中的基本问题,边缘检测的目的是标识数字图像中亮度变化明显的点.图像属性中的显著变化通常反映了属性的重要 ...

  7. 基于MATLAB的人脸识别算法的研究

    基于MATLAB的人脸识别算法的研究 作者:lee神 现如今机器视觉越来越盛行,从智能交通系统的车辆识别,车牌识别到交通标牌的识别:从智能手机的人脸识别的性别识别:如今无人驾驶汽车更是应用了大量的机器 ...

  8. 基于MATLAB的腐蚀膨胀算法实现

    本篇文章要分享的是基于MATLAB的腐蚀膨胀算法实现,腐蚀膨胀是形态学图像处理的基础,腐蚀在二值图像的基础上做“收缩”或“细化”操作,膨胀在二值图像的基础上做“加长”或“变粗”的操作. 什么是二值图像 ...

  9. 基于MATLAB的均值滤波算法实现

    在图像采集和生成中会不可避免的引入噪声,图像噪声是指存在于图像数据中的不必要的或多余的干扰信息,这对我们对图像信息的提取造成干扰,所以要进行去噪声处理,常见的去除噪声的方法有均值滤波.中值滤波.高斯滤 ...

随机推荐

  1. js设置当前页面始终为框架最顶层

    使用iframe做的页面,当session失效时,登录页面会显示在iframe里面 解决办法判断登录页面是否为顶层页面,不是的话刷新顶层页面

  2. Java原生API操作XML

    使用Java操作XML的开源框架比较多,如著名的Dom4J.JDOM等,但个人认为不管你用那个框架都要对JDK原生的API有所了解才能更得心应手的应用.本篇就来简单了解下原生的XML API. JAV ...

  3. 实现自动构建编译javaweb项目并发布到N台服务器

    前言 当你使用nginx实现了负载均衡,当你有了超过3台以上的应用服务器时,一个特别头疼的问题就来了,发布项目好麻烦. 你每次都要在本地编译打包一遍,然后手动复制到每一台服务器上面去,如果只有一两台服 ...

  4. 2243: [SDOI2011]染色

    2243: [SDOI2011]染色 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 3113  Solved: 1204[Submit][Status ...

  5. 《Django By Example》第九章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者@ucag 注:哈哈哈,第九章终于来啦 ...

  6. CSS规范 - 命名规则

    使用类选择器,放弃ID选择器 ID在一个页面中的唯一性导致了如果以ID为选择器来写CSS,就无法重用. NEC特殊字符:"-"连字符 "-"在本规范中并不表示连 ...

  7. iOS开发之UIDynamic

    1.概述 什么是UIDynamic? UIDynamic是从iOS 7开始引入的一种新技术,隶属于UIKit框架. 可以认为是一种物理引擎,能模拟和仿真现实生活中的物理现象.比如:重力.弹性碰撞等现象 ...

  8. 使用Yeoman generator来规范工程的初始化

    前言 随着开发团队不断发展壮大,在人员增加的同时也带来了协作成本的增加:业务项目越来越多,类型也各不相同.常见的类型有基础组件.业务组件.基于React的业务项目.基于Vue的业务项目等等.如果想要对 ...

  9. Unity 3D Framework Designing(5)——ViewModel之间如何共享数据

    对于客户端应用程序而言,单页应用程序(Single Page Application)是最常见的表现形式.有经验的开发人员往往会把一个View分解多个SubView.那么,如何在多个SubView之间 ...

  10. 【 js 性能优化】throttle 与 debounce 节流

    在看 underscore.js 源码的时候,接触到了这样两个方法,很有意思: 我先把实现的代码撂在下面,看不懂的可以先跳过,但是跳过可不是永远跳过哦- 一个是 throttle: _.throttl ...