Simulink模型编译加密共享

本文介绍的Simulink模型的编译加密,如果只是简单地想禁止用户查看和修改模块内部结构,参见:Simulink 模型简单加密-CSDN博客

1.前言

为了保护知识产权,有时候需要让用户能使用slx模型运行仿真,但是无法查看和修改模型和子系统的结构,同时对模型生成的源码也进行加密,这时可以用Simulink coder来生成受保护的模型。主要步骤如下:

(1)将slx模型的各个子系统唯一命名

(2)将各个子系统转换成引用模型(Referenced model)

(3)使用Simulink coder将转换得到的引用模型打包为受保护的slxp模型

(4)在原总slx模型中引用子系统的slxp模型

2.实现步骤

2.1 将各个子系统转换成引用模型

首先先运行一遍模型,创建所有变量。鼠标右击子系统模块,选择System & Model Reference/Convert to/Referenced Model,如下图所示。

在打开的对话框中依次运行各个步骤

其它类似。直到所有步骤运行成功,此时自动完成转换并打开新创建的引用模型,模型名称和子系统名称一致。如果出现以下错误:

Check failed
Converting subsystem 'xxxxx' to a referenced model is not supported because it is virtual. Subsystem being converted to a referenced model must be atomic.

说明该子系统本身没有实际的运行行为,而是作为模型层次结构的组织结构使用,一般可以不加密,如果必须加密,则要更换为Atomic Subsystem,即在该子系统XXX旁边创建一个空白的Atomic Subsystem,将内部结构复制进去,然后替换原来的子系统,记得保持同样命名。

2.2 使用Simulink coder将转换到的引用模型打包为受保护的slxp模型

在之前打开的引用模型界面中找到并打开Simulink Coder

打开Generate Protect Model: 

在对话框中设置生成的slxp用户模型权限:

一共支持4项权限:

(1)Open read-only view of model: 是否允许打开模型的只读视图查看内部结构。勾选表示允许用户以只读的方式查看内部结构。也可设置密码,让用户输入密码才能查看。

(2)Simulate: 是否允许运行模型仿真。也可设置密码,让用户输入密码才能运行。

(3)Use generated code:是否允许将模型生成为C/C++代码。

(4)Use generated HDL code:是否允许根据模型生成硬件描述语言(Hardware Description Language,缩写为 HDL)。

生成方式有两种,一般选择Protected model (. slxp) only,即只生成slxp模型,不打包依赖文件。点击Create,将在原目录下生成和上述引用模型同名的slxp模型。

2.3 在原总slx模型中引用slxp模型

返回到原总模型查看,可以看到Simulink自动将模型替换为加密后的引用模型:

这是因为当同一个目录下同时包含subsystem.slx和subsystem.slpx两种同名引用模型时,simulink优先加载slxp模型。所以不要将生成的slxp模型重命名。其它子系统按同样方法处理。

注意在运行之前关闭生成的子系统slx引用模型窗口,因为子系统slx和slxp两个模型同名,同时在simulink打开会造成命名冲突。

3.同时加密多个子系统

当一个子系统被加密为slxp后,其它依赖它的子系统将无法转换为引用模型,因此最好将全部要加密的子系统均转换为引用模型后再统一加密。

注意:包含传函等连续系统的模块必须离散化后才能使用这种方法加密。加密完成后需要将生成的子系统slx引用模型删除,只保留加密模型slxp,不然等于没有加密。

评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

安布奇

喜欢的朋友给点支持和鼓励吧

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

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

打赏作者

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

抵扣说明:

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

余额充值