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

初学stm32 --- FSMC驱动LCD屏

 

目录

 

FSMC简介

FSMC框图介绍

FSMC通信引脚介绍

FSMC_NWE 的作用

FSMC_NWE 的时序关系

FSMC_NOE 的含义

FSMC_NOE 的典型用途

FSMC_NOE 的时序关系

使用FSMC驱动LCD

FSMC时序介绍 

时序特性中的 OE

 ILI9341重点时序:

FSMC地址映射 

 HADDR与FSMC_A关系

 LCD的RS信号线与地址线关系

FSMC相关寄存器介绍

SRAM/NOR闪存片选控制寄存器(FSMC_BCRx) 

SRAM/NOR闪存片选时序寄存器(FSMC_BTRx)

SRAM/NOR闪存写时序寄存器(FSMC_BWTRx)

FSMC寄存器组合说明

FSMC相关HAL库函数简介

 SRAM_HandleTypeDef

FSMC_NORSRAM_InitTypeDef

FSMC模拟8080时序读写简化代码


FSMC简介

FSMC,Flexible Static Memory Controller,灵活的静态存储控制器。

用途:用于驱动SRAM,NOR FLASH,NAND FLASH及PC卡类型的存储器。

        配置好FSMC,定义一个指向这些地址的指针,通过对指针操作就可以直接修改存储单元的内容,FSMC自动完成读写命令和数据访问操作,不需要程序去实现时序。

        FSMC外设配置好就可以模拟出时序。

实例:FSMC模拟8080时序控制LCD

F1/ F4(407)系列大容量型号,且引脚数目在100脚以上的芯片都有FSMC接口

F4/F7/H7系列就是FMC接口

FSMC框图介绍

① 时钟控制逻辑

FSMC挂载在AHB总线上,时钟信号来自HCLK

② STM32内部的FSMC控制单元

NOR闪存和PSRAM控制器、NAND闪存和PC卡控制器、FSMC配置寄存器

③ 通信引脚

不同类型存储器用到的信号引脚

公共信号引脚

FSMC通信引脚介绍

  用于连接硬件设备的引脚,控制不同类型的存储器会用不同的引脚。

  • FSMC_NWE 的作用

  • 用于写操作

    • FSMC_NWE 用于通知外部存储器执行写操作。
    • 在写操作期间,FSMC 会将 FSMC_NWE 拉低(逻辑 0),使能外部存储器的写操作。
    • FSMC_NWE 通常连接到外部存储器的 WE(Write Enable)引脚,确保数据可以正确写入外部存储器。
  • 与数据总线和地址总线的配合

    • 在写操作中:
      • FSMC_NWE 为低电平时,外部存储器会从 FSMC 的数据总线(FSMC_Dx)上读取数据,并将数据写入指定的存储地址(由地址总线 FSMC_Ax 提供)。
      • FSMC_NWE 回到高电平时,写操作完成。
  • 写入控制的时序信号

    • FSMC 控制 FSMC_NWE 的上升沿和下降沿来定义写入周期的开始和结束,确保数据正确写入外部存储器。

FSMC_NWE 的时序关系

FSMC_NWE 的控制信号与以下其他 FSMC 信号配合使用:

  1. FSMC_NE(芯片选择,Chip Select)
    • 用于选择具体的外部存储器。
    • FSMC_NE 为低电平时,所选存储器芯片被激活。
  2. FSMC_A(地址总线)
    • 提供数据写入的目标地址。
  3. FSMC_D(数据总线)
    • 提供要写入的数据。
  4. FSMC_NWAIT(等待信号,可选)
    • 外部存储器可以通过拉高或拉低 FSMC_NWAIT 信号请求延迟完成写操作。

以下是典型的 FSMC 写入时序:

  • FSMC 首先激活 FSMC_NE(芯片选择)。
  • 然后将 FSMC_Ax(地址)和 FSMC_Dx(数据)设置为目标地址和数据值。
  • FSMC_NWE 被拉低,外部存储器开始写入。
  • 当写入完成后,FSMC_NWE 被拉高,FSMC 将完成该写操作。

FSMC_NOE 的含义

FSMC_NOE 的全称是 FSMC Output Enable (输出使能),它是 FSMC 用于控制外部存储器数据输出的信号引脚。

  • 名称含义

    • N:代表负逻辑(Active Low,低电平有效)。
    • OE:Output Enable(输出使能信号)。
  • 功能

    • FSMC_NOE 控制外部存储器是否将数据输出到 FSMC 的数据总线上。
    • FSMC_NOE 为低电平(逻辑 0)时,外部存储器的输出缓冲区被使能,数据可以传输到 FSMC 的数据总线。
    • FSMC_NOE 为高电平(逻辑 1)时,外部存储器的输出缓冲区被禁用,数据不会输出。

FSMC_NOE 的典型用途

  1. 与外部存储器的接口控制

    • 在读取外部存储器(如 NOR Flash 或 SRAM)时,FSMC 控制 FSMC_NOE 以使能数据的输出。
    • FSMC_NOE 信号通常连接到外部存储器的 OE 引脚,表示“是否允许数据输出”。
  2. 在读取操作中的作用

    • FSMC 进行读取操作时,FSMC_NOE 被拉低,通知外部存储器将数据放到数据总线上。
    • 在写操作或非活跃状态时,FSMC_NOE 保持高电平。

FSMC_NOE 的时序关系

FSMC_NOE 的控制通常与以下信号配合使用:

  1. FSMC_NE(芯片选择,Chip Select)
    • FSMC_NE 用于选择具体的外部存储器芯片。
    • FSMC_NE 为低电平时,选中的外部存储器被激活。
  2. FSMC_NWE(写使能,Write Enable)
    • 用于指示写操作。
    • FSMC_NWE 为低电平时,表示正在向存储器写入数据。
  3. 地址和数据总线(FSMC_A 和 FSMC_D)
    • 地址总线(FSMC_A)提供要访问的外部存储器地址。
    • 数据总线(FSMC_D)用于传输数据。

典型的读取时序如下:

  • FSMC 控制 FSMC_NE(芯片使能)和 FSMC_NOE(输出使能)信号,激活外部存储器的数据输出。
  • FSMC_NOE 拉低后,外部存储器将数据输出到数据总线上。
  • 数据输出完成后,FSMC 会将 FSMC_NOE 拉高,关闭数据输出。

使用FSMC驱动LCD

FSMC时序介绍 

FSMC是Flexible灵活的,可以产生多种时序来控制外部存储器。

  NOR/PSRAM控制器产生的异步时序就有5种,总体分为两类:一类是模式1,其他为拓展模式。

  拓展模式相对模式1来说读写时序时间参数设置可以不同,满足存储器读写时序不一样需求。

时序特性中的 OE

在时序特性中,“OE 在读取时序片选过程中不翻转” 或 “OE 在读取时序片选过程中翻转” 指的是 FSMC 控制 OE 信号在读取操作期间的状态行为:

  1. 不翻转

    • 读取操作开始时,FSMC 会将 OE 拉低,保持不变直到读取完成。
    • 这种方式适用于大多数 SRAM 或 CRAM 类型存储器。
  2. 翻转

    • 读取操作期间,FSMC 会在不同阶段对 OE 信号进行翻转(拉低-拉高-拉低),以协调更复杂的外部存储器时序。
    • 这种方式适用于特定类型的外部存储器,例如一些特殊的 SRAM 或 PSRAM。

 

 ILI9341重点时序:

读ID低电平脉宽(trdl)                        读ID高电平脉宽(trdh)

读FM低电平脉宽(trdlfm)                  读FM高电平脉宽(trdhfm)

写控制低电平脉宽(twrl)                    写控制高电平脉宽(twrh)

ID:指LCD的ID号                FM指帧缓存即GRAM

FSMC时序中ADDSET和DATAST不需要严格要求,可以使用实践值

 

FSMC地址映射 

使用FSMC外接存储器,其存储单元是映射到STM32的内部寻址空间的。

从FSMC角度看,可以把外部存储器划分为固定大小为256M字节的四个存储块。

FSMC存储块1被分为4个区,每个区管理64M字节空间。(64M Byte = 2^26 Byte)

 HADDRFSMC_A关系

HADDR总线是转换到外部存储器的内部AHB地址线。

简单来说,从CPU通过AHB总线到外部信号线之间的关系。

HADDR是字节地址,而存储器访问不都是按字节访问,接到存储器的地址线与其数据宽度相关。

注意:数据宽度为16位时,地址存在偏移

 LCDRS信号线与地址线关系

8080接口中RS(数据/命令选择线),用FSMC的某根A地址线进行替换。

FSMC_A10接到RS线上

        当FSMC_A10为高电平时(即RS为高电平),FSMC_D[15:0]被理解为数据。

        当FSMC_A10为低电平时(即RS为低电平),FSMC_D[15:0]被理解为命令。

究竟发送什么地址代替?

1、确认FSMC_NE4基地址:       

 0x6C00 0000        NEx(x=1…4):0x6000 0000 + (0x400 0000 * (x - 1))

2、确认FSMC_A10对应地址值

2^10 x 2 = 0x800        FSMC_Ay(y=0…25): 2^y x 2

3、确认两个地址

代表LCD命令的地址:0x6C00 0000

代表LCD数据的地址:0x6C00 0800

FSMC相关寄存器介绍

        对于NOR_FLASH/PSRAM控制器(存储块1)配置工作,通过FSMC_BCRx、FSMC_BTRx和FSMC_BWTRx寄存器设置(其中x=1~4,对应4个区)。

SRAM/NOR闪存片选控制寄存器(FSMC_BCRx 

 EXTMOD:扩展模式使能位,控制是否允许读写不同的时序。读和写用不同的时序,该位设置为1

WREN:写使能位。        向TFTLCD写入数据,该位设置1

 MWID[1:0]:存储器数据总线宽度。00,表示8位数据模式;01表示16位数据模式;10和11保留。

MTYP[1:0]:存储器类型。00表示SRAM、ROM;01表示PSRAM;10表示NOR FLASH;11保留。 

MBKEN:存储块使能位。该位设置1

SRAM/NOR闪存片选时序寄存器(FSMC_BTRx

ACCMOD[1:0]访问模式。00:模式A01:模式B10:模式C11:模式D

DATAST[7:0]数据保持时间,等于DATAST(+1)HCLK时钟周期,DATAST最大为255

对于ILI9341来说,其实就是RD低电平持续时间,最小为355ns

对于F1,一个HCLK = 13.9ns(1/72M),设置为15 (STM32F1的FSMC性能存在问题

对于F4,一个HCLK = 6ns(1/168M),设置为60

ADDSET[3:0]地址建立时间。表示ADDSET(+1)HCLK时钟周期,ADDSET最大为15

对于ILI9341来说,相当于RD高电平持续时间,为90ns

F1即使设置为0RD也有超过90ns的高电平,这里设置为1F4对该位设置为15

        如果未设置EXTMOD位,则读写共用这个时序寄存器!

SRAM/NOR闪存写时序寄存器(FSMC_BWTRx

 ACCMOD[1:0]:访问模式。00:模式A01:模式B10:模式C11:模式D

DATAST[7:0]数据保持时间,等于DATAST(+1)HCLK时钟周期,DATAST最大为255

对于ILI9341来说,其实就是WR低电平持续时间,最小为15ns

对于F1,一个HCLK = 13.9ns,设置为3

对于F4,一个HCLK = 6ns,设置为9

ADDSET[3:0]地址建立时间。表示ADDSET(+1)HCLK时钟周期,ADDSET最大为15

对于ILI9341来说,相当于WR高电平持续时间,为15ns

F1即使设置为1WR也有超过15ns的高电平,这里设置为1

F4对该位设置为8

FSMC寄存器组合说明

        在ST官方提供的寄存器定义里面,并没有定义FSMC_BCRxFSMC_BTRxFSMC_BWTRx等这个单独的寄存器,而是将他们进行了一些组合,规则如下:

FSMC_BCRxFSMC_BTRx,组合成BTCR[8]寄存器组,他们的对应关系如下:

          BTCR[0]对应FSMC_BCR1BTCR[1]对应FSMC_BTR1

          BTCR[2]对应FSMC_BCR2BTCR[3]对应FSMC_BTR2

          BTCR[4]对应FSMC_BCR3BTCR[5]对应FSMC_BTR3

          BTCR[6]对应FSMC_BCR4BTCR[7]对应FSMC_BTR4

FSMC_BWTRx则组合成BWTR[7]寄存器组,他们的对应关系如下:

          BWTR[0]对应FSMC_BWTR1BWTR[2]对应FSMC_BWTR2

          BWTR[4]对应FSMC_BWTR3BWTR[6]对应FSMC_BWTR4

          BWTR[1]、BWTR[3]BWTR[5]保留,没有用到

FSMC相关HAL库函数简介

        本例程涉及HAL库相关函数如下:

HAL_StatusTypeDef HAL_SRAM_Init ( 
SRAM_HandleTypeDef *hsram,
FSMC_NORSRAM_TimingTypeDef *Timing,
FSMC_NORSRAM_TimingTypeDef *ExtTiming )

 SRAM_HandleTypeDef

typedef struct 
{ FSMC_NORSRAM_TypeDef *Instance;				/* 寄存器基地址 */FSMC_NORSRAM_EXTENDED_TypeDef *Extended; 	/* 扩展模式寄存器基地址 */ FSMC_NORSRAM_InitTypeDef Init;				/* SRAM初始化结构体*/ HAL_LockTypeDef Lock; 						/* SRAM锁对象结构体 */ __IO HAL_SRAM_StateTypeDef State; 			/* SRAM设备访问状态 */ DMA_HandleTypeDef *hdma; 					/* DMA结构体 */ 
} SRAM_HandleTypeDef;

寄存器基地址选择:FSMC_NORSRAM_DEVICE

扩展模式寄存器基地址:FSMC_NORSRAM_EXTERNDEVICE

FSMC_NORSRAM_InitTypeDef

typedef struct 
{ uint32_t NSBank; 				/* 存储区块号 */ uint32_t DataAddressMux; 		/* 地址/数据复用使能 */ 	uint32_t MemoryType; 			/* 存储器类型 */ 	uint32_t MemoryDataWidth; 		/* 存储器数据宽度 */uint32_t BurstAccessMode;		/* 设置是否支持突发访问模式,只支持同步类型的存储器 */uint32_t WaitSignalPolarity;	/* 设置等待信号的极性 */uint32_t WrapMode; 			    /* 突发模式下存储器传输使能 */uint32_t WaitSignalActive; 		/* 等待信号在等待状态之前或等待状态期间有效 */ uint32_t WriteOperation; 		/* 存储器写使能 */ uint32_t WaitSignal; 			/* 是否使能等待状态插入 */ uint32_t ExtendedMode; 		    /* 使能或者禁止使能扩展模式 */ uint32_t AsynchronousWait; 		/* 用于异步传输期间,使能或者禁止等待信号 */ uint32_t WriteBurst; 			/* 用于使能或者禁止异步的写突发操作 */ uint32_t PageSize; 				/* 设置页大小 */ 
} FSMC_NORSRAM_InitTypeDef;

 储存区块号选择:FSMC_NORSRAM_BANK4

地址/数据复用功能选择:FSMC_DATA_ADDRESS_MUX_DISABLE

储存器类型选择:FSMC_MEMORY_TYPE_SRAM

储存器数据宽度选择:FSMC_NORSRAM_MEM_BUS_WIDTH_16

储存器写使能选择:FSMC_WRITE_OPERATION_ENABLE

使能或者禁止使能扩展模式选择:FSMC_EXTENDED_MODE_ENABLE

FSMC_NORSRAM_TimingTypeDef

typedef struct 
{ uint32_t AddressSetupTime; 			/* 地址建立时间 */ uint32_t AddressHoldTime; 			/* 地址保持时间 */ 	uint32_t DataSetupTime; 			/* 数据建立时间 */ 	uint32_t BusTurnAroundDuration; 	/* 总线周转阶段的持续时间 */uint32_t CLKDivision;				/* CLK时钟输出信号的周期 */uint32_t DataLatency;				/* 同步突发NOR FLASH的数据延迟 */uint32_t AccessMode;				/* 异步模式配置 */
} FSMC_NORSRAM_InitTypeDef;

这里要配置addressSetupTime地址建立时间和DataSetupTime数据建立时间。

FSMC模拟8080时序读写简化代码

void lcd_wr_cmd(volatile uint16_t cmd){cmd = cmd;*(uint16_t *)(FSMC_ADDR_CMD) = cmd;}
void lcd_wr_data(volatile uint16_t data)
{data = data;*(uint16_t *)(FSMC_ADDR_DATA) = data;
}
uint16_t lcd_rd_data(void)
{volatile uint16_t ram; 	ram = *(uint16_t *)(FSMC_ADDR_DATA);return ram;
}

硬件IO连接关系

相关文章:

初学stm32 --- FSMC驱动LCD屏

目录 FSMC简介 FSMC框图介绍 FSMC通信引脚介绍 FSMC_NWE 的作用 FSMC_NWE 的时序关系 FSMC_NOE 的含义 FSMC_NOE 的典型用途 FSMC_NOE 的时序关系 使用FSMC驱动LCD FSMC时序介绍 时序特性中的 OE ILI9341重点时序: FSMC地址映射 HADDR与FSMC_A关系 LCD的…...

Scala_【4】流程控制

第四章 分支控制if-else单分支双分支多分支返回值嵌套分支 For循环控制包含边界不包含边界循环守卫循环步长嵌套循环循环返回值 While循环Break友情链接 分支控制if-else 单分支 双分支 多分支 返回值 嵌套分支 For循环控制 Scala也为for循环这一常见的控制结构提供了非常多的…...

mysql带自动递增列的表删除数据后如何重置递增值

mysql带自动递增列的表删除数据后如何重置递增值 在 MySQL 中,如果你删除了表中的数据,自动递增列的值 不会自动重置。如果你希望在删除数据后重新设置自动递增列的值,可以使用以下几种方法: 1. 使用 ALTER TABLE 重置自动递增值…...

[CTF/网络安全] 攻防世界 simple_php 解题详析

题目描述:小宁听说php是最好的语言,于是她简单学习之后写了几行php代码。 代码解读 $a$_GET[a]; 从HTTP GET请求参数中获取一个名为a的变量,并将其赋值给变量a。符号用于禁止错误输出,如果不存在参数a则会将变量a设置为NULL。 $b$_GET[b];…...

Android 第三方框架:网络框架:OkHttp:源码分析:缓存

文章目录 概述磁盘缓存 类结构 InternalCache接口DiskLruCahce.Entry内部类DiskLruCahce.Snapshot内部类DiskLruCahce.Editor内部类DiskLruCahce类Cahce.Entry内部类Cahce类总结概述 不存在内存缓存,只存在磁盘缓存 磁盘缓存 磁盘缓存 类结构 主要InternalCache接口、Dis…...

大数据新视界 -- Hive 集群搭建与配置的最佳实践(2 - 16 - 13)

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…...

C# 设计模式(结构型模式):组合模式

C# 设计模式(结构型模式):组合模式 在软件设计中,有时我们需要处理的是一组对象,而这些对象既可以是单独的元素,也可以是由多个子元素组成的复合体。这时,组合模式(Composite Patte…...

Aloudata AIR | 逻辑数据平台的 NoETL 之道

一文为你介绍 Aloudata AIR 逻辑数据平台的技术原理与核心价值 本文主旨是介绍逻辑数据平台的技术原理与核心价值,包含几个部分的内容: 首先,简要阐述逻辑数据平台出现的背景;其次,详细讲解逻辑数据平台的构建方法&am…...

js的一些处理

1.翻转字符串 let str abcdef str str.split().reverse().join() console.log(str) 因此想到了我之前写的截取字符串获取参数跳转,在写一遍 let str nameJack&age18&gender男 let list str.split(&); let obj {} list.forEach((v)>{ …...

NLP 复习大纲

CH3 激活函数意义 增强网络表达能力,引入非线性因素 连续可导的非线性函数 尽可能简单 导数的值域要在合适的范围内 为什么会发生梯度消失 误差传播的迭代公式为: 其中需要用到激活函数的导数,而激活函数的导数值小于1时,误差经过…...

Kafka的rebalance机制

1、什么是 rebalance 机制 重平衡(rebalance)机制规定了如何让消费者组下的所有消费者来分配 topic 中的每一个分区。 2、rebalance 机制的触发条件是什么 (1)消费者组内成员变更 成员增加:当有新的消费者加入到消费…...

【git】git stash相关指令

目录 git stashgit stash save “”git stash list: 获取stash列表git stash pop:恢复最近一次stash缓存git stash apply stash{index}: 恢复指定缓存在这里插入图片描述git stash drop stash{1}:删除指定缓存 git stash clear :删除stash gi…...

BLIP论文笔记

论文地址 BLIP: Bootstrapping Language-Image Pre-training for Unified Vision-Language Understanding and Generation 论文思想 其实Clip就相当于只用了ITC...

设计模式-创建型设计模式总结

创建型设计模式(Creational Design Patterns)是 设计模式 中的一类,专注于如何实例化对象或类。它们提供了一些优雅的方式来创建对象,允许程序在对象创建过程中更灵活地进行管理,从而提高系统的扩展性和维护性。 创建…...

Java-多种方法实现多线程卖票

Java多线程卖票是一个经典的并发编程问题,它展示了如何在多个线程之间安全地共享和修改资 源。以下是几种实现方式: 使用synchronized关键字: 使用synchronized修饰符来同步方法或代码块,确保同一时刻只有一个线程可以访问临界区(即操 作共享资源的代码)。 使用Reen…...

嵌入式系统开发笔记112:通过有人云测试MQTT

文章目录 前言一、MQTT1、基本原理(1)发布 / 订阅模式:(2)主题系统:2、特点(1)轻量级:(2)可靠性:(3)低功耗:3、消息主题的命名(1)使用正斜杠(/)分隔层级:(2)区分大小写:(3)避免特殊字符:4、客户端ID(1)作用a、连接标识:b、消息路由与管理:c、会话…...

C++ Latch 和 Barrier: 新手指南

文章目录 什么是 Latch 和 Barrier?为什么要使用 Latch 和 Barrier?代码示例示例 1: 使用 std::latch示例 2: 多阶段任务示例 3: 使用 std::barrier 何时使用?优势使用时需要注意的事项参考链接源码链接 随着并发和并行编程的重要性日益增加, 理解像 Latch 和 Barrier 这样的…...

【Cocos TypeScript 零基础 4.1】

目录 背景滚动 背景滚动 创建一个 空节点 背景丟进去 ( 复制一个,再丢一次都行) 新建TS脚本 并绑定到 空节点 上 再对TS脚本进行编辑 export class TS2bg extends Component {property (Node) // 通过属性面板去赋值bg1:Node nullproperty (Node) bg2:Node nullprope…...

区块链安全常见的攻击合约和简单复现,附带详细分析——不安全调用漏洞 (Unsafe Call Vulnerability)【6】

区块链安全常见的攻击分析——不安全调用漏洞 Unsafe Call Vulnerability 1.1 漏洞合约1.2 漏洞分析1.3 攻击步骤分析1.4 攻击合约 Name: 不安全调用漏洞 (Unsafe Call Vulnerability) 重点: 在 TokenWhale 合约的 approveAndCallcode 函数中,漏洞允许任…...

鸿蒙应用开发搬砖经验之—使用ArkWeb要开启文档对象模型存储接口权限(DOM Storage API权限)

如题,该属性/功能默认是没有开启的!!!! 所以需要我们手动开启,否侧加载的H5 SPA大概率功能不正常,因为现在大多数的H5应用都用遇到对象模型存储的功能,对应的接口是 不开启一般会…...

UDP(Echoserver)

网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

【Zephyr 系列 10】实战项目:打造一个蓝牙传感器终端 + 网关系统(完整架构与全栈实现)

🧠关键词:Zephyr、BLE、终端、网关、广播、连接、传感器、数据采集、低功耗、系统集成 📌目标读者:希望基于 Zephyr 构建 BLE 系统架构、实现终端与网关协作、具备产品交付能力的开发者 📊篇幅字数:约 5200 字 ✨ 项目总览 在物联网实际项目中,**“终端 + 网关”**是…...

IT供电系统绝缘监测及故障定位解决方案

随着新能源的快速发展,光伏电站、储能系统及充电设备已广泛应用于现代能源网络。在光伏领域,IT供电系统凭借其持续供电性好、安全性高等优势成为光伏首选,但在长期运行中,例如老化、潮湿、隐裂、机械损伤等问题会影响光伏板绝缘层…...

Scrapy-Redis分布式爬虫架构的可扩展性与容错性增强:基于微服务与容器化的解决方案

在大数据时代,海量数据的采集与处理成为企业和研究机构获取信息的关键环节。Scrapy-Redis作为一种经典的分布式爬虫架构,在处理大规模数据抓取任务时展现出强大的能力。然而,随着业务规模的不断扩大和数据抓取需求的日益复杂,传统…...

论文阅读笔记——Muffin: Testing Deep Learning Libraries via Neural Architecture Fuzzing

Muffin 论文 现有方法 CRADLE 和 LEMON,依赖模型推理阶段输出进行差分测试,但在训练阶段是不可行的,因为训练阶段直到最后才有固定输出,中间过程是不断变化的。API 库覆盖低,因为各个 API 都是在各种具体场景下使用。…...

在树莓派上添加音频输入设备的几种方法

在树莓派上添加音频输入设备可以通过以下步骤完成,具体方法取决于设备类型(如USB麦克风、3.5mm接口麦克风或HDMI音频输入)。以下是详细指南: 1. 连接音频输入设备 USB麦克风/声卡:直接插入树莓派的USB接口。3.5mm麦克…...

深度学习之模型压缩三驾马车:模型剪枝、模型量化、知识蒸馏

一、引言 在深度学习中,我们训练出的神经网络往往非常庞大(比如像 ResNet、YOLOv8、Vision Transformer),虽然精度很高,但“太重”了,运行起来很慢,占用内存大,不适合部署到手机、摄…...

SpringAI实战:ChatModel智能对话全解

一、引言:Spring AI 与 Chat Model 的核心价值 🚀 在 Java 生态中集成大模型能力,Spring AI 提供了高效的解决方案 🤖。其中 Chat Model 作为核心交互组件,通过标准化接口简化了与大语言模型(LLM&#xff0…...

API网关Kong的鉴权与限流:高并发场景下的核心实践

🔥「炎码工坊」技术弹药已装填! 点击关注 → 解锁工业级干货【工具实测|项目避坑|源码燃烧指南】 引言 在微服务架构中,API网关承担着流量调度、安全防护和协议转换的核心职责。作为云原生时代的代表性网关,Kong凭借其插件化架构…...