MATLAB 帮助中心
验证值是实数
mustBeReal(value)
如果 value 不是实数,mustBeReal(value) 将抛出错误。此函数不返回值。
value
mustBeReal 调用以下函数来确定输入是否为实数:
mustBeReal
isreal
支持的类:重载 isreal 的所有数值类、logical 和 MATLAB® 类。
logical
此函数忽略输入参量中的空值。因此,当属性或函数参量值为空时,不会抛出错误。
示例
全部折叠
使用 mustBeReal 验证输入是实数。
验证计算结果是实数。
x = -2:2; z = x.^exp(-x.^2); mustBeReal(z)
Value must be real.
值 z 为复数。
z
此类将 Prop1 的值限制为实数值。
Prop1
classdef MyClass properties Prop1 {mustBeReal} end end
创建一个对象,并向其属性赋值。
x = -2:0.1:2; obj = MyClass; obj.Prop1 = x.^exp(-x.^2);
Error setting property 'Prop1' of class 'MyClass'. Value must be real.
当您向属性赋值时,MATLAB 会使用赋给属性的值调用 mustBeReal。mustBeReal 将引发错误,因为赋给 Prop1 的值为复数。
此函数将输入参量限制为标量实数值。
function r = mbReal(z) arguments z (1,1) {mustBeReal} end r = randi(9,z); end
使用复数值调用该函数会导致 mustBeReal 抛出错误。
x = -1; z = x.^exp(-x.^2); r = mbReal(z);
Error using mbReal (line 3) r = mbReal(z); ^ Invalid argument at position 1. Value must be real.
要验证的值,指定为标量或由以下任一类型的值组成的数组:
logical、char 或数值类
char
实现 isreal 的 MATLAB 类
其他数据类型会导致错误。
数据类型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | logical | char 复数支持: 是
single
double
int8
int16
int32
int64
uint8
uint16
uint32
uint64
mustBeReal 用于属性和函数参量验证。
全部展开
mustBeReal 函数完全支持 GPU 数组。要在 GPU 上运行该函数,请将输入数据指定为 gpuArray (Parallel Computing Toolbox)。有关详细信息,请参阅在 GPU 上运行 MATLAB 函数 (Parallel Computing Toolbox)。
gpuArray
此函数完全支持分布式数组。有关详细信息,请参阅使用分布式数组运行 MATLAB 函数 (Parallel Computing Toolbox)。
在 R2017a 中推出
arguments | isreal | mustBeFinite | mustBeNonNan | mustBeSparse
arguments
mustBeFinite
mustBeNonNan
mustBeSparse
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
选择网站
选择网站以获取翻译的可用内容,以及查看当地活动和优惠。根据您的位置,我们建议您选择:。
您也可以从以下列表中选择网站:
如何获得最佳网站性能
选择中国网站(中文或英文)以获得最佳网站性能。其他 MathWorks 国家/地区网站并未针对您所在位置的访问进行优化。
美洲
欧洲
亚太
联系您当地的办事处