用python写海明校验码

生成海明校验码

def Input():
    """
    输入字符串'0'与'1'的组合
    输出两个参数:字符串的长度,字符列表
    """
    string = input("请输入‘0’‘1’字符串:")
    return len(string), list(string)

# n表示字符串长度,List表示字符列表。List --> type(List[0])=string
n, List = Input()

def getK(n):
    """
    param: n表示字符串长度
    function:计算得到k的值,k为海明码检验位
    return:返回参数k
    """
    k = 1
    while n+k > pow(2, k)-1:
        k += 1
    return k

# k为海明码检验位
k = getK(n) 

def getHList(n, k, List):
    """
    param:n表示字符串长度,k表示海明码校验位,List表示'0' '1'字符列表
    function:初始化列表H,将List里的字符按照规律插入H列表中,未插入的位置则是校验码的位置,初始值为-1
    return:返回已经初始化列表H。H --> type(H[0])=int
    """
    H = [-1 for i in range(k+n+1)]
    cnt = 0
    for i in range(1, k+n+1):
        if i == pow(2, cnt):
            cnt += 1
            continue
        H[i] = int(List.pop())
    return H

# 初始化列表H。H --> type(H[0])=int
H = getHList(n, k, List.copy())

def getPDict(k, H):
    """
    param: k表示海明码校验位,H表示初始化列表
    function: 计算校验码的值
    return: 返回字典P,键确定索引位置,值是计算出来的校验码
    """
    P = dict()
    
    for i in range(k):
        P[i] = None
        cnt = 0
        for bi in range(1, len(H)):
            if bi == pow(2, cnt):
                cnt += 1
                continue
            if (bi >> i)&1:
                if not P[i]:
                    P[i] = H[bi]
                else:
                    P[i] = P[i]^H[bi]
    return P   

# 字典P,在pow(2, key)的H索引位置上插入value
P = getPDict(k, H) 

def insertPInH(P, H):
    """
    param: 字典P,存储了校验码的值。初始化列表H,待插入P的值。
    function:按照一定规律将P中的值插入H中
    return: 返回列表H
    """
    for key in P:
        Index = pow(2, key)
        H[Index] = P[key]
    return H  

# H1 表示已经处理好的海明校验码
H1 = insertPInH(P, H.copy())


输入字符串:1001101

生成海明码
在这里插入图片描述

海明码的校验

在传输过程中,数据可能会有一位出差错。那么我们就需要检错并纠错。
假设传输后我们得到的数据为:

[-1, 1, 0, 1, 0, 0, 1, 1, 1, 0, 1, 1]

然后将这个数据进行checking,检查是否出错。

def checking(Hs, k):
    """
    param: Hs表示传输过来的字符串,用于验证。k表示校验位数。
    function: 用来校验传输的字符串是否出错
    
    """
    # Pc得到Pi校验码
    Pc = getPDict(k, Hs)
    print(Pc)
    Si = []
    Svalue = 0
    cnt = 0
    for i in range(1, len(Hs)):
        if i == pow(2, cnt):
            Pi = Pc[cnt]
            value = Pi^Hs[i]
            Si.append(value)
            if value == 0 and cnt == 0:
                Svalue = 0
            else:
                Svalue += pow(2*value, cnt)
            cnt += 1
        if cnt == k:
            break
    print(Si)
    if Svalue:
        print("传输错误,错误的索引位置为:", Svalue)
        print("从下标0开始索引")   
    else:
        print("传输无误!")
     
checking([-1, 1, 0, 1, 0, 0, 1, 1, 1, 0, 1, 1], k)   

在这里插入图片描述

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是强筱华哇!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值