Shamir门限秘密共享方案 秘密分配及还原过程详解 【橘小白】

本文介绍Shamir(t,w)门限方案,一种安全地分散和恢复秘密的方法。秘密被拆分为w个碎片,只有当至少t个碎片聚合时,才能重构原始秘密。通过构造多项式和选取特定参数,确保即使部分碎片丢失或被恶意篡改,也能保障秘密的安全。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Shamir(t,w)门限方案,(0 < t <= w)
用途:
假设我们存在一个秘密S,把秘密S进行特定运算,得到w个秘密碎片Si(0 < i <= w),交给w个人保存,当至少t个人同时拿出自己所拥有的秘密碎片Si时,即可还原出最初的秘密S。

秘密碎片生成:
构造一个多项式
在这里插入图片描述
其中,S为我们的秘密,p为素数,且S < p
取w个不相等的x,带入F(x)中,得到w组(xi,yi),分配给w个人
公开p,销毁多项式,每个人负责保密自己的(xi,yi)

秘密恢复:

当x=0时,F(0)=S,即可恢复出S
将t组(xi,yi)带入下式即可
在这里插入图片描述
其中,负一次方为该项模p的逆
将t组(xi,yi)带入即可得到S

示例
假设我们有w=4个人,设定至少t=3人才能恢复秘密。
秘密S=2,p=23
构造
在这里插入图片描述
取x1=1,x2=2,x3=3,x4=4
带入得y1=7,y2=16, y3=6,y4=0
利用3组进行恢复(1,7) (3,6) (4,0)
在这里插入图片描述
计算可得到S=2

最后再附一个简单的恢复脚本

# coding:utf-8


def oj(a, n):   # 求逆的函数
    a = a % n
    s = [0, 1]
    while a != 1:
        if a == 0:
            return 0
        q = n/a
        t = n % a
        n = a
        a = t
        s += [s[-2] - q * s[-1]]
    return s[-1]

p = 23
m = ((4, 0),
     (3, 6),
     (2, 16))
r = (
    m[0][1] * (0 - m[1][0]) * (0 - m[2][0]) * oj((m[0][0] - m[1][0]) * (m[0][0] - m[2][0]), p) +
    m[1][1] * (0 - m[0][0]) * (0 - m[2][0]) * oj((m[1][0] - m[0][0]) * (m[1][0] - m[2][0]), p) +
    m[2][1] * (0 - m[0][0]) * (0 - m[1][0]) * oj((m[2][0] - m[0][0]) * (m[2][0] - m[1][0]), p)
     ) % p
print r

更新一个相对完整的脚本python3写的,变量名基本上与文章中含义一致



import Crypto.Util.number as numb
import random


# 求逆的函数,之前的版本用python2写的,这次用的python3,只把整除符号改了一下
def oj(a, n):
    a = a % n
    s = [0, 1]
    while a != 1:
        if a == 0:
            return 0
        q = n // a
        t = n % a
        n = a
        a = t
        s += [s[-2] - q * s[-1]]
    return s[-1]


# max_length 为p的长度,同时也是秘密的最大长度
# secret_is_text =0 默认输入时文本, 非0时认为是数字
# p 默认为0, 会根据max_length 自动生成,不为0时直接使用,需要保证p为素数, 函数内没有素性检验
def create(max_length=513, secret_is_text=0, p=0):
    if not p:
        p = numb.getPrime(max_length)

    w = int(input("请输入秘密保存人数:"))
    t = int(input("请输入秘密恢复所需人数:"))
    while not (t > 0 and t <= w):
        t = int(input("请重新输入:"))
    s = input("请输入你的秘密:")

    if secret_is_text:
        s = numb.bytes_to_long(s.encode("utf-8"))
    else:
        try:
            s = int(s)
        except Exception as e:
            s = numb.bytes_to_long(s.encode("utf-8"))

    x_list = list()
    a_list = list()
    i = w
    while i > 0:
        x = random.randint(p // 2, p)  # 该范围没有特定限制,如果想让xi,yi取小一点儿的话可把范围写小点儿,但是要大于w
        if x not in x_list:
            x_list.append(x)
            i -= 1

    for a in range(t):
        a_list.append(random.randint(p // 2, p))  # 同上

    result = list()
    for x in x_list:
        y = s
        for a_n in range(t):
            a = a_list[i]
            y += a * pow(x, i + 1, p)
        result.append((x, y))
    return t, p, result


# get_text=1 默认恢复为字符串,若想得到数字填0
def restore(p, information, get_text=1):

    x_list = list()
    y_list=list()
    for x, y in information:
        x_list.append(x)
        y_list.append(y)

    s = 0
    for x_i in range(len(x_list)):
        tmp_num = y_list[x_i]
        x_i_j = 1
        for x_j in range(len(x_list)):
            if x_i != x_j:
                tmp_num = tmp_num * (0 - x_list[x_j]) % p
                x_i_j *= x_list[x_i] - x_list[x_j]
        tmp_num = tmp_num * oj(x_i_j, p) % p
        s += tmp_num

    s = s % p
    print(s)
    if get_text:
        try:
            s = numb.long_to_bytes(s)
            s = s.decode("utf-8")
        except Exception as e:
            print(e)

    return s


t, p, result = create()             #result为秘密碎片的列表
print(result)
print(restore(p, result[:t]))     #这里我取了result的前t个,实际中可以取任意t个。






<think>好的,用户现在用的是瑞芯微的RV1126硬件平台,想要开发摄像头驱动和ISP驱动。首先,我需要回忆一下RV1126的相关资料。RV1126是一款针对视觉处理的芯片,通常用于摄像头、智能安防等领域,所以摄像头驱动和ISP确实是关键部分。 用户可能有一定的嵌入式开发经验,但可能对RV1126的具体开发流程不太熟悉。需要先确定他们的开发环境是否已经搭建好了,比如SDK、交叉编译工具链等。如果用户已经完成了这些基础工作,接下来就是具体的驱动开发步骤。 摄像头驱动方面,RV1126通常支持MIPI CSI-2接口的摄像头模块。需要确认用户使用的摄像头型号是否兼容,或者是否需要自己适配。可能需要修改设备树(Device Tree)来配置MIPI接口参数,比如时钟频率、数据通道数等。还有I2C通信,用于配置摄像头传感器的寄存器,这部分可能需要编写或调整驱动代码。 然后是ISP驱动,RV1126内置了ISP模块,处理图像数据如降噪、HDR等。用户可能需要配置ISP的参数,或者根据具体需求调整图像处理流程。瑞芯微的SDK里可能有相关的文档和示例代码,需要引导用户参考这些资料,比如如何通过mediactl或v4l2工具进行配置。 另外,用户可能会遇到调试问题,比如图像不显示、颜色异常等。这时候可能需要检查设备树配置是否正确,时钟信号是否稳定,或者I2C通信是否正常。还有可能是电源管理的问题,摄像头模块的供电是否充足。 用户可能还不太清楚如何测试驱动是否正常工作,可能需要指导他们使用工具如v4l2-ctl来捕获图像,或者使用瑞芯微提供的调试工具。另外,ISP的调试可能需要通过参数调整来优化图像质量,这部分可能需要反复试验。 需要提醒用户注意内核版本和SDK的兼容性,不同版本的SDK可能在驱动支持上有差异。如果用户遇到编译错误或驱动加载失败,建议检查内核配置和驱动模块的依赖关系。 最后,考虑到用户的具体需求,可能需要推荐他们查阅RV1126的官方文档,加入开发者社区或论坛,获取更多的支持和案例分享。如果有具体的错误信息或日志,分析起来会更有效率。</think>开发摄像头驱动和ISP驱动在RV1126平台上的实现可以分为以下几个关键步骤,以下是基于瑞芯微平台的开发要点总结: --- ### **一、RV1126视觉开发基础** 1. **硬件特性认知** - 双核NPU(2Tops算力)支持INT8/INT16量化 - 内置第三代ISP(支持HDR、3DNR等图像增强算法) - 支持MIPI CSI-2/DVP等摄像头接口 2. **开发环境搭建** ```bash # 官方推荐工具链(需联系瑞芯微获取) tar xvf rv1126_toolchain.tar.gz export PATH=$PATH:/opt/rv1126/gcc-arm-8.3-2019.11-x86_64-arm-linux-gnueabihf/bin ``` --- ### **二、摄像头驱动开发流程** #### **1. 设备树配置** ```dts // kernel/arch/arm/boot/dts/rv1126-ipc.dtsi &i2c1 { status = "okay"; camera0: camera-module@10 { compatible = "sony,imx415"; // 替换实际传感器型号 reg = <0x10>; clocks = <&cru CLK_MIPICSI_OUT>; clock-names = "xvclk"; port { camera_out: endpoint { remote-endpoint = <&mipi_in_ucam0>; data-lanes = <1 2 3 4>; // MIPI通道配置 link-frequencies = /bits/ 64 <594000000>; }; }; }; }; &mipi_csi2 { status = "okay"; ports { port@0 { mipi_in_ucam0: endpoint@1 { remote-endpoint = <&camera_out>; data-lanes = <1 2 3 4>; }; }; }; }; ``` #### **2. V4L2驱动框架适配** - 实现`struct v4l2_subdev_ops`操作集 - 注册I2C驱动: ```c static struct i2c_driver imx415_i2c_driver = { .driver = { .name = "imx415", .of_match_table = imx415_of_match, }, .probe = imx415_probe, .remove = imx415_remove, }; module_i2c_driver(imx415_i2c_driver); ``` --- ### **三、ISP驱动开发要点** #### **1. ISP管线配置** 通过`media-ctl`工具验证数据流: ```bash media-ctl -p -d /dev/media0 # 预期输出应包含实体链路: # "imx415 1-0010" -> "rkisp1_isp" ``` #### **2. 图像调优参数设置** 通过`v4l2-ctl`调整ISP参数: ```bash v4l2-ctl -d /dev/v4l-subdev0 \ --set-ctrl brightness=128 \ --set-ctrl contrast=90 \ --set-ctrl saturation=100 ``` #### **3. HDR模式启用(以IMX415为例)** ```c // 通过I2C发送传感器配置命令 static int imx415_set_hdr(struct i2c_client *client, u32 mode) { u8 reg_val[3]; reg_val[0] = 0x30; // HDR控制寄存器地址 reg_val[1] = (mode & 0x0F) << 4; i2c_master_send(client, reg_val, 2); return 0; } ``` --- ### **四、典型问题排查** 1. **图像无输出** - 检查供电:`cat /sys/class/regulator/regulator.9/voltage` - 验证时钟信号:示波器测量XCLK引脚(正常应输出24MHz) 2. **颜色异常** ```bash # 确认Bayer格式匹配 v4l2-ctl --get-fmt-video # 输出应为:'RG10' (对于IMX415) ``` 3. **ISP超时错误** ```dmesg [ 256.390241] rkisp1: timeout waiting for isp config lock! ``` 需检查时钟频率配置: ```dts &cru { assigned-clocks = <&cru CLK_MIPICSIOUT_RX>; assigned-clock-rates = <594000000>; // 需与传感器输出匹配 }; ``` --- ### **五、开发资源推荐** 1. **官方文档** - 《RV1126 TRM》第12章ISP子系统 - 《Rockchip_Developer_Guide_ISP3.x_CN》 2. **调试工具** ```bash # ISP3D调试工具(需配套SDK) isp_demo --sensor=imx415 --action=test ``` 建议通过瑞芯微官方GitHub获取最新内核补丁(注意分支选择): ``` git clone -b rv1126_linux_release https://github.com/rockchip-linux/kernel.git ``` 开发过程中若遇到具体硬件兼容性问题,建议直接联系瑞芯微FAE获取传感器适配支持包(Sensor Driver Adaptation Kit)。
评论 25
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值