Verilog语法——移位运算符“>>“和“>>>“的细节

Verilog中的移位运算符

“>>”

  不区分无符号和有符号移位,即对有符号和无符号数进行">>"操作结果一致。

  • 对有符号数使用">>“进行右移,高位补"0”;
  • 对无符号数使用">>“进行右移,高位补"0”;

“>>>”

  区分无符号和有符号移位,即对有符号和无符号数进行">>>"操作结果不一样。

  • 对有符号数使用">>>"进行右移,高位补符号位;
  • 对无符号数使用">>>“进行右移,高位补"0”;

测试代码

module tb ();reg signed [7:0] a;reg [7:0] b;reg [7:0] c_signed;      //有符号移位reg [7:0] d_unsigned;    //无符号移位initial begina = 8'b1111_0000;b = 8'b1111_0000;c_signed = 'd0;d_unsigned = 'd0;#10 c_signed = a <<< 1'b1;d_unsigned  = b <<< 1'b1;#10 c_signed = a >>> 1'b1;d_unsigned  = b >>> 1'b1;#10 c_signed = a  << 1'b1;d_unsigned  = b  << 1'b1;#10 c_signed = a  >> 1'b1;d_unsigned  = b  >> 1'b1;// 拼接符得到的数为无符号数,>>>和>>结果一致#10 c_signed   = {4'b1111,4'b0000} >>> 1;d_unsigned = {4'b1111,4'b0000} >> 1;// 需要保存给有符号变量a,再进行移位操作#10 a = {4'b1111,4'b0000};c_signed   = a >>> 1;d_unsigned = a >> 1;#10 $finish;endendmodule

  仿真波形如下
请添加图片描述

  综上所述,需要注意的是">>>“和”>>“,两者区分有符号和无符号变量,对于有符号数,”>>>“保留符号位右移,”>>“不保留符号位右移。
  此外,用拼接符得到的数如{4’b1111,4’b0000}为无符号数,”>>>“和”>>“效果一致,如果需要保留符号位需要将{4’b1111,4’b0000}复制给一个有符号数,再进行”>>>"移位。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/647597.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Springboot自定义全局异常处理

目录 ErrorController ControllerAdviceExceptionHandler ErrorController BasicErrorController是Spring Boot中默认提供的用于处理基本错误的控制器。它实现了ErrorController接口&#xff0c;用于处理在应用程序中发生的错误&#xff0c;例如404 Not Found等。此种方式是…

Vp9解码方式概述 -- Parsing Process

Vp9解码方式概述 – Parsing Process 本文是对vp9协议第9章&#xff0c;解析字符串函数的一个梳理&#xff0c;主要对几种解析类型&#xff08;Type&#xff09;的流程进行梳理 目录 Vp9解码方式概述 -- Parsing Process1. 如何解码视频&#xff1f;2. f(n)3. 布尔解码器Boole…

Spring5学习笔记

Spring5 框架概述IOC(Inversion Of Control)IOC基本过程:IOC接口(BeanFactory)IOC接口实现类IOC操作Bean管理一、什么是Bean管理?二、什么是DI?三、Bean管理的两种实现方式1.基于XML配置文件方式实现基于XML方式创建对象基于XML方式注入属性常规属性注入特殊属性值的注入…

【kubernets】kubelet证书单独更新

前言说明 接上一篇文章https://blog.csdn.net/margu_168/article/details/132584109关于kubernets中的证书管理。本篇文章将单独说明一下kubelet的证书更新。在1.19.16版本中&#xff0c;默认情况下使用 kubeadm alpha certs renew all 不能更新kubelet的证书&#xff0c;其他…

对数似然函数:为什么在统计学和机器学习中它如此重要?

在统计学和机器学习领域&#xff0c;对数似然函数常常扮演着关键的角色。本文将深入探讨对数似然函数的优势&#xff0c;为什么在实际问题中更经常使用对数似然函数而非原始似然函数。 1. 什么是对数似然函数&#xff1f; 似然函数是一个在统计学中描述参数的函数&#xff0c;…

pcl+vtk(十四)vtkCamera相机简单介绍

一、vtkCamera相机 人眼相当于三维场景下的相机&#xff0c; VTK是用vtkCamera类来表示三维渲染场景中的相机。vtkCamera负责把三维场景投影到二维平面&#xff0c;如屏幕、图像等。 相机位置&#xff1a;即相机所在的位置&#xff0c;用方法vtkCamera::SetPosition()设置。 相…

【C语言刷题系列】水仙花数的打印及进阶

1.水仙花数问题 水仙花数&#xff08;Narcissistic number&#xff09;也被称为超完全数字不变数&#xff08;pluperfect digital invariant, PPDI&#xff09;、自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数&#xff08;Armstrong number&#xff09; 水仙花数是指一个 3 位数&a…

x-cmd pkg | sqlite3 - 轻量级的嵌入式关系型数据库

目录 简介首次用户 技术特点竞品和相关产品sqlite 与 x-cmd进一步阅读 简介 sqlite3 是一个轻量级的文件数据库&#xff0c;体积非常小&#xff0c;提供简单优雅而功能强大的 sql 化的数据查询。 通常情况下&#xff0c;sqlite 指的是 SQLite 2.x 版本&#xff0c;而 sqlite3 …

【K8S 云原生】K8S的安全机制

目录 一、K8S安全机制概述 1、概念 2、请求apiserver资源的三个步骤&#xff1a; 一、认证&#xff1a;Anthentcation 1、认证的方式&#xff1a; 1、HTTP TOKEN&#xff1a; 2、http base&#xff1a; 3、http证书&#xff1a; 2、认证的访问类型&#xff1a; 3、签发…

网络安全B模块(笔记详解)- Linux操作系统渗透提权

1. 使用渗透机对服务器信息收集,并将服务器中SSH服务端口号作为flag提交; 2. 使用渗透机对服务器信息收集,并将服务器中主机名称作为flag提交; 3. 使用渗透机对服务器信息收集,并将服务器中系统内核版本作为flag提交; 4. 使用渗透机对服务器管理员提权,并将服务器中r…

C# 使用AutoMapper实现类映射

写在前面 AutoMapper是一个用于.NET中简化类之间的映射的扩展库&#xff1b;可以在执行对象映射的过程&#xff0c;省去的繁琐转换代码&#xff0c;实现了对DTO的快速装配&#xff0c;有效的减少了代码量。 通过NuGet安装&#xff0c;AutoMapper&#xff0c; 由于本例用到了D…

pyspark.sql.types 中的类型有哪些

对 pyspark.sql.types 中的类型做个记录 1、首先正常使用的时候&#xff0c;我们需要引用他们&#xff1a; from pyspark.sql.types import MapType,StringType # 或者 from pyspark.sql.types import *PySpark SQL TYPES是PySpark模型中的一个类&#xff0c;用于定义PySpark数…

小学信息科技Python课程第3课:变量与颜色

一、变量 变量是计算机内存中的一块区域&#xff0c;存储规定范围内的值&#xff0c;值可以改变&#xff0c;通俗的说变量就是给数据起个名字。 1️⃣变量命名规则 变量名由字母、数字、下划线组成 数字不能开头 不可以使用关键字 简短且具有描述性 2️⃣变量的赋值 每个变量在…

【WPF.NET开发】WPF中的双向功能

本文内容 FlowDirectionFlowDocumentSpan 元素非文本元素的 FlowDirection数字替换 与其他任何开发平台不同&#xff0c;WPF 具有许多支持双向内容快速开发的功能&#xff0c;例如&#xff0c;同一文档中混合了从左到右和从右到左的数据。 同时&#xff0c;WPF 也为需要双向功…

【知识---NVIDIA这是一个什么公司】

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言图形处理单元&#xff08;GPU&#xff09;&#xff1a;人工智能&#xff08;AI&#xff09;和深度学习&#xff1a;自动驾驶技术&#xff1a;游戏&#xff1a;数…

中移(苏州)软件技术有限公司面试问题与解答(4)—— virtio所创建的设备2

接前一篇文章&#xff1a;中移&#xff08;苏州&#xff09;软件技术有限公司面试问题与解答&#xff08;4&#xff09;—— virtio所创建的设备1 在上一篇文章中&#xff0c;对于面试所提出的问题“virtio会创建哪些设备&#xff1f;”&#xff0c;有了初步答案&#xff0c;即…

单调性的应用

1单调性 应用场景&#xff1a;常应用于双指针的进一步优化问题中含义&#xff1a;针对指针 i 1 > i i1>i i1>i一定有 j 1 > j j1>j j1>j或者 j 1 < j j1<j j1<j这样我们就可以利用该性质对算法进行进一步优化&#xff0c;避免一些不必要的遍历…

微软人工智能办公AI工具 Copilot Pro 11项 Copilot 功能

Copilot&#xff08;曾用名 Bing Chat 和 Bing Chat Enterprise&#xff09;在此期间成为了许多用户的日常AI伴侣&#xff0c;并在正式发布后将继续为用户提供AI驱动的网络聊天体验。 微软Copilot官方网址链接&#xff1a;Microsoft Copilot: 你的日常 AI 助手 Copilot详情&am…

基于springboot+vue旅游网站

摘要 旅游网站的开发是一个综合性的项目&#xff0c;涉及到前端和后端的技术&#xff0c;而基于Spring Boot和Vue.js的组合是一种常见的选择&#xff0c;因为它们可以很好地配合&#xff0c;提供高效且现代化的开发体验。首先&#xff0c;我们使用Spring Boot作为后端框架。Spr…

centos系统安装Ward服务器监控工具

简介 Ward是一个简约美观多系统支持的服务器监控面板 安装 1.首先安装jdk yum install java-1.8.0-openjdk-devel.x86_64 2.下载jar wget 3.启动 java -jar ward-1.8.8.jar 体验 浏览器输入 http://192.168.168.110:4000/ 设置服务名设置为:myserver 端口号:5000 点击…