百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

实例讲解Simulink的Assignment模块

zhezhongyun 2025-05-26 20:18 9 浏览

Simulink的Assignment模块为指定的信号元素赋值,可以通过在模块对话框中输入索引,或者通过将一个或多个外部索引源连接到模块,来指定要赋值的元素的索引。


1.Assignment模块



库:
Simulink / Math Operations
HDL Coder / Math Operations

从C语言的角度去理解,就是将一个变量赋值给数组中的某个元素。

输入
1.Y0 — 输入初始化信号
标量 | 向量
输出信号的初始化信号。如果元素未被赋予另一个值,则输出元素的值与此输入信号值匹配。


2.U — 输入数据端口
标量 | 向量
赋给输出元素的值(当指定了该值时)。


3.IndxN — 第 N 个索引信号
标量 | 向量
外部端口,用于指定对应输出元素的赋值的索引。
输出
Y — 具有已赋值的输出信号
标量 | 向量
对指定元素赋值后的输出信号。


参数
1.输出维度的数量 — 输出信号的维度数
1 (默认) | 整数
键入输出信号的维度数。
编程用法
参数:NumberOfDimensions
类型:字符向量
值:integer
默认值:'1'
2.索引模式 — 索引模式
从 1 开始 (默认) | 从 0 开始
选择索引模式。如果选择从 1 开始,则索引 1 指定输入向量的第一个元素。如果选择从 0 开始,则索引 0 指定输入向量的第一个元素。
编程用法
参数:IndexMode
类型:字符向量
值:'Zero-based' | 'One-based'
默认值:'One-based'


3.初始化输出(Y) — 如何初始化输出信号
使用输入端口 <Y0> 初始化 (默认) | 指定表中每个维度的大小
指定如何初始化输出信号。
使用输入端口 <Y0> 初始化 - 位于输入端口 Y0 的信号初始化输出。
指定表中每个维度的大小 - 要求您在输出大小参数中指定模块输出信号的宽度。如果输出具有未分配的元素,则这些元素的值未定义。
编程用法
参数:OutputInitialize
类型:字符向量
值:'Initialize using input port <Y0>' | 'Specify size for each dimension in table'
默认值:'Initialize using input port <Y0>'


4.未分配任何输出元素时的动作 — 产生警告或错误的选项
警告 (默认) | 错误 | 无
指定当您还有未分配的输出元素时是否生成警告或错误。选项包括:
警告 - Simulink 显示警告并继续进行仿真。
错误 - Simulink 终止仿真并显示错误。
无 - Simulink 不执行任何操作。
编程用法
参数:DiagnosticForDimensions
类型:字符向量
值:'Error' | 'Warning' | 'None'
默认值:'Warning'
5.索引选项 — 元素的索引方法
索引向量(对话框) (默认) | 全部赋值 | 索引向量(端口) | 起始索引(对话框) | 起始索引(端口)
按维度定义信号元素的索引方式。从列表中,选择:
使用输入端口 <Y0> 初始化
指定表中每个维度的大小
否则,Y0 始终初始化输出端口 Y。
索引和输出大小列显示为具有相关性。
编程用法
参数:IndexOptionArray
类型:字符向量
值:'Assign all' | 'Index vector (dialog)' | 'Index option (port)' | 'Starting index (dialog)' | 'Starting index (port)'
默认值:'Index vector (dialog)'




2.实例


2.1实例1

模块参数

Y0:设置的初始数组值 Idx1:要修改的数组元素下标 U:要修改的数组元素值。

修改Index mode:从One-based改为Zero-based:





2.2 实例2

修改Index Option属性

仿真模型

参数设置


仿真模型


参数设置

当模型运行的过程中需要更新某个Vector信号中的某个元素。从C语言的角度去理解,就是将一个变量赋值给数组中的某个元素。可以通过Assignment模块实现这个需求。Assignment有分配、指派的含义,在建模中这么理解也是很贴切的。相对应的,从一个Vector信号中提取某个元素可以用Selector模块。

用于数组的读写处理,Y0为输入的数组,U为要为Y0赋的值。可以为数,也可以为数组。

Starting index 是从index(含本身)后开始将U的值全部赋为Y0,如果U为一个数,就只赋值给对应的索引值。如果U为一个数组,看其数值长度。但其数值长度一定小于Y0的长度。


仿真模型


3.参考内容

[1]https://ww2.mathworks.cn/help/simulink/slref/assignment.html

[2] 知乎作者你若盛开的文章《Simulink中Assignment模块用法详解》,文章链接为:
https://zhuanlan.zhihu.com/p/507259921

[3] 知乎作者小张在奔跑的文章《Simulink模块之Assignment》,文章链接为:
https://zhuanlan.zhihu.com/p/458794544

[4]CSDN作者chhttty的文章《Simulink代码生成:Assignment模块及其代码》,文章链接为:

https://blog.csdn.net/u013288925/article/details/108983473

本文内容来源于网络,仅供参考学习,如内容、图片有任何版权问题,请联系处理,24小时内删除。


作 者 | 郭志龙

编 辑 | 郭志龙
校 对 | 郭志龙

相关推荐

饿了么面试官:实现一下 Element-UI 官网的主题切换动画!

最近看到ElementPlus官网上的切换主题方式非常有趣,这是一个过渡的动画效果所以在网上查了一番,找到基本的实现方法实现基本效果首先我们起一个html文件,写一个按钮,以及简单的背景颜色切...

强大而好用的选择器:focus-within

伪类和伪元素在开发网页样式中,选择器必不可少,而且选择器也是在开发css中非常重要的内容,包括常用的类选择器,id选择,同时还有伪类,伪类选择器最大的特点就是冒号开头。平时也经常会有小伙伴问到,在使用...

令程序员惊叹的一些CSS3效果库

还在寻找那些CSS3的效果库吗?如果你的答案是肯定的,并且目前没有找到,那么你一定不能错过小编为大家收集的这些CSS3效果库,这是一个令你兴奋的集合!最新的CSS3都配备了新的特性,来设计创建动画和互...

伪元素黑魔法:一个替代onerror解决图片加载失败的方案

问题的引出是这样的,在一个项目中有大量的页面主体是table做数据展示,所以就封装了一个table的组件,提供动态渲染的方案。有个问题是数据类型中有图片,对于图片的加载失败我们需要做容错。一般我们的思...

前端 - 如何通过CSS修改图片透明度

如果在图片上显示文字,经常会遇到这个情况,就是当文字和背景颜色差不多时,文字会看不清楚,我们一般通过给文字加textshadow或者修改图片的透明度来让文字显示更加突出。我们今天说一下透明度的问题,...

CSS元素居中方法完全指南

这里是工作狂的聚集地职场学术新媒体设计极客专门治愈处女座强迫症。本文为CSS入门翻译redman9原载CSS-Trick人们经常抱怨在CSS中居中元素的问题,其实这个问题并不复杂,只是因为方法众...

CSS图像 hover 动画效果

点击页底“阅读原文”下载原码CSSHover在网页设计中是极为常用的一个CSS效果,只要你有创造力,都可以让Hover变得更多姿多彩,今天我们主要分享40多款使用CSSHOVER完成...

前端能限制用户截图吗?

摘要:在某些业务场景下,保护屏幕信息的私密性,防止用户随意截图分享,成为了前端开发者的一个棘手需求。但浏览器和操作系统的设计,真的允许网页开发者完全掌控用户的截图行为吗?本文将深入探讨前端限制截图的...

每天一个CSS小技巧 - 不规则投影

当我们想给一个矩形或者其他能用border-radius生成的形状加投影时,box-shadow的表现都很棒的。但是,当元素添加可一些伪元素或半透明的装饰之后,border-radius会无视这些。这...

Web开发中10个有用的免费CSS代码

在本文中主要展示了在Web开发中一些免费但是非常有用的代码,开发人员可以下载它们来简化工作流程。在这个集合中的所有代码都是经过精挑细选的,对于开发人员来说非常有用。在开发一个网站时,这些代码将节省大量...

什么是伪类和伪元素?两者有什么区别?单一冒号和双冒号有何不同

https://juejin.im/post/5df1e312f265da33d039d06d?utm_source=bigezhang.com#comment伪类伪类存在的意义是为了通过选择器找到那...

CSS2与CSS3中常用的伪类汇总大全

CSS2与CSS3中有非常多的伪类,可以用于实现各种强大的、酷炫的功能。有用于选择标签状态的,如:a:linka:hoverinput:checkedinput:focus等;也有用于根据结构选...

实用!这8个CSS工具可以提升编程速度

作为网页设计师,为了在预期的时间内能完成项目,前期肯定是要进行大量练习的。但是如果你花了大量的时间在编写CSS代码上,那无疑是浪费时间。工欲善其事必先利其器,聪明的设计师善于利用工具提升他们的编码效率...

《丝路传说怀旧版》宠物融合丹:属性加成与技能继承要点

在《丝路传说怀旧版》中,宠物融合丹是优化宠物属性与技能的核心道具,其使用需结合技能继承规则、品质提升机制及资源规划策略。以下是关键要点分析一、属性加成机制品质提升与属性增长品质阶梯:宠物分为白、绿、蓝...

Python 3.14 t-string 要来了,它与 f-string 有何不同?

Python最近出了个大新闻:PEP-750t-string语法被正式采纳了!这意味着Python将在今年10月发布的3.14版本中引入一种新的字符串前缀t,称为模板字符串(Tem...