主要内容

添加元素之和总和

  • 库:
  • 金宝appSimulink /数学运算

    HDL编码器/ HDL浮点运算

    HDL编码器/数学运算

  • 添加块

描述

总和块对其输入执行加法或减法。加、减、元素和和块都是相同的块。这个块可以加或减标量、向量或矩阵输入。它还可以折叠信号的元素并执行求和。

属性指定块的操作符号列表参数加(+) - (-),以及垫片(|).

  • 的数量+-字符等于输入的数量。例如,+-+需要三个输入。该块从第一个(上)输入减去第二个(中)输入,然后加上第三个(下)输入。

  • 间隔字符在块图标上的端口之间创建额外的空间。

  • 如果只执行加法,则可以使用与输入数相等的数值。

  • 如果只有一个输入端口,一个+-在所有维度或指定维度上添加或减去元素。

Sum块首先将输入数据类型转换为其累加器数据类型,然后执行指定的操作。该块使用指定的舍入和溢出模式将结果转换为其输出数据类型。

块输出计算

求和块的输出计算取决于块输入的数量和输入端口的符号:

如果Sum块有… 和… 计算产量的公式为… 在那里……

一个输入端口

输入端口符号是+

Y = e[0] + e[1] + e[2]…+ e [m]


e[我]是我th输入元素

输入端口符号为-

Y = 0.0 - e[0] - e[1] - e[2]…- e [m]


两个或多个输入端口

所有输入端口符号为-

Y = 0.0 - u[0] - u[1] - u[2]…- u [n]


u[i]是输入到ith输入端口

kth输入端口是第一个带+号的端口

y = u [k] - u [0] - [1] - u [2] - u (k - 1) (+ / -) [k + 1]…(+ / -) u [n]


港口

输入

全部展开

输入可以是不同的数据类型,除非您选择要求所有输入具有相同的数据类型参数。

输入信号进行加法或减法运算。如果只有一个输入信号,则对所有维度或指定维度上的元素进行加减运算。

数据类型:一半|仅有一个的||int8|int16|int32|int64|uint8|uint16|uint32|uint64|布尔|不动点

n输入信号的操作。输入的数量与符号的数量匹配符号列表参数。该块按照列出的顺序对输入应用操作。您还可以使用一个等于输入端口数量的数值作为符号列表参数。该块创建输入端口并对所有输入应用加法。例如,如果你分配5符号列表参数时,块创建5输入端口并将它们相加以生成输出。

所有非标量输入必须具有相同的维数。将标量输入展开,使其具有与其他输入相同的维度。

数据类型:一半|仅有一个的||int8|int16|int32|int64|uint8|uint16|uint32|uint64|布尔|不动点

输出

全部展开

由加法和/或减法运算产生的输出信号。输出信号与输入信号具有相同的尺寸。

数据类型:一半|仅有一个的||int8|int16|int32|int64|uint8|uint16|uint32|uint64|布尔|不动点

参数

全部展开

主要的

指定块的图标形状为矩形或圆形。

对于矩形块,第一个输入端口是顶部端口。对于一个整数块,第一个输入端口是最接近12点位置的端口,以逆时针方向围绕块。类似地,其他输入端口以逆时针方向排列。

编程使用

块参数:IconShape
类型:字符向量
:“矩形”|“圆”
默认的:“圆”

输入对输入执行的加法和减法运算。为每个运算创建一个输入端口。间隔符(|)在块图标上的输入端口之间创建额外空间。添加是默认操作。如果只想添加输入,请输入输入端口数。操作按所列顺序执行。

当您只输入一个元素时,块将启用合计参数。对于单个矢量输入,+-在所有维度或指定维度上添加或减去元素。

提示

可以通过插入垫片来操纵块上输入端口的位置(|)之间的符号符号列表参数。例如,“++|--在第二和第三输入端口之间创造了一个额外的空间。

编程使用

块参数:输入
类型:字符向量
:“+”|“- - -”|||整数
默认的:“+ +”

选择块执行求和操作的维度。

所有维度,对所有输入元素进行求和。当选择配置参数时使用优化的行主阵列布局算法,仿金宝app真软件®为模拟启用行主算法。要生成行主代码,请设置配置参数阵列布局(金宝appSimulink编码器)除了选择使用优化的行主阵列布局算法。列主算法和行主算法仅在求和顺序上不同。在某些情况下,由于同一数据集上的操作顺序不同,您可能会在列主算法和行主算法的输出中遇到微小的数字差异。

当您选择指定的尺寸,另一个参数出现了。选择对输入向量求和的具体维度。

附属国

中只列出一个签名时启用符号列表参数。

编程使用

块参数:羽衣甘蓝
类型:字符向量
:“所有维度”|“指定维度”
默认的:“所有维度”

当你选择指定的尺寸合计参数时,指定要执行操作的维度。

该块遵循与MATLAB相同的求和规则®总和函数。

假设你有一个2 × 3矩阵U

  • 设置1输出结果Y计算如下:

    Y 1 2 U j

  • 设置2输出结果Y计算如下:

    Y j 1 3. U j

如果指定的维度大于输入的维度,则会出现错误消息。

附属国

当您选择启用时指定的尺寸合计参数。

编程使用

块参数:CollapseDim
类型:字符向量
价值:整数
默认的:' 1 '

将样本时间指定为-1以外的值。有关更多信息,请参见指定采样时间

依赖关系

这个参数是不可见的,除非它被显式地设置为非-1.想要了解更多,请看不推荐采样时间的块

编程使用

块参数:SampleTime
类型:特征向量
价值观:标量或矢量
默认值:' 1 '

信号的属性

单击显示数据类型助手按钮显示数据类型的助理,它可以帮助您设置数据类型属性。有关更多信息,请参见使用数据类型助手指定数据类型

指定输入信号是否必须具有相同的数据类型。如果启用此参数,则如果输入信号类型不同,则在模拟过程中发生错误。

编程使用

块参数:InputSameDT
类型:特征向量
价值观:“关”|“开”
默认值:“关闭”

选择累加器的数据类型。类型可以继承、直接指定或表示为数据类型对象,例如金宝appSimulink.NumericType.当你选择继承:通过内部规则继承, 金宝appSimulink选择一种数据类型来平衡数字精度、性能和生成的代码大小,同时考虑嵌入式目标硬件的属性。

编程使用

块参数:AccumDataTypeStr
类型:字符向量
:继承:通过内部规则继承|“继承:与第一次输入相同”|“双”“单一”|“一半”|“int8”|‘uint8’|“int16”|“uint16”“int32”|“uint32”|“int64”|“uint64”|‘fixdt(1,16)’|‘fixdt(1,16,0)’|“fixdt(1, 16日2 ^ 0,0)”|“< >数据类型表达”
默认的:“继承:通过内部规则继承”

Simulink检查的输出范围的较低值。金宝app

金宝appSimulink使用最小值执行以下操作:

请注意

最小输出不饱和或剪辑实际输出信号。使用饱和块来代替。

编程使用

块参数:OutMin
类型:字符向量
:“[]”|标量
默认的:“[]”

Simulink检查的输出范围的上限值。金宝app

金宝appSimulink使用最大值来执行:

请注意

最大输出不饱和或剪辑实际输出信号。使用饱和块来代替。

编程使用

块参数:奥特马克斯
类型:字符向量
:“[]”|标量
默认的:“[]”

选择输出的数据类型。类型可以继承、直接指定或表示为数据类型对象,例如金宝appSimulink.NumericType

当您选择继承的选项时,块的行为如下:

  • 继承:通过内部规则继承-金宝appSimulink选择一种数据类型来平衡数值精度、性能和生成的代码大小,同时考虑嵌入式目标硬件的特性。

    请注意

    累加器内部规则倾向于更高的数值精度,可能是以生成的代码效率较低为代价的。要获得输出的相同精度,请将输出数据类型设置为继承:继承与累加器相同

    请注意

    如果输入是小于单精度的浮点数据类型,则继承:通过内部规则继承的设置决定输出数据类型继承小于单精度的浮点输出类型配置参数。当编码数据类型所需的位数小于编码单精度数据类型所需的32位时,数据类型小于单精度。例如一半int16比单一精度小。

  • 继承:保留MSB- 金宝appSimulink选择一种数据类型来维护整个操作范围,然后将输出的精度降低到适合嵌入式目标硬件的大小。

    提示

    要获得更有效的生成代码,请设置蓄电池数据类型继承:通过内部规则继承,并取消选择整数溢出饱和参数。

    此规则不会产生溢出。

  • 继承:保留LSB–S金宝appimulink选择的数据类型可保持操作精度,但如果完整类型不适合嵌入式目标硬件,则会缩小范围。

    提示

    要获得更有效的生成代码,请设置蓄电池数据类型继承:通过内部规则继承,并取消选择整数溢出饱和参数。

    该规则可能会产生溢出。

    如果更改嵌入式目标设置,则这些内部规则选择的数据类型可能会更改。软件并不总是能够同时优化代码效率和数值精度。如果规则不能满足您对数字精度或性能的具体需求,请使用以下选项之一:

    • 显式指定输出数据类型。

    • 使用简单的选择继承:与第一个输入相同

    • 显式指定默认数据类型,例如fixdt(1, 32岁,16)然后使用定点工具为模型提出数据类型。有关更多信息,请参见fxptdlg(定点设计师)

    • 要指定自己的继承规则,请使用继承:通过反向传播继承然后使用数据类型传播块。如何使用此块的示例可在信号属性库中找到数据类型传播示例块。

  • 继承:通过反向传播继承-使用驱动块的数据类型。

  • 继承:与第一个输入相同—使用第一个输入信号的数据类型。

  • 继承:继承与累加器相同—使用累加器的数据类型。

编程使用

块参数:OutDataTypeStr
类型:字符向量
:继承:通过内部规则继承|“继承:保持最高有效位”|继承:保持LSB的|“继承:通过反向传播继承”“继承:与第一次输入相同”|'继承:与累加器相同'|“双”|“单一”|“一半”|“int8”|‘uint8’|“int16”|“uint16”“int32”|“uint32”|“int64”|“uint64”|‘fixdt(1,16)’|‘fixdt(1,16,0)’|“fixdt(1, 16日2 ^ 0,0)”|“< >数据类型表达”
默认的:“继承:通过内部规则继承”

选择此选项可根据定点工具和定点顾问的更改锁定此块的数据类型设置。有关更多信息,请参见锁定输出数据类型设置(定点设计师)

编程使用

块参数:LockScale
价值观:“关”|“开”
默认值:“关闭”

指定定点操作的舍入模式。有关详细信息,请参阅舍入(定点设计师)

块参数总是舍入到最接近的可表示值。要控制块参数的舍入,请使用MATLAB舍入函数在掩码字段中输入表达式。

编程使用

块参数:RndMeth
类型:特征向量
价值观:'天花板' | '收敛' | '地板' | '最近' | 'Round' | '最简单' | '零'
默认值:“地板”

指定溢出是否饱和或缠绕。

行动 基本原理 对溢流的影响 例子

选择此复选框().

您的模型可能存在溢出,您希望在生成的代码中显示饱和保护。

溢出会饱和到数据类型所能表示的最小值或最大值。

的最大值int8(有符号,8位整数)数据类型可以表示为127。任何大于此最大值的块操作结果都会导致8位整数溢出。选中此复选框后,块输出在127处饱和。同样,块输出在最小输出值-128处饱和。

不选择此复选框().

您希望优化生成代码的效率。

您希望避免过度指定块如何处理超出范围的信号。有关更多信息,请参阅排除信号范围误差

溢出将换行为可由数据类型表示的适当值。

的最大值int8(有符号,8位整数)的数据类型可以表示为127。任何大于这个最大值的块操作结果都会导致8位整数溢出。清除复选框后,软件将导致溢出的值解释为int8,这可能会产生意想不到的结果。例如,块结果130(二进制1000 0010)表示为int8,是-126。

选中此复选框时,饱和应用于块上的每个内部操作,而不仅仅是输出或结果。通常,代码生成过程可以检测何时无法溢出。在这种情况下,代码生成器不会生成饱和代码。

编程使用

块参数:饱和积分溢出
类型:特征向量
价值观:“关”|“开”
默认值:“关闭”

块特征

数据类型

布尔||不动点|一半|整数|仅有一个的

直接引线

是的

多维信号

是的

可变大小信号

是的

讨论二阶导数过零检测

没有

扩展能力

C / c++代码生成
使用Simulink®编码器生成C和C++代码™.金宝app

PLC的代码生成
使用Simulink®PLC Coder™生成结构化文本代码。金宝app

定点转换
使用fixed-point Designer™设计和模拟定点系统。

之前介绍过的R2006a