什么是逻辑运算符

数字硬件建模systemverilog-逻辑运算符  
经过几周的更新,sv核心部分用户自定义类型和包内容已更新完毕,接下来就是rtl表达式和运算符。
逻辑运算符 逻辑运算符对其操作数求值,并返回一个值,该值指示求值结果是真还是假(true or false)。例如,运算a && b测试a和b是否都为真,如果两个操作数都为真,则运算符返回真。否则,运算符返回false。
逻辑运算符返回值。systemverilog没有内置的true或false布尔值。相反,逻辑运算符的返回使用逻辑值1’b1(一个一位宽的逻辑l)表示真,1’b0表示假。逻辑运算符还可以返回1’bx,指示仿真无法确定实际逻辑门的评估结果是否为真或假的模糊条件。
判断一个表达式是真是假。要确定操作数是真是假,systemverilog使用以下规则:
如果所有位均为0,则操作数为假 如果所有位均为1,则操作数为真 如果所有位均为x或z,且没有位为1,则操作数未知x 表5-1列出了rtl综合编译器普遍支持的逻辑运算符。
表5-11:rtl建模的逻辑运算符
逻辑求反运算符通常被称为“not运算符”,它是“not true”的缩写。
逻辑运算符通过对每个操作数进行归约or来执行其运算,从而产生一个1位结果。然后对该结果进行求值,以确定其为真还是假。对于not运算符,1位的结果首先被反转,然后求值为真或假。
表5-12和5-13显示了这些逻辑运算符对几个示例值的结果。
表5-12:逻辑and and or运算的示例结果
表5-13:逻辑求反运算的示例结果
逻辑求反运算符(!)和按位反转运算符(~)之间的区别 练习题目《hdlbits: 在线学习 systemverilog(一)-problem 2-6》problem 4
应注意不要混淆逻辑求反运算符(!)以及按位反转运算符(~)。求反运算符对其操作数执行真/假求值,并返回表示真、假或未知结果的1位值。按位反转运算符对操作数的每一位(补码)执行逻辑反转,并返回与操作数相同位宽的值。
在某些操作中,这些操作的结果恰好相同,但在其他操作中,它们返回的值非常不同。当运算符与决策语句一起被错误使用时,这种差异可能导致错误代码。考虑下面的例子:
前面代码片段的最后两行之所以不同,是因为这两个运算符的工作方式不同——逻辑求反运算符(!)通过将两位相加或相减,对2位选择执行真/假计算,然后反转1位结果,按位反转运算符(~)只反转2位选择向量的每一位的值,并返回2位结果。if语句然后对2位向量进行真/假测试,该向量的计算结果为真,因为反转后的值仍有一位设置为1。
最佳实践指南5-1
使用按位反转运算符反转值的位,不要使用按位反转运算符对逻辑求反运算符求反。相反,使用逻辑求反运算符来否定真/假测试的结果。不要使用逻辑求反运算符反转值。
最佳实践指南5-2
仅使用逻辑求反运算符求反来测试标量(1位)值,而不是 对向量执行真/假测试。
如果向量的任何位为1,逻辑运算将返回true,这可能会导致在测试特定位时出现设计错误。计算向量值时,使用等式或关系运算符测试可接受的值。
示例5-7说明了一个小型rtl模型,该模型使用逻辑not、逻辑and和逻辑or运算符。该设计是一个逻辑比较器,如果两个数据值中的任何一个在可配置的值范围内,则设置一个flag。
示例5-7:使用逻辑运算符:当值在某个范围内时设置flag
图5-7显示了示例5-7中的rtl模型综合结果
图5-7:示例5-7的综合结果:逻辑运算符(范围内比较)
不可综合的逻辑运算符 sv-2009增加了两个额外的逻辑运算符,它们是蕴涵和等价运算符,在本文编写时rtl综合编译器通常不支持这些运算符。表5-14列出了这两个运算符的标记和描述。
表5-14:不可综合逻辑运算符

Raspberry Pi WebIOPi IOT—全彩LED圣诞装饰
LED台灯设计集锦—点缀浪漫的私人空间
TTI解读中国高利润潜力市场 聚焦提供顶级零组件
台湾高技 GAOJ-K为何能参加2021年的DMP大湾区工业博览会
虹科Flow如何帮助企业优化数据管道性能
什么是逻辑运算符
新唐科技N79E825单片机简介
电路设计中11个需要注意的事项
日本将在今年完成给全国中小学生每人配备一台电脑计划
脉冲发生器DG645EF通道坏了维修
对话FF91副总裁 2018年肯定会交付
Innodisk与Avalue合作,将AIoT带入台北市
回顾18年AI大赛的内容和介绍
CallerRunsPolicy拒绝策略的相关知识
ESD断路过压保护,ESD产生的高压和高峰值电流会损坏IC
工业5G+边缘计算在电子行业的应用
基于USB2.0与FPGA技术的高速数据采集系统的设计
M16公母插座8芯航空插头
厨房电器产品设计制造企业比依股份发布2022第一季度报告
iOS11正式版已经推送!要不要升级?iOS11正式版支持哪些设备升级?需要注意事项及这些老果粉暂且不必升级