当前位置: 首页 > news >正文

【AXI总线专题】AXI-FULL-Master

【AXI总线专题】AXI-FULL-Master

  • 1.axi-full概述
  • 2.信号定义
  • 3.测试
  • 4.仿真波形
  • 5.附录
    • clogb2函数
    • axi4中的一些参数解释
    • wishbone总线
  • 6.工程文件

概述
参考文档:
《3-2-03米联客2022版AXI4总线专题-20211123.pdf》
《IHI0022E_amba_axi_and_ace_protocol_spec.pdf》

1.axi-full概述

和axi-lite差不多,基本信号都差不多,就是多了几个信号。主要是因为axi-full支持突发传输,axi4支持最大256次的突发传输。

2.信号定义

在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述
在这里插入图片描述

3.测试

测试工程通过手动编写一个axi-full-master的模块,和slave进行通信,测试并查看仿真波形。其中的slave模式使用官方直接生产的模块。
如下图所示,一共是两个模块,一个master一个slave。我们直接把这两个模块添加到block design中,省去了例化一个个填信号的步骤。然后直接在tb文件中直接例化block design就可以了。
在这里插入图片描述
tb文件示例代码:

module sim_tb_top();reg clk,rst;initial beginrst = 0;#100;@(posedge clk)rst = 1;
endalways beginclk = 0;#10;clk = 1;#10;
end
/*直接例化的block design,就一个时钟和一个复位信号,其他都是内部信号*/
system_wrapper system_wrapper_u0(.M_AXI_ACLK_0     (clk)  ,.M_AXI_ARESETN_0  (rst));endmodule

4.仿真波形

如下图所示,图中列出了写地址,写数据,写响应的时序波形。
在写地址过程中,因为是突发传输,这个过程只需要写入突发传输的起始地址,以及突发长度就行,因此这里的valid和ready信号持续的信号周期很短。
在写数据过程中,数据一直处于突发传输过程,此时的valid和ready信号需要一直保持为高电平。
last信号是和最后一个数据对齐,也就是说,在传输最后一个数据的过程中,就应该将last信号拉高,表明此时正在传输最后一个数据。
写响应阶段,是在所有数据都写入完成后,才产生valid和ready信号。
在这里插入图片描述

下图是读数据阶段。
程序设计的流程是先写完成后再读数据。因此在上面写响应完成后,开始一段读操作。读地址阶段的时序和写地址的时序一样。重点看下读数据阶段。
master将M_AXI_RREADY拉高后,就可以接收slave的数据了。接着slave拉高M_AXI_RVALID信号,可以看到,slave并不是一直拉高valid信号的,而是呈现脉冲式的拉高,所以接收到的数据中间都会有无效数据,就是这里的0。当然这里的0会被忽略,因为有效数据是在valid和ready同时有效的时候才正确被接收。
同样,last信号也是在接收最后一个数据的时候同时被拉高。
在这里插入图片描述
下图是整个程序流程的总览,即实现的写数据读数据的不断循环。整个过程读写都可以正常进行。
在这里插入图片描述

5.附录

clogb2函数

功能:位宽计算函数
例如,要将8个数据存到fifo中,那么fifo的深度是8,就是从0~7,这里的最大值是7,对应的就是3‘b111;地址位宽就是3,这个函数就用来计算这个3。
可以应用的场景,比如在逻辑中需要点亮LED灯,每隔500ms翻转一次,常规操作如下:

	// Add user logic here//ref_clk=50M cnt_number=25,000,000
reg [24:0] cnt_500ms;
always@(posedge clk or negedge rst)if(!rst)cnt_500ms <= 'b0;else if(cnt_500ms == 'd24_999_999)cnt_500ms <= 1'b0;elsecnt_500ms <= cnt_500ms + 1'b1;always @(posedge clk or negedge rst) beginif(!rst)led <= 1'b1;else if(cnt_500ms == 'd24_999_999)led <= ~led;end

如上所示,这里需要定义一个cnt_500ms的变量,用来计数,通过计算,我们得知,这个变量需要计数25000000次才是500ms,那么这个变量在定义的时候就要确定它的位宽,也就是上面计算的[24:0],就是25bit。通常都是要借助程序员计算器来计算这个位宽值。
现在有了这个函数就可以直接使用这个函数来计算了
示例如下:

reg [clogb2(24999999):0] cnt_500ms;

参考链接:
Verilog定义计算位宽的函数clogb2

axi4中的一些参数解释

参考链接:[axi][学习笔记]s_axi_awlen/s_axi_awsize 和s_axi_wdata关系
这个里面解释了比较容易混淆的awlen和awsize等的关系。
M_AXI_AWLEN:axi-full是突发传输的模式,一次突发传输可以传输多个数据,个数为1~256;最多传输256个数据,这个值就是用来设置一次突发传输的数据个数。
M_AXI_AWSIZE:突发传输过程中,每个传输的数据的大小(以字节为单位)。这是一个3位的信号。支持的数据的大小为1、2、4、8、16、32、64、128;那么对应关系就是
000:1
001:2
010:4
011:8
100:16
101:32
110:64
111:128
这个值和数据位宽是有关系的,数据位宽就是下面显示的M_AXI_DATA_WIDTH;假设数据位宽是128,那么传输一个128bit的数据就是传输16个字节,也就是突发传输过程中的数据的大小是16字节,对应到M_AXI_AWSIZE的值就是100;
使用举例:

parameter integer C_M_AXI_DATA_WIDTH = 32;
assign M_AXI_AWSIZE = clogb2((C_M_AXI_DATA_WIDTH/8)-1);//这里就是使用位宽计算公式,计算出来是010;对应上面就是4字节,也就是32位的位宽

M_AXI_WDATA:这个是需要传输的数据,这个数据在定义的时候是需要定义位宽的,比如

output  wire [M_AXI_DATA_WIDTH-1 : 0] 	    M_AXI_WDATA			,

wishbone总线

参考链接:CPU设计实战-Wishbone总线接口

为什么有个逻辑工程中会使用到axi_to_wishbone?我们分析一下下面这个模块,就是将axi总线转换成wishbone总线,目的就是为了简化接口的操作,因为axi总线的接口比较多。

module axi_to_wishbone(input                   aclk,         input                   aresetn,//wishbone signalsoutput reg [31:0]		wb_addr_o,input       [31:0]      wb_dat_i,output reg	[31:0]		wb_dat_o,output reg			    wb_we_o,//读写使能信号,低表示读操作,高表示写操作output reg			    wb_stb_o,//总线选用信号,有效时代表发起一次总线操作output                  wb_cyc_o,//总线周期信号,代表总线正在被占用,在总线使用时须持续有效input                   wb_ack_i,//操作结束信号,操作结束给一个有效位//axi signals      input  [31:0]           m_axi_araddr, input  [1:0]            m_axi_arburst,input  [3:0]            m_axi_arcache,input  [7:0]            m_axi_arlen,  input  [0:0]            m_axi_arlock, input  [2:0]            m_axi_arprot, input  [3:0]            m_axi_arqos,  output reg	            m_axi_arready,input  [3:0]            m_axi_arregion,input  [2:0]            m_axi_arsize, input 		    	    m_axi_arvalid,input  [31:0]           m_axi_awaddr, input  [1:0]            m_axi_awburst,input  [3:0]            m_axi_awcache,input  [7:0]            m_axi_awlen,  input  [0:0]            m_axi_awlock, input  [2:0]            m_axi_awprot, input  [3:0]            m_axi_awqos,  output reg              m_axi_awready,input  [3:0]            m_axi_awregion,input  [2:0]            m_axi_awsize, input                   m_axi_awvalid,input                   m_axi_bready, output [1:0]            m_axi_bresp,  output reg              m_axi_bvalid, output reg [31:0]       m_axi_rdata,  output reg              m_axi_rlast,  input                   m_axi_rready, output [1:0]            m_axi_rresp,  output reg              m_axi_rvalid, input  [31:0]           m_axi_wdata,  input                   m_axi_wlast,  output reg             m_axi_wready, input  [3:0]            m_axi_wstrb,  input                   m_axi_wvalid  );
axi_to_wishbone host_to_wb(//clock and reset.aclk                    (sys_clk_i),.aresetn                 (sys_rst_n_i),//wishbone signals                          .wb_addr_o               (host_wb_addr),       .wb_dat_i                (host_wb_dat_o ),     .wb_dat_o                (host_wb_dat_i ),     .wb_we_o                 (host_wb_we),         .wb_stb_o                (host_wb_stb),        .wb_cyc_o                (host_wb_cyc),        .wb_ack_i                (host_wb_ack),        //AXI signals                                 .m_axi_araddr            (reg_m_axi_araddr  ),.m_axi_arburst           (reg_m_axi_arburst ),.m_axi_arcache           (reg_m_axi_arcache ),.m_axi_arlen             (reg_m_axi_arlen   ),.m_axi_arlock            (reg_m_axi_arlock  ),.m_axi_arprot            (reg_m_axi_arprot  ),.m_axi_arqos             (reg_m_axi_arqos   ),.m_axi_arready           (reg_m_axi_arready ),.m_axi_arregion          (reg_m_axi_arregion),.m_axi_arsize            (reg_m_axi_arsize  ),.m_axi_arvalid           (reg_m_axi_arvalid ),.m_axi_awaddr            (reg_m_axi_awaddr  ),.m_axi_awburst           (reg_m_axi_awburst ),.m_axi_awcache           (reg_m_axi_awcache ),.m_axi_awlen             (reg_m_axi_awlen   ),.m_axi_awlock            (reg_m_axi_awlock  ),.m_axi_awprot            (reg_m_axi_awprot  ),.m_axi_awqos             (reg_m_axi_awqos   ),.m_axi_awready           (reg_m_axi_awready ),.m_axi_awregion          (reg_m_axi_awregion),.m_axi_awsize            (reg_m_axi_awsize  ),.m_axi_awvalid           (reg_m_axi_awvalid ),.m_axi_bready            (reg_m_axi_bready  ),.m_axi_bresp             (reg_m_axi_bresp   ),.m_axi_bvalid            (reg_m_axi_bvalid  ),.m_axi_rdata             (reg_m_axi_rdata   ),.m_axi_rlast             (reg_m_axi_rlast   ),.m_axi_rready            (reg_m_axi_rready  ),.m_axi_rresp             (reg_m_axi_rresp   ),.m_axi_rvalid            (reg_m_axi_rvalid  ),//block design中的glbreg_m_axi这个slave接口的地址已经分配好了,在sdk中使用Xil_Out();函数就可以和这个slave通信了。.m_axi_wdata             (reg_m_axi_wdata   ),//这个从外面(block_design中)写进来的数据,即glbreg_m_axi_wdata,这个axi是从机;写进来后给axi_to_wishbone,转换到成host_wb_dat_i,从axi_to_wishbone模块输出.m_axi_wlast             (reg_m_axi_wlast   ),//再给wb_bus_switch;在wb_bus_switch中,根据不同的通道地址,将这个数据再转给ch1_wb_dat_o~ch5_wb_dat_o输出出去。ch1_wb_dat_o对应的是glbreg_wb_dat_i;.m_axi_wready            (reg_m_axi_wready  ),//glbreg_wb_dat_i这个数据再进入到global_register这个模块中,在这个模块中,将这个数据赋值给不同的寄存器,用来配置逻辑的工作模式。.m_axi_wstrb             (reg_m_axi_wstrb   ),.m_axi_wvalid            (reg_m_axi_wvalid  )//同上,wb_bus_switch中的ch1_wb_dat_i~ch5_wb_dat_i先传给host_wb_dat_o;然后这个数据再进入到axi_to_wishbone的wb_dat_i//在axi_to_wishbone中传给m_axi_rdata,就是axi从机的输出数据接口,给axi主机读。); 

6.工程文件

相关文章:

【AXI总线专题】AXI-FULL-Master

【AXI总线专题】AXI-FULL-Master 1.axi-full概述2.信号定义3.测试4.仿真波形5.附录clogb2函数axi4中的一些参数解释wishbone总线 6.工程文件 概述 参考文档&#xff1a; 《3-2-03米联客2022版AXI4总线专题-20211123.pdf》 《IHI0022E_amba_axi_and_ace_protocol_spec.pdf》 1.a…...

风车OVF镜像:解放AI开发限制的Ubuntu精简系统

风车OVF镜像&#xff1a;解放AI开发限制的Ubuntu精简系统 AI白嫖续杯一站式-风车ovf AI白嫖续杯一站式解决-风车ovf 前言 作为一名AI开发者&#xff0c;我经常在Windows和Linux环境之间切换开发。然而&#xff0c;Windows平台上的各种免费版限制逐渐成为我工作效率的瓶颈。在寻…...

降低60.6%碰撞率!复旦大学地平线CorDriver:首次引入「走廊」增强端到端自动驾驶安全性

导读 复旦大学&地平线新作-CorDriver: 首次通过引入"走廊"作为中间表征&#xff0c;揭开一个新的范式。预测的走廊作为约束条件整合到轨迹优化过程中。通过扩展优化的可微分性&#xff0c;使优化后的轨迹能无缝地在端到端学习框架中训练&#xff0c;从而提高安全…...

查看购物车

一.查看购物车 查看购物车使用get请求。我们要查看当前用户的购物车&#xff0c;就要获取当前用户的userId字段进行条件查询。因为在用户登录时就已经将userId封装在token中了&#xff0c;因此我们只需要解析token获取userId即可&#xff0c;不需要前端再传入参数了。 Control…...

11 配置Hadoop集群-免密登录

一、复习导入 前面的课程中我们在虚拟机上安装并测试使用了hadoop的示例程序wordcount&#xff0c;并且在准备好了集群的同步工具&#xff0c;那接下来&#xff0c;我们就可去配置hadoop集群了。 二、授新 &#xff08;一&#xff09;认识ssh命令 SSH&#xff08;Secure Shell…...

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】金融风控分析案例-10.1 风险数据清洗与特征工程

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 PostgreSQL金融风控分析案例&#xff1a;风险数据清洗与特征工程实战一、案例背景&#xff1a;金融风控数据处理需求二、风险数据清洗实战&#xff08;一&#xff09;缺失值…...

《AI大模型应知应会100篇》第60篇:Pinecone 与 Milvus,向量数据库在大模型应用中的作用

第60篇&#xff1a;Pinecone与Milvus&#xff0c;向量数据库在大模型应用中的作用 摘要 本文将系统比较Pinecone与Milvus两大主流向量数据库的技术特点、性能表现和应用场景&#xff0c;提供详细的接入代码和最佳实践&#xff0c;帮助开发者为大模型应用选择并优化向量存储解…...

如何在通义灵码里使用 MCP 能力?

通义灵码编程智能体支持 MCP 工具使用&#xff0c;根据用户需求描述&#xff0c;通过模型自主规划&#xff0c;实现 MCP 工具调用&#xff0c;并深度集成国内最大的 MCP 中文社区——魔搭 MCP 广场&#xff0c;涵盖开发者工具、文件系统、搜索、地图等十大热门领域 2400 MCP 服…...

关于mac配置hdc(鸿蒙)

关于mac配置hdc(鸿蒙) 在最开始配置的hdc -v时候老是出现格式不匹配 于是乎在网上找官网也不行&#xff0c;最后在csdn上找到了这篇文章Mac配置hdc才有的头绪 环境变量的问题 自己做一个简单的总结 首先在访达里面打开ide 打开之后输入下面的命令&#xff0c;一步一步的找…...

几何_平面方程表示_点+向量形式

三维平面方程可以写成&#xff1a; π : n ⊤ X d 0 \boxed{\pi: \mathbf{n}^\top \mathbf{X} d 0} π:n⊤Xd0​ &#x1f4d0; 一、几何直观解释 ✅ 平面是“法向量 平面上一点”定义的集合 一个平面可以由&#xff1a; 一个单位法向量 n ∈ R 3 \mathbf{n} \in \mat…...

iOS safari和android chrome开启网页调试与检查器的方法

手机开启远程调试教程&#xff08;适用于 Chrome / Safari&#xff09; 前端移动端调试指南&#xff5c;适用 iPhone 和 Android&#xff5c;WebDebugX 出品 本教程将详细介绍如何在 iPhone 和 Android 手机上开启网页检查器&#xff0c;配合 WebDebugX 实现远程调试。教程包含…...

Matlab 模糊pid控制的永磁同步电机PMSM

1、内容简介 Matlab 226-模糊pid控制的永磁同步电机PMSM 可以交流、咨询、答疑 2、内容说明 略 3、仿真分析 略 4、参考论文 略基于模糊控制的高精度伺服速度控制器的设计与实现_刘京航...

ActiveMQ 高级特性:延迟消息与优先级队列实战(二)

三、优先级队列实战 3.1 优先级队列概念与应用场景 优先级队列是一种特殊的队列&#xff0c;与普通队列按照先进先出&#xff08;FIFO&#xff09;的规则不同&#xff0c;优先级队列中的元素按照其优先级进行排序&#xff0c;在消费消息时&#xff0c;高优先级的消息会优先被…...

ActiveMQ 高级特性:延迟消息与优先级队列实战(一)

引言 在当今的分布式系统开发中&#xff0c;消息中间件扮演着至关重要的角色&#xff0c;而 ActiveMQ 作为一款广泛使用的开源消息中间件&#xff0c;凭借其丰富的特性和良好的性能&#xff0c;深受开发者的青睐。它支持多种消息模型&#xff0c;如点对点和发布 / 订阅&#x…...

动手学深度学习12.4.硬件-笔记练习(PyTorch)

以下内容为结合李沐老师的课程和教材补充的学习笔记&#xff0c;以及对课后练习的一些思考&#xff0c;自留回顾&#xff0c;也供同学之人交流参考。 本节课程地址&#xff1a;31 深度学习硬件&#xff1a;CPU 和 GPU【动手学深度学习v2】_哔哩哔哩_bilibili 本节教材地址&am…...

LAN-402 全国产信号采集处理模块K7-325T(4通道采集)

UD LAN-402全国产化信号处理模块最多支持2通道16bit125Msps的短波采集&#xff08;或2通道14bit250Msps超短波采集&#xff09;、2通道16bit310Msps超短波采集&#xff0c;可选配XC7K325T、XC7K410T、JFM7K325T、JFM7K410T FPGA芯片&#xff0c;对外支持PCIe2.0x8接口、千兆网、…...

关于大语言模型的困惑度(PPL)指标优势与劣势

1. 指标本身的局限性 与人类感知脱节&#xff1a; PPL衡量的是模型对词序列的预测概率&#xff08;基于交叉熵损失&#xff09;&#xff0c;但低困惑度未必对应高质量的生成结果。例如&#xff1a; 模型可能生成语法正确但内容空洞的文本&#xff08;PPL低但质量差&#xff09;…...

[Spring AOP 8] Spring AOP 源码全流程总结

Spring AOP总结 更美观清晰的版本在&#xff1a;Github 前面的章节&#xff1a; [Spring AOP 1] 从零开始的JDK动态代理 [Spring AOP 2] 从零开始的CGLIB动态代理 [Spring AOP 3] Spring选择代理 [Spring AOP 4] Spring AOP 切点匹配 [Spring AOP 5] 高级切面与低级切面&#…...

通信网络编程——JAVA

1.计算机网络 IP 定义与作用 &#xff1a;IP 地址是在网络中用于标识设备的数字标签&#xff0c;它允许网络中的设备之间相互定位和通信。每一个设备在特定网络环境下都有一个唯一的 IP 地址&#xff0c;以此来确定其在网络中的位置。 分类 &#xff1a;常见的 IP 地址分为 I…...

支持向量机算法

支持向量机&#xff08;Support Vector Machine&#xff0c;SVM&#xff09;作为机器学习领域中一颗耀眼的明星&#xff0c;凭借其卓越的分类与回归能力&#xff0c;在众多算法中独树一帜。它宛如一位精准的边界守护者&#xff0c;通过巧妙地构建超平面&#xff0c;将不同类别的…...

Redis集群模式、持久化、过期策略、淘汰策略、缓存穿透雪崩击穿问题

Redis四种模式 单节点模式 架构​​&#xff1a;单个Redis实例运行在单台服务器。 ​​优点​​&#xff1a; ​​简单​​&#xff1a;部署和配置容易&#xff0c;适合开发和测试。 ​​低延迟​​&#xff1a;无网络通信开销。 ​​缺点​​&#xff1a; ​​单点故障​​&…...

【WPF】Opacity 属性的使用

在WPF&#xff08;Windows Presentation Foundation&#xff09;中&#xff0c;Opacity 属性是定义一个元素透明度的属性&#xff0c;其值范围是从 0.0&#xff08;完全透明&#xff09;到 1.0&#xff08;完全不透明&#xff09;。由于 Opacity 是在 UIElement 类中定义的&…...

编程题 02-线性结构3 Reversing Linked List【PAT】

文章目录 题目输入格式输出格式输入样例输出样例 题解解题思路完整代码 编程练习题目集目录 题目 Given a constant K K K and a singly linked list L L L, you are supposed to reverse the links of every K K K elements on L L L. For example, given L being 1 → …...

集成指南:如何采用融云 Flutter IMKit 实现双端丝滑社交体验

在移动应用开发领域&#xff0c;跨平台框架的广泛应用已成为一种趋势。 融云跨平台方案持续升级&#xff0c;近期正式上线 Flutter IMKit&#xff0c;uni-app IMKit 也将紧随其后向广大开发者开放。覆盖两大跨平台核心框架&#xff0c;一套代码即可支持 Android、iOS 双端丝滑…...

使用vite重构vue-cli的vue3项目

一、修改依赖 首先修改 package.json&#xff0c;修改启动方式与相应依赖 移除vue-cli并下载vite相关依赖&#xff0c;注意一些peerDependency如fast-glob需要手动下载 # 移除 vue-cli 相关依赖 npm remove vue/cli-plugin-babel vue/cli-plugin-eslint vue/cli-plugin-rout…...

LeetCode 2094.找出 3 位偶数:遍历3位偶数

【LetMeFly】2094.找出 3 位偶数&#xff1a;遍历3位偶数 力扣题目链接&#xff1a;https://leetcode.cn/problems/finding-3-digit-even-numbers/ 给你一个整数数组 digits &#xff0c;其中每个元素是一个数字&#xff08;0 - 9&#xff09;。数组中可能存在重复元素。 你…...

FLASH闪存(擦除、编译)

FLASH闪存 文章目录 FLASH闪存1.存储器映像位置2.FLASH简介3.闪存模块组织3.2闪存的共性&#xff1a; 4.FLASH基本结构4.1FLASH解锁4.2使用指针访问寄存器 5.选项字节5.1选项字节编程5.2选项字节擦除 6.相关函数介绍7.读取内部FLASH&#xff08;实操&#xff09;7.1接线图7.2工…...

企业即时通讯软件,私有化安全防泄密

在数字化转型与信创战略双重驱动下&#xff0c;企业对即时通讯工具的需求已从基础沟通转向安全可控、高效协同的综合能力。BeeWorks作为一款专为政企设计的私有化即时通讯与协同办公平台&#xff0c;凭借其全链路安全架构、深度国产化适配及灵活的业务集成能力&#xff0c;成为…...

直方图特征结合 ** 支持向量机图片分类

一、核心技术框架 1. 直方图特征原理 颜色直方图&#xff1a;统计图像中每个颜色区间&#xff08;如 RGB 通道&#xff09;的像素数量&#xff0c;反映颜色分布。HOG 直方图&#xff08;方向梯度直方图&#xff09;&#xff1a;统计图像局部区域的梯度方向分布&#xff0c;捕…...

【prometheus+Grafana篇】基于Prometheus+Grafana实现windows操作系统的监控与可视化

&#x1f4ab;《博主主页》&#xff1a; &#x1f50e; CSDN主页 &#x1f50e; IF Club社区主页 &#x1f525;《擅长领域》&#xff1a;擅长阿里云AnalyticDB for MySQL(分布式数据仓库)、Oracle、MySQL、Linux、prometheus监控&#xff1b;并对SQLserver、NoSQL(MongoDB)有了…...

PyTorch实战(4)——卷积神经网络(Convolutional Neural Network, CNN)详解

PyTorch实战&#xff08;4&#xff09;——卷积神经网络详解 0. 前言1. 全连接网络的缺陷2. 卷积神经网络基本组件2.1 卷积2.2 步幅和填充2.3 池化2.3 卷积神经网络完整流程 3. 卷积和池化相比全连接网络的优势4. 使用 PyTorch 构建卷积神经网络4.1 使用 PyTorch 构建 CNN 架构…...

【Python】Python常用控制结构详解:条件判断、遍历与循环控制

Python提供了多种控制结构来处理逻辑判断和循环操作&#xff0c;包括if-else条件分支、switch替代方案、遍历方法以及循环控制语句break和continue。以下是对这些功能的详细说明及示例&#xff1a; 一、条件判断&#xff1a;if-else与多分支结构 单分支结构 • 语法&#xff1…...

在Linux中安装JDK并且搭建Java环境

1.首先准备好JDK的Linux的安装包 2.打开Linux,进入root的文件夹,直接拖入即可 3.输入解压命令,后面指定的是位置&#xff08;注意不要填写错误&#xff0c;就填写这个&#xff09; 4.之后进入我们安装的jdk的文件 利用pwd命令&#xff0c;展示我们安装的目录&#xff0c;之后…...

理解多智能体深度确定性策略梯度MADDPG算法:基于python从零实现

引言&#xff1a;多智能体强化学习&#xff08;MARL&#xff09; 多智能体强化学习&#xff08;MARL&#xff09;将强化学习拓展到多个智能体在共享环境中相互交互的场景。这些智能体可能相互合作、竞争&#xff0c;或者目标混杂。MARL 引入了单智能体设置中不存在的独特挑战。…...

【AI大语言模型本质分析框架】

AI大语言模型本质分析框架 ——从教育危机到智能本质的七层递进式解构 第一层&#xff1a;现象观察——阴&#xff08;显性危机&#xff09;与阳&#xff08;隐性变革&#xff09;的共存 观点1&#xff08;阴&#xff09;&#xff1a;AI作弊泛滥&#xff0c;传统教育体系崩溃…...

算法模型部署后_python脚本API测试指南-记录3

API 测试指南 服务运行后&#xff0c;可以通过以下方式测试&#xff1a; Curl: curl -X POST -F "file./test_dataset/surface/surface57.png" http://<服务器IP>:9000/api/v1/predictPython 脚本: (参考 svm_request测试.py) import requestsurl http://…...

鸿蒙(HarmonyOS)应用开发入门教程

目录 第一章:鸿蒙系统简介 1.1 什么是鸿蒙系统? 1.2 鸿蒙系统架构 第二章:开发环境搭建 2.1 安装DevEco Studio 步骤1:下载与安装 步骤2:首次配置 步骤3:设备准备 2.2 创建第一个项目 第三章:鸿蒙应用开发基础 3.1 核心概念:Ability与AbilitySlice 示例代码…...

MIT XV6 - 1.6 Lab: Xv6 and Unix utilities -uptime

接上文 MIT XV6 - 1.5 Lab: Xv6 and Unix utilities - xargs 第一章持续有点久了&#xff0c;虽然肯定有些特点和细节还没注意到&#xff0c;但这次的主要目的是学习内核部分&#xff0c;决定水一篇然后进入第二章节 uptime 第一章的最后一个实验&#xff0c;选做性质&#xf…...

Python语言在地球科学交叉领域中的应用——从数据可视化到常见数据分析方法的使用【实例操作】

前言&#xff1a; Python是功能强大、免费、开源&#xff0c;实现面向对象的编程语言&#xff0c;Python能够运行在Linux、Windows、Macintosh、AIX操作系统上及不同平台&#xff08;x86和arm&#xff09;&#xff0c;Python简洁的语法和对动态输入的支持&#xff0c;再加上解释…...

flutter 的 json序列化和反序列化

一、json转实体 Instantly parse JSON in any language | quicktype 二、实体中的toJson和fromJson 实现 官方推荐的 两个插件(个人觉得一个实体会多一个.g.dart 文件太多了&#xff0c;不喜欢) json_annotation json_serializable 三、使用 dart_json_mapper 实现上面的功…...

什么是数据集市(Data Mart)?

数据集市&#xff08;Data Mart&#xff09;是数据仓库&#xff08;Data Warehouse&#xff09;的一个子集&#xff0c;专门针对某个特定业务部门、业务线或主题领域&#xff0c;存储和管理该部门或领域所需的特定数据。它通常包含从企业范围的数据仓库中抽取、筛选和汇总的部分…...

从攻击者角度来看Go1.24的路径遍历攻击防御

目录 一、具体攻击示例 程序 攻击步骤&#xff1a; 二、为什么攻击者能成功&#xff1f; 分析 类比理解 总结 三、TOCTOU 竞态条件漏洞 1、背景&#xff1a;符号链接遍历攻击 2. TOCTOU 竞态条件漏洞 3. 另一种变体&#xff1a;目录移动攻击 4. 问题的核心 四、防…...

[ARM][汇编] 01.基础概念

目录 1.全局标号 1.1.使用方法 1.1.1.声明全局标号 1.1.2.定义全局标号 1.1.3.引用全局标号 1.2.全局标号与局部标号的区别 1.3.注意事项 2.局部标号 2.1.使用方法 2.1.1.定义局部标号 2.1.2.跳转引用 2.2.局部标号与全局标号的对比 2.3.注意事项 3.符号定义伪指…...

杭州电商全平台代运营领军者——品融电商

杭州电商全平台代运营领军者——品融电商&#xff1a;以“效品合一”驱动品牌全域增长 在电商行业竞争日益白热化的当下&#xff0c;品牌如何突破流量焦虑、实现长效增长&#xff1f;作为中国领先的品牌化电商服务商&#xff0c;杭州品融电商&#xff08;PINKROON&#xff09;…...

02.Golang 切片(slice)源码分析(一、定义与基础操作实现)

Golang 切片&#xff08;slice&#xff09;源码分析&#xff08;一、定义与基础操作实现&#xff09; 注意当前go版本代码为1.23 一、定义 slice 的底层数据是数组&#xff0c;slice 是对数组的封装&#xff0c;它描述一个数组的片段。两者都可以通过下标来访问单个元素。 数…...

当生产了~/qt-arm/bin/qmake,可以单独编译其他-源码的某个模块,如下,编译/qtmultimedia

cd ~/qt-everywhere-src-5.15.2/qtmultimedia # 设置交叉编译器和 qmake 路径 export CC/usr/bin/aarch64-linux-gnu-gcc export CXX/usr/bin/aarch64-linux-gnu-g export QMAKE~/qt-arm/bin/qmake # 使用已安装的 qmake export QT_INSTALL_PREFIX~/qt-arm # 安装路径 # 配…...

WordPress 网站上的 jpg、png 和 WebP 图片插件

核心功能 1. 转换 AVIF 并压缩 AVIF 将您 WordPress 网站上的 jpg、png 和 WebP 图片转换为 AVIF 格式&#xff0c;并根据您设置的压缩级别压缩 AVIF 图片。如果原始图片已经是 WordPress 6.5 以上支持的 AVIF 格式&#xff0c;则原始 AVIF 图片将仅被压缩。 2. 转换 WebP 并…...

构造+简单树状

昨日的牛客周赛算是比较简单的&#xff0c;其中最后一道构造题目属实眼前一亮。 倒数第二个题目也是一个很好的模拟题目&#xff08;考验对二叉树的理解和代码的细节&#xff09; 给定每一层的节点个数&#xff0c;自己拟定一个父亲节点&#xff0c;构造一个满足条件的二叉树。…...

Flask支持哪些日志框架

目录 ✅ Flask 默认支持的日志框架 ✅ 默认推荐:logging(标准库) ✅ 进阶推荐:Loguru(更优雅的日志库) ✅ Flask 日志级别说明(与标准库一致) ✅ 生产环境建议 ✅ 总结推荐 在 Flask 中,默认的日志系统是基于 Python 标准库 logging 模块 构建的。 ✅ Flask 默认…...

健康养生指南:解锁活力生活的科学密码

健康是人生最珍贵的财富&#xff0c;在快节奏的现代生活中&#xff0c;掌握科学的养生方法至关重要。虽然不借助中医理念&#xff0c;我们依然可以从饮食、运动、睡眠等多个方面入手&#xff0c;打造健康生活方式。 合理的饮食是健康的基石。遵循均衡饮食原则&#xff0c;保证每…...