FPGA实现AXI4总线的读写_如何写axi4逻辑

FPGA实现AXI4总线的读写_如何写axi4逻辑

一、AXI4 接口描述

通道

信号

信号描述

全局信号

aclk

主机

全局时钟

aresetn

主机

全局复位,低有效

写通道地址与控制信号通道

M_AXI_WR_awid[3:0]

主机

写地址ID,用来标志一组写信号

M_AXI_WR_awaddr[31:0]

主机

写地址,给出一次写突发传输的写地址

M_AXI_WR_awlen[7:0]

主机

突发长度,给出突发传输的次数

M_AXI_WR_awsize[2:0]

主机

突发大小,给出每次突发传输的字节数

M_AXI_WR_awburst[1:0]

主机

突发类型

M_AXI_WR_awlock

主机

总线锁信号,可提供操作的原子性

M_AXI_WR_awcache[3:0]

主机

内存类型,表明一次传输是怎样通过系统的

M_AXI_WR_awprot[2:0]

主机

保护类型,表明一次传输的特权级及安全等级

M_AXI_WR_awqos[3:0]

主机

质量服务QoS

M_AXI_WR_awvalid

主机

有效信号,表明此通道的地址控制信号有效

M_AXI_WR_awready

从机

表明“从”可以接收地址和对应的控制信号

写通道数据通道

M_AXI_WR_wdata[63:0]

主机

写数据

M_AXI_WR_wstrb[7:0]

主机

写数据有效的字节线,用来表明哪8bits数据是有效的

M_AXI_WR_wlast

主机

表明此次传输是最后一个突发传输

M_AXI_WR_wvalid

主机

写有效,表明此次写有效

M_AXI_WR_wready

从机

表明从机可以接收写数据

写通道响应通道

M_AXI_WR_bid[3:0]

从机

写响应ID TAG

M_AXI_WR_bresp[1:0]

从机

写响应,表明写传输的状态

M_AXI_WR_bvalid

从机

写响应有效

M_AXI_WR_bready

主机

表明主机能够接收写响应

读通道地址与控制信号通道

M_AXI_RD_arid[3:0]

主机

读地址ID,用来标志一组写信号

M_AXI_RD_araddr[31:0]

主机

读地址,给出一次写突发传输的读地址

M_AXI_RD_arlen[7:0]

主机

突发长度,给出突发传输的次数

M_AXI_RD_arsize[2:0]

主机

突发大小,给出每次突发传输的字节数

M_AXI_RD_arburst[1:0]

主机

突发类型

M_AXI_RD_arlock[1:0]

主机

总线锁信号,可提供操作的原子性

M_AXI_RD_arcache[3:0]

主机

内存类型,表明一次传输是怎样通过系统的

M_AXI_RD_arprot[2:0]

主机

保护类型,表明一次传输的特权级及安全等级

M_AXI_RD_arqos[3:0]

主机

质量服务QOS

M_AXI_RD_arvalid

主机

有效信号,表明此通道的地址控制信号有效

M_AXI_RD_arready

从机

表明“从”可以接收地址和对应的控制信号

读通道数据通道

M_AXI_RD_rid[3:0]

从机

读IDtag

M_AXI_RD_rdata[63:0]

从机

读数据

M_AXI_RD_rresp[1:0]

从机

读响应,表明读传输的状态

M_AXI_RD_rlast

从机

表明读突发的最后一次传输

M_AXI_RD_rvalid

从机

表明此通道信号有效

M_AXI_RD_rready

主机

表明主机能够接收读数据和响应信息

二、地址通道的控制信号与地址描述

1、地址ID

AWID[3:0]与ARID[3:0]:对于只有一个主机从机设备,该值可设置为任意

2、地址结构

AWADDR[31:0]与ARADDR[31:0]:AXI协议是基于burst(突发)的,主机只给出突发传输的第一个字节的地址,从机必须计算突发传输后续的地址。突发传输不能跨4KB边界(防止突发跨越两个从机的边界,也限制了从机所需支持的地址自增数

3、突发长度

AWLEN[7:0]与ARLEN[7:0]:ARLEN[7:0]决定读传输的突发长度,AWLEN[7:0]决定写传输的突发长度。AXI4扩展突发长度支持INCR突发类型为1256次传输,对于其他的传输类型依然保持116次突发传输(Burst_Length=AxLEN[7:0]+1)

4、突发大小

ARSIZE[2:0],读突发传输;AWSIZE[2:0],写突发传输。

AxSIZE[2:0]

传输字节大小

3'b000

1

3'b001

2

3'b010

4

3'b011

8

3'b100

16

3'b101

32

3'b110

64

3'b111

128

5、突发类型

AWBURST[1:0]与ARBURST[1:0]:

AxBURST[1:0]

突发类型

2'b00

FIXED

2'b01

INCR

2'b10

WRAP

2'b11

Reserved

FIXED:突发传输过程中地址固定,用于FIFO访问

INCR:增量突发,传输过程中,地址递增。增加量取决AxSIZE的值

WRAP:回环突发,和增量突发类似,但会在特定高地址的边界处回到低地址处。回环突发的长度只能是2,4,8,16次传输,传输首地址和每次传输的大小对齐。最低的地址整个传输的数据大小对齐。回环边界等于(AxSIZE*AxLEN)

三、数据通道信号描述

1、WDATA与RDATA:写与读数据线信号

WSTRB:有效字节,WSTRB[n:0]对应于对应的写字节,WSTRB[n]对应WDATA[8n+7:8n],也就是对于的数据宽度的字节数是否有效。WVALID为低时,WSTRB可以为任意值,WVALID为高时,WSTRB为高的字节线必须指示有效的数据。对于一般应用,将WSTRB全部置1即可,保证全部数据有效。读通道无该信号。

2、WLAST与RLAST

写与读最后一个字节,拉高表示传输最后一个字节,也意味着传输结束

3、burst[1:0]

描述读写相应结构

burst[1:0]

00

常规访问成功

01

独占访问成功

10

从机错误

11

解码错误

四、突发写时序:

AXI4突发写可以分为7个状态,写空闲,写通道写地址等待,写通道写地址,写数据等待,写数据循环,接受写应答,写结束这7种状态。之所以划分为7个状态是为了后续写程序的状态机做准备。

7种状态

1、写空闲:等待触发突发信号

2、写通道写地址等待:准备好写地址AWADDR,然后拉高AWVALID。

3、写通道写地址:从机接受到AWVALID,发出AWREADY。

4、写数据等待:准备好数据WDATA,拉高WVALID。

5、写数据循环:从机接受WVALID,确认数据WDATA有效并且接受,发出WREADY,AXI是突发传输:循环该操作到接受到WLAST最后一个数据标志位。

6、接受写应答:接受到从机发出的BVALID,主机发出BREADY。

7、写结束:拉低未拉低的信号,进入写空闲

五、突发读时序

AXI4突发读可以分为6个状态,读空闲,读通道写地址等待,读通道写地址,读数据等待,读数据循环,读结束这6种状态。之所以划分为6个状态是为了后续写程序的状态机做准备。

6种状态

1、读空闲:等待触发突发信号。

2、读通道写地址等待:准备好写地址ARADDR,然后拉高ARVALID。

3、读通道写地址:从机接受到ARVALID,发出ARREADY。

4、读数据等待:从机准备好数据WDATA,从机拉高RVALID。

5、读数据循环:主机接受RVALID,确认数据RDATA有效并且接受,发出RREADY给从机,AXI是突发传输:循环该操作到接受到RLAST最后一个数据标志位

6、读结束:拉低未拉低的信号,进入读空闲

注:

1、读数据必须总是跟在与其数据相关联的地址之后。

2、写响应必须总是跟在与其相关联的写事务的最后出现。

六、写时序状态机

七、写时序代码

module axi4_write(input               clk             ,input               resetn          ,input               enable_write    ,  //写使能input  [31:0]       w_addr          ,  //地址input  [63:0]       w_data          ,  //数据output reg          write_done      ,  //写完成output reg          write_data      ,  //表示数据写入,突发模式下可用于切换数据的指示信号//axi4写通道地址通道output  [3:0]       m_axi_awid      , //写地址ID,用来标志一组写信号output reg[31:0]    m_axi_awaddr    ,//写地址,给出一次写突发传输的写地址 output [7:0]        m_axi_awlen     , //突发长度,给出突发传输的次数 output [2:0]        m_axi_awsize    , //突发大小,给出每次突发传输的字节数 output [1:0]        m_axi_awburst   , //突发类型 output              m_axi_awlock    , //总线锁信号,可提供操作的原子性 output [3:0]        m_axi_awcache   , //内存类型,表明一次传输是怎样通过系统的output [2:0]        m_axi_awprot    , //保护类型,表明一次传输的特权级及安全等级 output [3:0]        m_axi_awqos     , //质量服务QoSoutput reg          m_axi_awvalid   , //有效信号,表明此通道的地址控制信号有效 input               m_axi_awready   , //表明“从”可以接收地址和对应的控制信号//axi4写通道数据通道output reg[63:0]    m_axi_wdata     , //写数据 output [7:0]        m_axi_wstrb     , //写数据有效的字节线 output reg          m_axi_wlast     , //表明此次传输是最后一个突发传输output reg          m_axi_wvalid    , //写有效,表明此次写有效input               m_axi_wready    , //表明从机可以接收写数据 //axi4写通道应答通道 input [3:0]         m_axi_bid       , //写响应ID TAGinput [1:0]         m_axi_bresp     , //写响应,表明写传输的状态input               m_axi_bvalid    , //写响应有效output reg          m_axi_bready      //表明主机能够接收写响应);//*******************参数*****************************localparam  W_IDLEW     = 3'b001    ; //空闲等待localparam  W_DRIVEW    = 3'b011    ; //准备、取地址localparam  W_HANDS     = 3'b010    ; //握手localparam  W_WSTBR     = 3'b110    ; //突发localparam  W_WAIT      = 3'b111    ; //等待结束的信息localparam  W_END       = 3'b101    ; //写数据阶段parameter   LEN_NUM     = 1         ;parameter   AWID        = 0         ;
//*********内部信号******************************reg  [2:0]  state ,   next_state   ;reg         wready_over            ;reg  [7:0]  len                    ;assign  m_axi_awid    = AWID[3:0] ;    // [3:0]  //写地址ID,用来标志一组写信号  assign  m_axi_awlen   = LEN_NUM-1 ;    // [7:0]  //突发长度,给出突发传输的次数  assign  m_axi_awsize  = 3'b011    ;    // [2:0]  //突发大小,给出每次突发传输的字节数  assign  m_axi_awburst = 2'b10     ;    // [1:0]  //突发类型  assign  m_axi_awlock  = 1'b0      ;    //        //总线锁信号,可提供操作的原子性  assign  m_axi_awcache = 4'b0010   ;    // [3:0]  //内存类型,表明一次传输是怎样通过系统的 assign  m_axi_awprot  = 3'b000    ;    // [2:0]  //保护类型,表明一次传输的特权级及安全等级 assign  m_axi_awqos   = 4'b0000   ;    // [3:0]  //质量服务QoS assign  m_axi_wstrb   = 8'hff     ;//状态机always @(*) beginstate   =   next_state    ;end    always @(posedge clk or negedge resetn) beginif(!resetn) beginwready_over<=0;endelse if(state==W_IDLEW || state==W_END )wready_over<=0;else if(m_axi_wready)wready_over<=1;endalways @(posedge clk or negedge resetn) beginif(!resetn) beginnext_state  <=  W_IDLEW   ;len <=0 ;endelse case(state)W_IDLEW :   if(enable_write) next_state <= W_DRIVEW  ;  else next_state<=W_IDLEW    ;W_DRIVEW:   if(m_axi_awready) beginnext_state <= W_HANDS ; len<=LEN_NUM-1          ; end else next_state<=W_DRIVEW   ;W_HANDS :   if(wready_over && len==0)next_state <= W_WAIT ;  else   if(wready_over ) next_state <= W_WSTBR   ;else next_state<=W_HANDS  ;W_WSTBR :   if(len==1)       next_state <= W_WAIT ;  else begin next_state <= W_WSTBR ;len <=len-1           ;endW_WAIT  :   next_state<=W_END ;  W_END   :   if(m_axi_bvalid)next_state <= W_IDLEW  ;  else next_state<=W_END    ;default :   next_state<=W_IDLEW ;endcase   end// 组合逻辑输出always @(* ) begincase(state)W_IDLEW :   beginm_axi_wlast    =   0        ;m_axi_awaddr   =   0        ;m_axi_awvalid  =   0        ;m_axi_wdata    =   0        ;m_axi_wvalid   =   0        ;m_axi_bready   =   0        ;write_done     =   0        ;write_data     =   0        ;endW_DRIVEW:   beginm_axi_wlast    =   0       ;m_axi_awaddr   =   w_addr  ;m_axi_awvalid  =   1       ;m_axi_wdata    =   0       ;m_axi_wvalid   =   0       ;m_axi_bready   =   0       ;write_done     =   0       ;write_data     =   0       ;endW_HANDS :   beginm_axi_wlast    =   0       ;m_axi_awaddr   =   0       ;m_axi_awvalid  =   0       ;m_axi_wdata    =   0       ;m_axi_wvalid   =   0       ;m_axi_bready   =   0       ;write_done     =   0       ;write_data     =   0       ;endW_WSTBR :   beginm_axi_wlast    =   0       ;m_axi_awaddr   =   0       ;m_axi_awvalid  =   0       ;m_axi_wdata    =   w_data  ;m_axi_wvalid   =   1       ;m_axi_bready   =   0       ;write_done     =   0       ;write_data     =   1       ;endW_WAIT  :   beginm_axi_wlast    =   1       ;m_axi_awaddr   =   0       ;m_axi_awvalid  =   0       ;m_axi_wdata    =   w_data  ;m_axi_wvalid   =   1       ;m_axi_bready   =   0       ;write_done     =   1       ;write_data     =   1       ;endW_END   :   beginm_axi_wlast    =   0       ;m_axi_awaddr   =   0       ;m_axi_awvalid  =   0       ;m_axi_wdata    =   0       ;m_axi_wvalid   =   0       ;m_axi_bready   =   1       ;write_done     =   0       ;write_data     =   0       ;enddefault :   beginm_axi_wlast    =   0   ;m_axi_awaddr   =   0   ;m_axi_awvalid  =   0   ;m_axi_wdata    =   0   ;m_axi_wvalid   =   0   ;m_axi_bready   =   0   ;write_done     =   0   ;write_data     =   0   ;endendcaseend
endmodule

八、读时序状态机

九、读时序代码

module axi4_read(input               resetn          ,//axi复位 input               clk             ,  //axi时钟 input               enable_read     ,output              read_data       ,output              read_done       ,input       [31:0]  r_addr          ,output  reg [63:0]  r_data          ,//axi读通道写地址 output     [3:0]   m_axi_arid      , //读地址ID,用来标志一组写信号output reg [31:0]  m_axi_araddr    , //读地址,给出一次写突发传输的读地址output     [7:0]   m_axi_arlen     , //突发长度,给出突发传输的次数output     [2:0]   m_axi_arsize    , //突发大小,给出每次突发传输的字节数output     [1:0]   m_axi_arburst   , //突发类型output     [1:0]   m_axi_arlock    , //总线锁信号,可提供操作的原子性output     [3:0]   m_axi_arcache   , //内存类型,表明一次传输是怎样通过系统的 output     [2:0]   m_axi_arprot    , //保护类型,表明一次传输的特权级及安全等级output     [3:0]   m_axi_arqos     , //质量服务QOS output reg         m_axi_arvalid   , //有效信号,表明此通道的地址控制信号有效 input              m_axi_arready   , //表明“从”可以接收地址和对应的控制信号//axi读通道读数据 input      [3:0]   m_axi_rid       , //读ID tag input      [63:0]  m_axi_rdata     , //读数据 input      [1:0]   m_axi_rresp     , //读响应,表明读传输的状态input              m_axi_rlast     , //表明读突发的最后一次传输input              m_axi_rvalid    , //表明此通道信号有效 output reg         m_axi_rready      //表明主机能够接收读数据和响应信息);
//localparam [2:0] R_IDLER      =  3'b001   ;localparam [2:0] R_WAIT       =  3'b011   ;localparam [2:0] R_BURST      =  3'b010   ;localparam [2:0] R_END        =  3'b110   ;parameter  ARID   = 0    ;parameter  RD_LEN = 1    ;
//reg [2:0] state , next_state    ;reg          rvalid_over    ;
//    assign m_axi_arid      = ARID[3:0]      ;//地址id assign m_axi_arlen     = RD_LEN-32'd1   ;//突发长度assign m_axi_arsize    = 3'b011         ;//表示AXI总线每个数据宽度是8字节,64位 assign m_axi_arburst   = 2'b01          ;//地址递增方式传输assign m_axi_arlock    = 1'b0           ;assign m_axi_arcache   = 4'b0010        ; assign m_axi_arprot    = 3'b000         ;assign m_axi_arqos     = 4'b0000        ;assign read_data       =  m_axi_rvalid  ;assign read_done       = m_axi_rlast    ;
//axi读状态机always @(*) beginstate   =   next_state  ;end//always @(posedge clk  or negedge resetn) beginif(!resetn) beginrvalid_over <=0  ;end else if(state==R_IDLER) beginrvalid_over <=0  ;endelse if(m_axi_rvalid)beginrvalid_over <= 1 ;endendalways @(posedge clk or negedge resetn) beginif(!resetn)next_state <= R_IDLER;else    case(state)R_IDLER  :  if(enable_read) next_state <= R_WAIT ;else next_state<=R_IDLER   ; R_WAIT   :  if(m_axi_arready) next_state<=R_BURST  ;else next_state<=R_WAIT  ;  R_BURST  :  if(m_axi_rlast)  next_state<=R_END    ;else next_state  <=  R_BURST ;R_END    :  if(rvalid_over) next_state<=R_IDLER;else next_state<=R_END ;  default  :  next_state<=R_IDLER ;endcaseend//always @(*) begincase(state)R_IDLER  :  beginm_axi_araddr  = 0       ;  m_axi_arvalid = 0       ;  m_axi_rready  = 0       ;  r_data        = 0       ;  end R_WAIT   :  beginm_axi_araddr  = r_addr      ;  m_axi_arvalid = 1           ;  m_axi_rready  = 0           ;  r_data        = 0           ;    end             R_BURST  :  beginm_axi_araddr  = 0           ;  m_axi_arvalid = 0           ;  m_axi_rready  = 1           ;  r_data        = m_axi_rdata ;      end   R_END    :  beginm_axi_araddr  = 0           ;  m_axi_arvalid = 0           ;  m_axi_rready  = 1           ;  r_data        = 0           ;     end default  :  beginm_axi_araddr  = 0           ;  m_axi_arvalid = 0           ;  m_axi_rready  = 0           ;  r_data        = 0           ;     end endcaseendendmodule

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

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

相关文章

Nest.js项目初始配置

1.全局安装nest pnpm add -g nestjs/cli nodemon ts-node 2.创建nest项目 nest new project-name 3.安装依赖 pnpm add prisma-binding ts-node prisma/client mockjs nestjs/config class-validator class-transformer argon2 nestjs/passport passport passport-local n…

如何一键清除文件目录下所有的node_modules

如何一键清除文件目录下所有的node_modules 快速删除目录下的node_modules&#xff0c;下面附上windows和mac的脚本指令 windows脚本 FOR /d /r . %d in (node_modules) DO IF EXIST "%d" rm -rf "%d"mac脚本 find . -name "node_modules" -…

最短路问题之Bellman-Ford,SPFA算法,例题 负环

Bellman-Ford算法&#xff1a; Bellman-Ford算法用于解决带有负权边的单源最短路径问题。其基本思想是通过不断地松弛边来逐步求解最短路径。算法的主要步骤如下&#xff1a; 初始化&#xff1a;将源点到各个顶点的距离初始化为无穷大&#xff0c;源点的距离初始化为0。重复更…

JavaScript 变量 及 案例练习

变量 一. 变量是什么: 问题1: 用户输入的数据我们如何存储起来? 答案1: 使用变量 理解变量是如何存储数据的 “容器” **变量: ** 白话: 变量就是一个装东西的盒子通俗: 变量是计算机中用来存储数据的 “容器” , 它可以让计算机变得有记忆注意: 变量不是数据本身, 它们仅…

IDEA2023版本创建Sping项目无法使用Java8

1. 问题复现 1.1 当前版本2023.3.2 1.2 创建项目时&#xff1a;不存在jdk8选项 提示报错 1.3 原因分析 Spring官方发布Spring Boot 3.0.0 的时候告知了一些情况&#xff0c;Java 17将成为未来的主流版本 2. 如何解决 2.1 替换创建项目的源 我们只知道IDEA页面创建Spring项目…

对Java未来的发展趋势和新技术的看法

Java作为一种广泛使用的编程语言&#xff0c;已经走过了数十年的历程&#xff0c;其在企业级应用开发、大数据处理、云计算等多个领域都发挥着重要作用。随着技术的不断进步&#xff0c;Java也在不断发展&#xff0c;呈现出一些新的趋势和新技术。以下是对Java未来发展趋势和新…

Mysql 的char 和varchar的的区别

1、char 和varchar 区别 下面以utf8字符集为例&#xff0c;char和varchar的占比计算&#xff0c;如下图 valueChar(5)bytesVarchar(5)bytesVarchar(100&#xff09;bytes‘’‘ ’15‘’1‘’1‘abcd’‘abcd ’15‘abcd’13‘abcd’13abcdeabcde15abcde16abcde16 varchar使用…

【PHP快速上手(十四)】

目录 PHP快速上手&#xff08;十四&#xff09;PHP 中常用数据库操作使用 WHERE 子句进行条件查询使用 ORDER BY 子句进行排序使用 UPDATE 语句更新数据使用 DELETE 语句删除数据执行事务总结 PHP快速上手&#xff08;十四&#xff09; PHP 中常用数据库操作 当使用 PHP 中的…

NumPy 1.26 中文文档翻译完成

NumPy 1.26 中文文档NumPy 用户指南开始入门什么是 NumPy&#xff1f;NumPy 快速开始NumPy: 绝对初学者的基础知识基础与用法NumPy 基础知识MATLAB 用户的 NumPyNumPy 特性NumPy 如何操作高级用法和互操作性从源码编译使用 NumPy C-APIF2PY 用户指南和参考手册开发人员的底层文…

kubernetes中的静态POD

我们都知道&#xff0c;pod是kubelet创建的&#xff0c;那么创建的流程是什么呐&#xff1f; 此时我们需要了解k8s中config.yaml配置文件了&#xff1a; 他的存放路径&#xff1a; 【/var/lib/kubelet/config.yaml】 一、查看静态pod的路径 [K8Sk8s-master ~]$ sudo cat /va…

前端中的promise.all()的使用

理解和使用Promise.all和Promise.race 一、promise.all的使用 说明 Promise.all 可以将多个Promise实例包装成一个新的Promise实例&#xff0c;等待所有都完成&#xff08;或第一个失败&#xff09;返回值 成功的时候返回的是一个数组&#xff0c;失败的时候则返回先被…

Linux驱动开发——(五)内核中断

目录 一、内核中断简介 1.1 中断号 1.2 中断API函数 1.2.1 irq_of_parse_and_map函数 1.2.2 gpio_to_irq函数 1.2.3 request_irq函数 1.2.4 free_irq函数 1.2.5 中断处理函数 1.2.6 中断使能与禁止函数 二、上半部&#xff08;顶半部&#xff09;与下半部&#xff08…

代码托管基础操作

在待上传代码文件夹中右键&#xff0c;打开Git Bash Here依次输入以下命令&#xff1a; git init(在本地初始化一个代码仓库&#xff0c;具体表现为会在你的文件夹里出现一个隐藏的.git文件夹) git add .&#xff08;先把代码放到本地的一个缓冲区&#xff09;添加当前目录下的…

【C++】从零开始认识泛型编程 — 模版

送给大家一句话&#xff1a; 尽管眼下十分艰难&#xff0c;可日后这段经历说不定就会开花结果。总有一天我们都会成为别人的回忆&#xff0c;所以尽力让它美好吧。 – 岩井俊二 &#xff3c;&#xff3c;\ ⱶ˝୧(๑ ⁼̴̀ᐜ⁼̴́๑)૭兯 //&#xff0f;&#xff0f; &#…

六、Java+FFmpeg,实战直播推流

目录 类 JavaFFmepegTest run() 方法 openFFmpegExe() 方法 main() 方法 总结 import java.io.BufferedInputStream; import java.io.BufferedReader; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io

Unity 时间格式 12小时制与24小时制

using System; using System.Collections; using System.Collections.Generic; using TMPro; using UnityEngine; using UniRx; public class DisplayTime : MonoBehaviour { //时间文本显示 [SerializeField] private TextMeshProUGUI _time; private int _timeType 0; enu…

AI大模型探索之路-训练篇3:大语言模型全景解读

文章目录 前言一、语言模型发展历程1. 第一阶段&#xff1a;统计语言模型&#xff08;Statistical Language Model, SLM&#xff09;2. 第二阶段&#xff1a;神经语言模型&#xff08;Neural Language Model, NLM&#xff09;3. 第三阶段&#xff1a;预训练语言模型&#xff08…

Ali-Sentinel-节点与度量

归档 GitHub: Ali-Sentinel-节点与度量 作用 保存资源的实时统计信息 节点 节点-类结构 com.alibaba.csp.sentinel.slots.statistic.metric.DebugSupport /** 调试支持 */ public interface DebugSupport {void debug(); // 打印统计信息 }com.alibaba.csp.sentinel.n…

Python基础知识(二)

&#x1f3ac; 秋野酱&#xff1a;《个人主页》 &#x1f525; 个人专栏:《Java专栏》 《Python专栏》 ⛺️心若有所向往,何惧道阻且长 文章目录 1.输入和输出函数1.1输出函数1.2输入函数 2.常见运算符2.1赋值运算符2.2比较运算符2.3逻辑运算符2.4and逻辑与2.5or逻辑或2.6not逻…

nvidia-smi详解

nvidia-smi&#xff1a;控制你的 GPU 大多数用户都知道如何检查他们的 CPU 的状态&#xff0c;查看有多少系统内存可用&#xff0c;或者找出有多少磁盘空间可用。相比之下&#xff0c;从历史上看&#xff0c;密切关注 GPU 的运行状况和状态一直比较困难。如果您不知道去哪里寻…