data:image/s3,"s3://crabby-images/93bc7/93bc7148dd7489e61203bf30dde353bb33b831ca" alt="人工智能硬件电路设计基础及应用"
2.3 运算操作符和属性
2.3.1 运算操作符
运算操作符是进行信号、变量等对象运算时不可或缺的。表2.2是VHDL中的运算操作符,共8类。其中,运算操作符类别的序号越大,优先级越高。同类别运算符在运算时具有相同的优先级,不同类别运算符的优先级依据表2.2中的优先级先后运算。
表2.2 VHDL运算操作符
data:image/s3,"s3://crabby-images/9f5d8/9f5d8ea9ccd317f6ff7fd2eee586bfd64defdfdf" alt=""
条件运算符
VHDL条件运算符如表2.3所示。
表2.3 VHDL条件运算符
data:image/s3,"s3://crabby-images/4a222/4a222d013f5cd51d158033824ac86842d265713a" alt=""
运算符??将bit类型的取值‘0’和‘1’与boolean类型的false和true对应转换,一般用在条件表达式中。这个转换运算符也会在库中重载给其他数据类型,例如,ieee库中的std_logic_1164包集将std_ulogic的“1”和“H”转换为true,其他值转换为false。条件运算符一般是隐式的,不会在程序中以代码的形式体现出来。
逻辑运算符
逻辑运算符是执行逻辑运算操作的运算符。VHDL逻辑运算符如表2.4所示。
表2.4 VHDL逻辑运算符
data:image/s3,"s3://crabby-images/d7bb7/d7bb7b83a970a79e7ec3e6d9f7bf088905bfbd02" alt=""
逻辑运算符示例如下。
data:image/s3,"s3://crabby-images/551b6/551b686d5aed8dc7d71b42ebca6f2d76c63bece1" alt=""
关系运算符
关系运算符是判断两个操作数之间的数值关系的运算符。VHDL关系运算符如表2.5所示。
表2.5 VHDL关系运算符
data:image/s3,"s3://crabby-images/4d84c/4d84c3051ab23fe73feea38cbf6bbb381b8ab30e" alt=""
操作符=和/=为所有非文件类型、非保护类型和不包含文件类型、保护类型子元素的复合类型提供数值相等和不相等判断。进行相等操作的两个操作数相等时,表达式返回true,否则返回false;不相等操作与之相反。当且仅当两个同类型的标量类型对象的值完全相同时,两者相等。当且仅当两个同类型的复合类型对象的子元素一一匹配且完全相同时,两者相等。
对于大小比较的运算符,标量类型的对象依据两个操作数的值的大小进行比较。对于标量数组类型,如果左操作数是空数组,右操作数是非空数组,那么左操作数小于右操作数。如果左右操作数都是非空数组,那么就从最高位开始逐位比较。
运算操作符?=、?/=、?<、?<=、?>和?>=是std库和ieee库为bit类型和std_ulogic预定义的匹配操作符。对于bit类型的操作数,这些匹配操作符的运算操作与普通的操作符相同。对于std_ulogic类型的操作数,匹配操作符?=和?<的运算定义如表2.6和表2.7所示,其余的匹配操作符的运算定义可以依此类推。
表2.6 操作符?=运算定义
data:image/s3,"s3://crabby-images/e5e93/e5e9362331b62d05aefbece7687ebd4b43201923" alt=""
续表
data:image/s3,"s3://crabby-images/eb564/eb56491ece78f69984cf0cfa4a0c9582427cd57a" alt=""
表2.7 操作符?<运算定义
data:image/s3,"s3://crabby-images/01a95/01a95875829ddfb547f7ca3f441afc155ee4f7c3" alt=""
移位运算符
移位操作符是对目标对象进行移位操作的运算符。VHDL中的移位操作符如表2.8所示。
表2.8 VHDL移位运算符
data:image/s3,"s3://crabby-images/a86b5/a86b5e0198b93ef63303c189fceb0b6aac9321d7" alt=""
运算符sll和srl实现数据移位,移位产生的空位用‘0’填充。运算符sla实现数据左移,移位结束后将最右端的位复制后填充到空位上;运算符sra则与之相反,实现数据右移,移位结束后,将最左端的位复制后填充到空位上。运算符rol和ror实现数据循环移位,将移出的位依次填充到空位上。
移位运算符的示例如下。
data:image/s3,"s3://crabby-images/20c4a/20c4a1ec32f99053452ebd2ada1a6d74014b77fe" alt=""
加法运算符
VHDL中的加法运算符包括+、-和串联运算符&。VHDL中的加法运算符如表2.9所示。
表2.9 VHDL加法运算符
data:image/s3,"s3://crabby-images/6eefe/6eefe4eb83a2460ca3d25f4f122b275f06f99068" alt=""
运算符+和-的操作为常规的数学加减操作。串联运算符的位移为数组类型定义的操作符,用于数据的拼接。串联运算符的示例如下。
data:image/s3,"s3://crabby-images/0137b/0137b57a333e3a9fff082d9e5be4b0599053de30" alt=""
data:image/s3,"s3://crabby-images/2e437/2e437f6c29ca379429f523c1b285f033e2623ef4" alt=""
标志运算符
标志运算符分别表示标识和取反的+和-。VHDL标志运算符如表2.10所示。
表2.10 VHDL标志运算符
data:image/s3,"s3://crabby-images/f9dd3/f9dd35ad0e0cee41705be3de3b8d68b8bb1c9e02" alt=""
标志运算符的示例如下。
data:image/s3,"s3://crabby-images/71146/711466e64b942de8b36c79482a8785ebce12f66f" alt=""
乘法运算符
VHDL中的乘法运算符如表2.11所示,包括*、/、mod和rem,分别表示乘法、除法、取模和取余4种操作。
表2.11 VHDL乘法运算符
data:image/s3,"s3://crabby-images/6b5a7/6b5a7dc141bec976b7e2ef6c5542d46c80d25adc" alt=""
运算符*、/对任意整数类型和浮点类型有常规的算术操作。对于整数类型,除法运算是整除运算,运算结果会舍去小数部分转换为整数类型。运算符mod和rem针对任意的整数类型实现取模和取余操作。
VHDL乘法运算符对物理类型的定义,如表2.12所示。
表2.12 VHDL乘法运算符对物理类型的定义
data:image/s3,"s3://crabby-images/375fa/375fae9382bcc2782559355bb803f4440b746760" alt=""
乘法运算符的示例如下。
data:image/s3,"s3://crabby-images/05ecb/05ecb0d738a1df3e70702f3babdba67d87784b37" alt=""
data:image/s3,"s3://crabby-images/adc3e/adc3ee0697c3a6c85deef88250cdc2be464ec7c7" alt=""
其他运算符
VHDL中还有两个操作符,不属于以上分类,如表2.13和表2.14所示。
表2.13 VHDL运算符abs
data:image/s3,"s3://crabby-images/9907b/9907b3c0139f73b9fada484aaf43f492d3bc0cc8" alt=""
表2.14 VHDL运算符**
data:image/s3,"s3://crabby-images/97c02/97c027480fee83adb45bb774fdf100cd173073fc" alt=""
运算符abs和**的示例如下。
data:image/s3,"s3://crabby-images/0d366/0d3661773a7603a4d940f52936e0da9d1940ce24" alt=""
2.3.2 属性
VHDL中的属性可以从指定的对象中获得相关的数据和信息,使得VHDL代码更加灵活。VHDL中预定义的属性可以划分为7类,即数据类型和对象的属性、数组类型的属性、信号的属性、命名实体的属性、范围的属性、PSL对象的属性和模式视图的属性。
数据类型和对象的属性
VHDL中的数据类型和对象的属性如表2.15所示。
表2.15 VHDL中的数据类型和对象的属性
data:image/s3,"s3://crabby-images/af6e9/af6e94b6bce8bf0e242ba906e7de48e55d282e46" alt=""
续表
data:image/s3,"s3://crabby-images/c5a03/c5a03ec7a9cca81c79262722ffdbea6cb797c236" alt=""
续表
data:image/s3,"s3://crabby-images/97c60/97c60529251ff53b42db88a97d5e1a13cda0009e" alt=""
续表
data:image/s3,"s3://crabby-images/c6361/c6361ac94ddd94dab6ce2f853b501770ac76b5de" alt=""
数组类型的属性
VHDL中的数组类型的属性如表2.16所示。
表2.16 VHDL中的数组类型的属性
data:image/s3,"s3://crabby-images/c2225/c22254b749f467a1b5a302ee216427155f47a291" alt=""
续表
data:image/s3,"s3://crabby-images/f8359/f8359fe8859e9683045ed745a94ac6b1495657ac" alt=""
信号的属性
VHDL中信号的属性如表2.17所示。
表2.17 VHDL中信号的属性
data:image/s3,"s3://crabby-images/eb5ac/eb5ac9de43a985b139c49f8c418a233f5cf39e99" alt=""
续表
data:image/s3,"s3://crabby-images/fd308/fd3082d95f04f2a17d951f4346cd0eb6e3704819" alt=""
命名实体的属性
VHDL中的命名实体的属性如表2.18所示。
表2.18 VHDL中的命名实体的属性
data:image/s3,"s3://crabby-images/632df/632df086e57534a0622ea2750f4c061f474f271f" alt=""
续表
data:image/s3,"s3://crabby-images/1c1ed/1c1eddf22927fe2bb9dd1e0a82af277329c8f593" alt=""
范围的属性
VHDL中的范围的属性如表2-19所示。
表2-19 VHDL中的范围的属性
data:image/s3,"s3://crabby-images/c2b1d/c2b1d744066ce2585b7f9c05ee1a75ce2bb03208" alt=""
PSL对象的属性
VHDL中的PSL对象的属性如表2.20所示。
表2.20 VHDL中的PSL对象的属性
data:image/s3,"s3://crabby-images/f5bda/f5bda5cfad97a6012a01b5090c354a39e6d5411a" alt=""
模式视图的属性
VHDL中的模式视图的属性如表2.21所示。
表2.21 VHDL中的模式视图的属性
data:image/s3,"s3://crabby-images/62a3c/62a3ccb4182e9b9064a563a793f5e4ef7e5fdae1" alt=""
2.3.3 通用属性
通用属性(generic)是VHDL中定义的静态常规参数,可以在实体、元件等程序段的声明中定义。在通用属性定义的程序段中,通用属性是静态的,是不可更改的。通用属性实现内部参数与外部程序的联系,在元件实例化或者配置声明中可以重新配置参数的值,从而实现程序段的功能多样化,增加代码的灵活性和重用性。通用属性的语法结构如下。
data:image/s3,"s3://crabby-images/bc648/bc64837d4f0da56299120d70cafc342c3faac128" alt=""
其中,parameter_name是参数的名称;parameter_type是参数的类型;parameter_value是参数的默认值。在通用属性实例化时,如果没有重新配置参数的值,参数将保持默认值不变。
例2.3 通用属性示例
下方代码实现了2输入的通用门,定义通用参数gate_type是实现在多种基本逻辑门中切换。在实例化元件或配置声明时,重新配置gate_type的值,可以将元件或者实体的功能切换为目标逻辑门。
data:image/s3,"s3://crabby-images/64b15/64b1588269050690e2faa3389020e9f00fc0f137" alt=""
data:image/s3,"s3://crabby-images/47cfd/47cfdcbadbb953dca4cbf10af108f2077781989e" alt=""