Slip打包与解包及MATLAB程序

Slip打包与解包

基本原理

     在数据包的头和尾加0xC0,如果数据中包含0xC0,用0xDB 0xDC代替,如果数据中包含0xDB,则用0xDB 0xDD代替。

SLIP打包程序(MATLAB)

function SlipOut = SlipPk(SlipIn)
   
    xC0 = hex2dec('C0');
    xDB = hex2dec('DB');
    xDC = hex2dec('DC');
    xDD = hex2dec('DD');
   
    SlipInLen = length(SlipIn);
    SlipOut = zeros(1,2*SlipInLen);
    m = 1;
    for k = 1:SlipInLen
        if(SlipIn(k) == xC0)
            SlipOut(m) = xDB;
            SlipOut(m+1) = xDC;
            m = m + 1;
        elseif(SlipIn(k) == xDB)
            SlipOut(m) = xDB;
            SlipOut(m+1) = xDD;
            m = m + 1;
        else
            SlipOut(m) = SlipIn(k);           
        end
        m = m + 1;
    end
    SlipOut = [xC0 SlipOut(1:m-1) xC0];
end

SLIP解包程序(MATLAB)

function UnpkOut = SlipUnpk(UnpkIn)
   
    xC0 = hex2dec('C0');
    xDB = hex2dec('DB');
    xDC = hex2dec('DC');
    xDD = hex2dec('DD');
   
    if(UnpkIn(1) ~= xC0 && UnpkIn(end) ~= xC0)
        error('The slip package is wrong!');
    end
    UnpkInLen = length(UnpkIn);
    UnpkOut = zeros(1,UnpkInLen-2);
    m = 1;
    k = 2;
    while k < UnpkInLen
        if(UnpkIn(k) == xDB && UnpkIn(k+1) == xDC)
            UnpkOut(m) = xC0;
            k = k + 2;
        elseif(UnpkIn(k) == xDB && UnpkIn(k+1) == xDD)
            UnpkOut(m) = xDB;
            k = k + 2;
        else
            UnpkOut(m) = UnpkIn(k);   
            k = k + 1;
        end
        m = m + 1;
    end
    UnpkOut = UnpkOut(1:m-1);
end
       


转载于:https://www.cnblogs.com/erizen/archive/2011/05/08/2040300.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值