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

STM32——SPI通信

文章目录

    • SPI(Serial Peripheral Interface)概述:
    • SPI的硬件连接:
    • SPI的特点和优势:
    • SPI的常见应用:
    • SPI的工作方式和时序图分析:
      • 工作模式
      • 传输模式与时序分析
      • 工作流程
    • SPI设备的寄存器结构和寄存器设置
      • SPI设备寄存器结构:
      • 常见的寄存器设置:
    • STM32F4xx SPI 模块特性
    • 如何调试SPI通信问题和故障排除

SPI(Serial Peripheral Interface)概述:

SPI是一种串行通信接口,用于在微控制器、传感器、存储器等设备之间进行数据传输。
SPI通信通常涉及一个主设备(Master)和一个或多个从设备(Slave),通过共享时钟信号和数据线进行通信。

SPI的硬件连接:

SPI使用四条信号线:时钟线(SCLK)、主设备输出线(MOSI)、主设备输入线(MISO)和片选线(SS)。
通信过程中,主设备通过时钟线产生时钟信号,控制数据传输的时序。
主设备通过MOSI线发送数据,而从设备通过MISO线返回响应数据。
片选线用于选择要与主设备进行通信的从设备。
在这里插入图片描述
一主一从连接
在这里插入图片描述
一主多从连接
在这里插入图片描述

SPI的特点和优势:

SPI支持高速的全双工数据传输、只需少量的信号线和硬件引脚、SPI可以连接多个从设备,每个从设备都有独立的片选线,方便扩展和集成多个设备、SPI通常用于设备之间的短距离通信,如同一个电路板上的通信。

SPI的常见应用:

存储器接口:SPI常用于与闪存、EEPROM等存储器设备进行通信。
传感器接口:许多传感器模块使用SPI接口与主控制器通信,如加速度计、陀螺仪等。
显示器接口:某些显示模块使用SPI接口进行数据传输。
无线通信模块:一些无线模块,如WiFi模块、蓝牙模块等,可以通过SPI与主控制器通信。

SPI的工作方式和时序图分析:

工作模式

配置SPI设备的参数,如时钟频率、数据位数和传输模式。本模块代码参考博客:https://blog.51cto.com/u_15903730/6163015
主模式(Master Mode):
在主模式下,一个主设备控制整个SPI通信过程。主设备负责生成时钟信号(SCLK)和控制片选信号(SS)来选择从设备,并通过MOSI线(Master Output Slave Input)向从设备发送数据。同时,主设备通过MISO线(Master Input Slave Output)接收从设备返回的数据。

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include "stm32f4xx.h"#define SPIx            SPI1
#define GPIO_AF_SPIx     GPIO_AF5_SPI1
#define GPIO_CS         GPIO_Pin_4
#define GPIO_CLK        GPIO_Pin_5
#define GPIO_MISO       GPIO_Pin_6
#define GPIO_MOSI       GPIO_Pin_7void init_spi(void)
{SPI_InitTypeDef spi_init_struct;GPIO_InitTypeDef gpio_init_struct;/* Enable the SPI clock */RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE);/* Enable the GPIO clock */RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);/* Configure the chip select pin as output */gpio_init_struct.GPIO_Mode = GPIO_Mode_OUT;gpio_init_struct.GPIO_OType = GPIO_OType_PP;gpio_init_struct.GPIO_Pin = GPIO_CS;gpio_init_struct.GPIO_PuPd = GPIO_PuPd_NOPULL;gpio_init_struct.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &gpio_init_struct);/* Configure the SPI pins */gpio_init_struct.GPIO_Mode = GPIO_Mode_AF;gpio_init_struct.GPIO_OType = GPIO_OType_PP;gpio_init_struct.GPIO_Pin = GPIO_CLK | GPIO_MISO | GPIO_MOSI;gpio_init_struct.GPIO_PuPd = GPIO_PuPd_NOPULL;gpio_init_struct.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &gpio_init_struct);/* Connect the SPI pins to their alternate functions */GPIO_PinAFConfig(GPIOA, GPIO_PinSource5, GPIO_AF_SPIx);GPIO_PinAFConfig(GPIOA, GPIO_PinSource6, GPIO_AF_SPIx);GPIO_PinAFConfig(GPIOA, GPIO_PinSource7, GPIO_AF_SPIx);/* Configure the SPI peripheral */spi_init_struct.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_4;spi_init_struct.SPI_CPHA = SPI_CPHA_1Edge;spi_init_struct.SPI_CPOL = SPI_CPOL_Low;spi_init_struct.SPI_CRCPolynomial = 7;spi_init_struct.SPI_DataSize = SPI_DataSize_8b;spi_init_struct.SPI_Direction = SPI_Direction_2Lines_FullDuplex;spi_init_struct.SPI_FirstBit = SPI_FirstBit_MSB;spi_init_struct.SPI_Mode = SPI_Mode_Master;spi_init_struct.SPI_NSS = SPI_NSS_Soft;SPI_Init(SPIx, &spi_init_struct);/* Enable the SPI peripheral */SPI_Cmd(SPIx, ENABLE);
}uint8_t spi_send_byte(uint8_t byte)
{/* Wait for any pending transfers to complete */while (SPI_I2S_GetFlagStatus(SPIx, SPI_I2S_FLAG_TXE) == RESET);/* Send the byte */SPI_I2S_SendData(SPIx, byte);/* Wait for the transfer to complete */while (SPI_I2S_GetFlagStatus(SPIx, SPI_I2S_FLAG_RXNE) == RESET);/* Return the received byte */return SPI_I2S_ReceiveData(SPIx);
}int main(void)
{uint8_t data;/* Initialize the SPI module */init_spi();/* Select the slave device */GPIO_ResetBits(GPIOA, GPIO_CS);/* Send some data */data = spi_send_byte(0xAA);printf("Received: 0x%02X\n", data);/* Deselect the slave device */GPIO_SetBits(GPIOA, GPIO_CS);return 0;
}

从模式(Slave Mode):
在从模式下,从设备被动地响应主设备的控制。从设备通过MISO线接收主设备发送的数据,并通过MOSI线向主设备返回数据。从设备在接收到有效的片选信号(SS)后才会响应数据传输。

#include <stdio.h>
#include <stdlib.h>
#include <stdint.h>
#include "stm32f4xx.h"#define SPIx            SPI1
#define GPIO_AF_SPIx     GPIO_AF5_SPI1
#define GPIO_CS         GPIO_Pin_4
#define GPIO_CLK        GPIO_Pin_5
#define GPIO_MISO       GPIO_Pin_6
#define GPIO_MOSI       GPIO_Pin_7void init_spi(void)
{SPI_InitTypeDef spi_init_struct;GPIO_InitTypeDef gpio_init_struct;/* Enable the SPI clock */RCC_APB2PeriphClockCmd(RCC_APB2Periph_SPI1, ENABLE);/* Enable the GPIO clock */RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA, ENABLE);/* Configure the chip select pin as output */gpio_init_struct.GPIO_Mode = GPIO_Mode_OUT;gpio_init_struct.GPIO_OType = GPIO_OType_PP;gpio_init_struct.GPIO_Pin = GPIO_CS;gpio_init_struct.GPIO_PuPd = GPIO_PuPd_NOPULL;gpio_init_struct.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &gpio_init_struct);/* Configure the SPI pins */gpio_init_struct.GPIO_Mode = GPIO_Mode_AF;gpio_init_struct.GPIO_OType = GPIO_OType_PP;gpio_init_struct.GPIO_Pin = GPIO_CLK | GPIO_MISO | GPIO_MOSI;gpio_init_struct.GPIO_PuPd = GPIO_PuPd_NOPULL;gpio_init_struct.GPIO_Speed = GPIO_Speed_50MHz;GPIO_Init(GPIOA, &gpio_init_struct);/* Connect the SPI pins to their alternate functions */GPIO_PinAFConfig(GPIOA, GPIO_PinSource5, GPIO_AF_SPIx);GPIO_PinAFConfig(GPIOA, GPIO_PinSource6, GPIO_AF_SPIx);GPIO_PinAFConfig(GPIOA, GPIO_PinSource7, GPIO_AF_SPIx);/* Configure the SPI peripheral */spi_init_struct.SPI_BaudRatePrescaler = SPI_BaudRatePrescaler_4;spi_init_struct.SPI_CPHA = SPI_CPHA_1Edge;spi_init_struct.SPI_CPOL = SPI_CPOL_Low;spi_init_struct.SPI_CRCPolynomial = 7;spi_init_struct.SPI_DataSize = SPI_DataSize_8b;spi_init_struct.SPI_Direction = SPI_Direction_2Lines_FullDuplex;spi_init_struct.SPI_FirstBit = SPI_FirstBit_MSB;spi_init_struct.SPI_Mode = SPI_Mode_Slave;spi_init_struct.SPI_NSS = SPI_NSS_Hard;SPI_Init(SPIx, &spi_init_struct);/* Enable the SPI peripheral */SPI_Cmd(SPIx, ENABLE);
}uint8_t spi_receive_byte(void)
{/* Wait for any pending transfers to complete */while (SPI_I2S_GetFlagStatus(SPIx, SPI_I2S_FLAG_TXE) == RESET);/* Return the received byte */return SPI_I2S_ReceiveData(SPIx);
}void spi_send_byte(uint8_t byte)
{/* Wait for any pending transfers to complete */while (SPI_I2S_GetFlagStatus(SPIx, SPI_I2S_FLAG_TXE) == RESET);/* Send the byte */SPI_I2S_SendData(SPIx, byte);/* Wait for the transfer to complete */while (SPI_I2S_GetFlagStatus(SPIx, SPI_I2S_FLAG_RXNE) == RESET);/* Clear the receive buffer */SPI_I2S_ReceiveData(SPIx);
}int main(void)
{uint8_t data;/* Initialize the SPI module */init_spi();/* Wait for the chip select signal */while (GPIO_ReadInputDataBit(GPIOA, GPIO_CS) != Bit_RESET);/* Loop forever */while (1){/* Receive some data */data = spi_receive_byte();/* Process the data */printf("Received: 0x%02X\n", data);/* Send a response */spi_send_byte(0xAA);}return 0;
}

传输模式与时序分析

时钟极性和相位(Clock Polarity and Phase):
SPI接口还具有时钟极性(CPOL)和时钟相位(CPHA)的设置。CPOL定义了时钟信号在空闲状态时的电平,可以是高电平(CPOL=1)或低电平(CPOL=0)。CPHA定义了数据采样的时机,可以是在时钟信号的上升沿(CPHA=0)或下降沿(CPHA=1)进行采样。
根据CPOL和CPHA的不同组合,可以有四种不同的时钟极性和相位模式,分别为:

模式0:CPOL=0,CPHA=0
模式1:CPOL=0,CPHA=1
模式2:CPOL=1,CPHA=0
模式3:CPOL=1,CPHA=1

时钟极性和相位的设置需要主设备和从设备之间保持一致,以确保正确的数据传输。SPI 总线有四种工作方式(SP0, SP1, SP2, SP3),其中使用的最为广泛的是 SPI0 和和 SPI3 方式

读取数据方式:
00 起始电平为低电平—>数据采样(读数据)在第一个边沿,时钟线从低到高跳变的时候,数据线保持不变,这时候读数据,时钟线从高到底跳变的时候,数据线可以变化,发送数据,所以上升沿读,下降沿写

01 起始电平为低电平—>数据采样(读数据)在第二个边沿,时钟线从低到高跳变的时候,数据线可以变化,发送数据,时钟线从高到底跳变的时候,数据线保持不变,这时候读数据,所以上升沿写,下降沿读

10 起始电平是高点平—>数据采样(读数据)在第一个边沿,时钟线从高到低跳变的时候,数据线保持不变,这时候读数据,时钟线从低到高跳变的时候,数据线可以变化,发送数据,所以,下降沿读,上升沿写

11 起始电平是高点平—>数据采样(读数据)在第二个边沿,时钟线从高到低跳变的时候,数据线可以变化,发送数据,时钟线从低到高跳变的时候,数据线保持不变,这时候读数据,所以,下降沿写,上升沿读
在这里插入图片描述
每次传输数据的宽度为 8bit,上升沿发送、下降沿接收、高位先发送。
上升沿到来的时候,MOSI 上的电平将被发送到从设备的寄存器中。
下降沿到来的时候,MISO 上的电平将被接收到主设备的寄存器中。

在这里插入图片描述

工作流程

  1. SPI通信工作流程
    1)硬件连接:
    首先,确保SPI主机(如微控制器)和SPI从机(外部设备)之间正确连接。通常,SPI通信需要四根线:SCLK(时钟线)、MOSI(主机输出从机输入线)、MISO(主机输入从机输出线)和SS(从机选择线)。
    2)主机配置:
    主机(如微控制器)需要配置SPI控制器的相关寄存器或寄存器位,以设置通信参数,如时钟速率、数据位顺序、数据传输模式等。
    3)选择从机:
    主机通过设置SS线(从机选择线)来选择要与之通信的从机。如果有多个从机连接到同一总线,主机需要选择其中一个从机与之通信,常通过将SS线拉低来选中对应的从机。
    4)数据传输:
    SPI通信是全双工的,数据可以同时在主机和从机之间传输。
    主机通过SCLK线发送时钟信号,驱动数据传输的时序。主机在每个时钟周期的上升沿或下降沿将数据位推送到MOSI线上,发送给从机。从机在相应的时钟边沿读取MOSI线上的数据位,并将响应的数据位推送到MISO线上,供主机读取。数据传输可以按照指定的字节、位数或连续传输的方式进行。
    5)传输完成:
    传输完成后,可以继续进行下一次传输或者释放SPI总线。

SPI设备的寄存器结构和寄存器设置

SPI设备寄存器结构:

控制寄存器(Control Register):控制SPI设备的操作模式、时钟频率、数据位顺序等设置。
状态寄存器(Status Register):提供SPI设备的状态信息,如传输完成标志、错误标志等。
数据寄存器(Data Register):用于存储要发送或接收的数据。

常见的寄存器设置:

操作模式(Mode):SPI设备通常支持多种操作模式,如主模式(Master Mode)和从模式(Slave Mode)。通过控制寄存器的相关位,选择适当的模式。
时钟频率(Clock Frequency):SPI设备的通信速率由时钟频率决定。控制寄存器中的时钟分频位或配置寄存器可以用于设置合适的时钟频率。
时钟极性和相位(Clock Polarity and Phase):SPI设备的时钟极性(CPOL)和时钟相位(CPHA)设置决定了数据采样和传输的时机。通过控制寄存器的相关位设置CPOL和CPHA。
数据位顺序(Data Bit Order):SPI设备可以支持先传输最高有效位(MSB)或先传输最低有效位(LSB)。寄存器中的位序设置可以用于选择合适的数据位顺序。
中断使能(Interrupt Enable):SPI设备通常支持中断功能,用于通知主设备有数据可用或传输完成。中断使能位可以在控制寄存器中设置。
具体参考技术文档、参考文档、数据手册来确定产品的使用。

STM32F4xx SPI 模块特性

1) 由 SPI 模块中 SCLK、MOSI 和 MISO 三线组成全双工同步传输
2) 支持数据传输位宽为 8 位数据或 16 位数据
3) 可以通过软件设置 SPI 模块为主机模式或从机模式
4) 可以对 SPI 的时钟源进行分频,来做为作为主机或从机时的通讯速度(分频最大值为 fPCLK/2),但 STM32F401xE 的 SPI 模块最大通信速度为 42MHz (spi1,spi4)或者 21Mhz(spi2,spi3)。
5) 可以使用软件对 SPI 的通讯时序(时钟极性和时钟相位)进行选择
6) 可以对 SPI 数据传输顺序进行选择为最先移位 MSB 或 LSB
7) SPI 模块的中断源为:SPI 数据发送和接收、主模式故障、数据上溢(过载)以及 CRC 错误
8) SPI 可以利用 DMA 功能对数据进行每次 1 字节发送和接收。
在这里插入图片描述

如何调试SPI通信问题和故障排除

掌握常见的SPI通信错误和解决方法,如时钟频率不匹配、数据线连接错误等。
1.串口显示内容但是乱码:时钟频率两端不匹配,重新调频率
2.无现象或者本来有现象后来突然中断通信:数据线是否连接错误,附近是否有信号干扰,检查电源线是否未连接好
3.冲突和协议错误:和板子的协议不匹配,先查看协议,检查硬件连接是否正确,确保SPI主设备和从设备之间的通信协议和数据格式设置正确。检查SPI设备的地址、片选信号等设置是否正确。确保主设备和从设备之间的通信时序和协议一致。检查设备的文档和规格说明,确保了解正确的配置和操作方法。

相关文章:

STM32——SPI通信

文章目录 SPI&#xff08;Serial Peripheral Interface&#xff09;概述&#xff1a;SPI的硬件连接&#xff1a;SPI的特点和优势&#xff1a;SPI的常见应用&#xff1a;SPI的工作方式和时序图分析&#xff1a;工作模式传输模式与时序分析工作流程 SPI设备的寄存器结构和寄存器设…...

Linux虚拟机局域网IP配置

前言 应用程序包部署在主机&#xff08;Window&#xff09;的虚拟机&#xff08;Linux CentOS7&#xff09;上&#xff0c;把主机当做一个服务器&#xff0c;在局域网中访问部署在主机上的应用程序&#xff0c;配置Linux网络。 文章如有侵权&#xff0c;无意为之&#xff0c;…...

MacOS删除.DS_Store文件

目录 .DS_Store是什么删除命令防止再生命令 .DS_Store是什么 在 Mac OS X 系统下&#xff0c;几乎绝大部分文件夹中都包含 .DS_Store 隐藏文件&#xff0c;这里保存着针对这个目录的特殊信息和设置配置&#xff0c;例如查看方式、图标大小以及这个目录的一些附属元数据。 而在…...

ARM Linux DIY(十一)板子名称、开机 logo、LCD 控制台、console 免登录、命令提示符、文件系统大小

文章目录 前言板子名称uboot Modelkernel 欢迎词、主机名 开机 logoLCD 控制台console 免登录命令提示符文件系统大小 前言 经过前面十篇文章的介绍&#xff0c;硬件部分调试基本完毕&#xff0c;接下来的文章开始介绍软件的个性化开发。 板子名称 uboot Model 既然是自己的…...

【Unity程序技巧】Unity中的单例模式的运用

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…...

java leetcodetop100 (3,4 )最长连续数列,移动零

top3 最长连续数列 给定一个未排序的整数数组 nums &#xff0c;找出数字连续的最长序列&#xff08;不要求序列元素在原数组中连续&#xff09;的长度。 * * 请你设计并实现时间复杂度为 O(n) 的算法解决此问题。 * * * * 示例 1&#xff1a; * * 输入&#xff1a;nums [100,…...

用Vite从零到一创建React+ts项目

方式一&#xff1a;使用create-react-app命令创建项目 1、使用以下命令初始化一个空的npm 项目 npm init -y 2、输入以下命令安装React npm i create-react-app ps:如果失败的话尝试&#xff08;1&#xff1a;使用管理员身份执行命令&#xff08;2&#xff1a;切换镜像重…...

HTTP状态码301(永久重定向)不同Web服务器的配置方法

文章目录 301状态码通常在那些情况下使用301永久重定向配置Nginx配置301永久重定向Windows配置IIS301永久重定向PHP下的301重定向Apache服务器实现301重定向 301重定向是否违反相关法规&#xff1f;推荐阅读 当用户或搜索引擎向服务器发出浏览请求时&#xff0c;服务器返回的HT…...

vue-element-admin项目部署 nginx动态代理 含Docker部署、 Jenkins构建

介绍三种方式&#xff1a; 1.直接部署到nginx中 2.用nginx docker镜像部署 3.使用Jenkins构建 1.直接用nginx部署 vue-element-admin项目下有两个.env文件&#xff0c;.env.production是生产环境的&#xff0c;.env.developpment是开发环境的 vue-element-admin默认用的是mock数…...

使用Python来写模拟Xshell实现远程命令执行与交互

一、模块 这里使用的是 paramiko带三方库 pip install paramiko二、效果图 三、代码实现&#xff08;这里的IP&#xff0c;用户名&#xff0c;密码修改为自己对应服务器的&#xff09; import paramiko import timeclass Linux(object):# 参数初始化def __init__(self, ip, us…...

mybatis 数据库字段为空or为空串 忽略条件过滤, 不为空且不为空串时才需nameParam过滤条件

name未配置视为不考虑name条件 select * from user where (( (ISNULL(name)) OR (name) ) OR name #{user.nameParam} ) 三个or语句 推荐这个 select * from user where ISNULL(name) OR name OR name #{user.nameParam} select * from user where ISNULL(name) OR …...

【玩玩Vue】通过vue-store实现枚举管理,用于下拉选项和中英文翻译等

原文作者&#xff1a;我辈李想 版权声明&#xff1a;文章原创&#xff0c;转载时请务必加上原文超链接、作者信息和本声明。 文章目录 一、store基础用法1.在src下新建store文件夹&#xff0c;在store下新建module文件夹2.在module下新建enums.js文件3.在store下新建getters.js…...

ISCSI:后端卷以LVM 的方式配置 ISCSI 目标启动器

写在前面 准备考试整理相关笔记博文内容涉及使用 LVM 做ISCSI 目标后端块存储 Demo理解不足小伙伴帮忙指正 对每个人而言&#xff0c;真正的职责只有一个&#xff1a;找到自我。然后在心中坚守其一生&#xff0c;全心全意&#xff0c;永不停息。所有其它的路都是不完整的&#…...

八公山豆腐发展现状与销售对策研究

1.引言 八公山豆腐作为中国传统特色食品之一&#xff0c;一直以来备受人们的喜爱。然而&#xff0c;在现代社会中&#xff0c;由于消费者对于营养健康的追求以及市场竞争的加剧&#xff0c;八公山豆腐的市场份额逐渐缩小。因此&#xff0c;为了更好地推广和发展八公山豆腐&…...

排序算法-插入排序

属性 当插入第i(i>1)个元素时&#xff0c;前面的array[0],array[1],…,array[i-1]已经排好序&#xff0c;此时用array[i]的排序码与array[i1],array[i-2],…的排序码顺序进行比较&#xff0c;找到插入位置即将array[i]插入&#xff0c;原来位置上的元素顺序后移 直接插入排序…...

多位数按键操作(闪烁)数码管显示

/*----------------------------------------------- 内容&#xff1a;按键加减数字&#xff0c;多个数码管显示 ------------------------------------------------*/ #include<reg52.h> //包含头文件&#xff0c;一般情况不需要改动&#xff0c;头文件包含特殊功能寄存…...

MyEclipse项目导入与导出

一、项目导出 1、右键选择项目名称&#xff0c;弹出菜单中选择“export”&#xff0c;如下图所示 2、选择“恶心“export”&#xff0c;弹出菜单如下&#xff1b;在“General“选项中&#xff0c;选择“File System”选项 3、点击“next”&#xff0c;进入保存位置选择界面&am…...

ArrayList和LinkedList

最近在刷回溯算法时&#xff0c;遇见了List<Integer> A new ArrayList<>(); LinkedList<Integer> B new LinkedList<>();这类型的表达方式 很好奇的问题是&#xff1a; 1、List<Integer> A new ArrayList<>();为什么是正确的写法 2…...

Linux 配置 Nginx 服务完整详细版

目录 前言 配置Nginx监听端口和服务器块 # 防DDoS配置 # 日志配置 # 设置服务器块 监听端口 网站根目录 默认文件 静态文件目录 图像文件目录 # 自定义错误页面 # 反向代理配置 # 配置SSL/TLS 1、获取SSL/TLS证书 2、安装证书 3、配置SSL/TLS # 配置SSL协议版本…...

Python实现猎人猎物优化算法(HPO)优化LightGBM回归模型(LGBMRegressor算法)项目实战

说明&#xff1a;这是一个机器学习实战项目&#xff08;附带数据代码文档视频讲解&#xff09;&#xff0c;如需数据代码文档视频讲解可以直接到文章最后获取。 1.项目背景 猎人猎物优化搜索算法(Hunter–prey optimizer, HPO)是由Naruei& Keynia于2022年提出的一种最新的…...

【WiFi帧结构】

文章目录 帧结构MAC头部管理帧 帧结构 Wi-Fi的帧分为三部分组成&#xff1a;MAC头部frame bodyFCS&#xff0c;其中MAC是固定格式的&#xff0c;frame body是可变长度。 MAC头部有frame control&#xff0c;duration&#xff0c;address1&#xff0c;address2&#xff0c;addre…...

linux arm系统烧录

1、打开瑞芯微程序 2、按住linux arm 的 recover按键 插入电源 3、当瑞芯微检测到有设备 4、松开recover按键 5、选择升级固件 6、点击固件选择本地刷机的linux arm 镜像 7、点击升级 &#xff08;忘了有没有这步了 估计有&#xff09; 刷机程序 和 镜像 就不提供了。要刷的时…...

06 Deep learning神经网络编程基础 激活函数 --吴恩达

深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...

精益数据分析(97/126):邮件营销与用户参与度的关键指标优化指南

精益数据分析&#xff08;97/126&#xff09;&#xff1a;邮件营销与用户参与度的关键指标优化指南 在数字化营销时代&#xff0c;邮件列表效度、用户参与度和网站性能等指标往往决定着创业公司的增长成败。今天&#xff0c;我们将深入解析邮件打开率、网站可用性、页面参与时…...

Linux 中如何提取压缩文件 ?

Linux 是一种流行的开源操作系统&#xff0c;它提供了许多工具来管理、压缩和解压缩文件。压缩文件有助于节省存储空间&#xff0c;使数据传输更快。本指南将向您展示如何在 Linux 中提取不同类型的压缩文件。 1. Unpacking ZIP Files ZIP 文件是非常常见的&#xff0c;要在 …...

Java求职者面试指南:计算机基础与源码原理深度解析

Java求职者面试指南&#xff1a;计算机基础与源码原理深度解析 第一轮提问&#xff1a;基础概念问题 1. 请解释什么是进程和线程的区别&#xff1f; 面试官&#xff1a;进程是程序的一次执行过程&#xff0c;是系统进行资源分配和调度的基本单位&#xff1b;而线程是进程中的…...

在Mathematica中实现Newton-Raphson迭代的收敛时间算法(一般三次多项式)

考察一般的三次多项式&#xff0c;以r为参数&#xff1a; p[z_, r_] : z^3 (r - 1) z - r; roots[r_] : z /. Solve[p[z, r] 0, z]&#xff1b; 此多项式的根为&#xff1a; 尽管看起来这个多项式是特殊的&#xff0c;其实一般的三次多项式都是可以通过线性变换化为这个形式…...

Python 实现 Web 静态服务器(HTTP 协议)

目录 一、在本地启动 HTTP 服务器1. Windows 下安装 node.js1&#xff09;下载安装包2&#xff09;配置环境变量3&#xff09;安装镜像4&#xff09;node.js 的常用命令 2. 安装 http-server 服务3. 使用 http-server 开启服务1&#xff09;使用 http-server2&#xff09;详解 …...

uni-app学习笔记三十五--扩展组件的安装和使用

由于内置组件不能满足日常开发需要&#xff0c;uniapp官方也提供了众多的扩展组件供我们使用。由于不是内置组件&#xff0c;需要安装才能使用。 一、安装扩展插件 安装方法&#xff1a; 1.访问uniapp官方文档组件部分&#xff1a;组件使用的入门教程 | uni-app官网 点击左侧…...

基于江科大stm32屏幕驱动,实现OLED多级菜单(动画效果),结构体链表实现(独创源码)

引言 在嵌入式系统中&#xff0c;用户界面的设计往往直接影响到用户体验。本文将以STM32微控制器和OLED显示屏为例&#xff0c;介绍如何实现一个多级菜单系统。该系统支持用户通过按键导航菜单&#xff0c;执行相应操作&#xff0c;并提供平滑的滚动动画效果。 本文设计了一个…...