STM32G474RE之RTC

STM32G474RE之RTC使用HAL库实现RTC时间配置,以及报警配置,支持双路报警。

1、STM32G474RE的RTC晶振引脚:

OSC32_IN为PC14,OSC32_OUT为PC15;

2、Vbat引脚

Vbat引脚是用来给外部晶振LSE和备份寄存器提供电源。当没有“外部电池”连接到Vbat引脚,RTC会使用VDD供电。因此Vbat也可以不接“外部电池”。1.55V<Vbat<3.6V

通过上图,连接到Vbat的外部电池,需要设计充电电路给它充电

3、RTC_OUT映射

RTC报警输出RTC_OUT1和RTC_OUT2
RTC_OUT1为PC13,RTC_OUT2为PB2;

RTC_CR寄存器的bit22:21(OSEL[1:0])
OSEL[1:0]=00b,输出不使能
OSEL[1:0]=01b,RTC报警器A输出使能
OSEL[1:0]=10b,RTC报警器B输出使能
OSEL[1:0]=11b,RTC唤醒输出使能

RTC_CR寄存器的bit31(OUT2EN)
OUT2EN=0,RTC_OUT2输出不使能;
OUT2EN=1,RTC_OUT2输出使能;

RTC_CR寄存器的bit23(COE)
COE=0校准输出不使能
COE=1校准输出使能

RTC_CR寄存器的bit19(COSEL)
COE=1且COSEL=0,CALIB输出为512Hz
COE=1且COSEL=1,CALIB输出为1Hz

 4、测试程序

RTC.c程序

RTC_HandleTypeDef hrtc;void RTC_Init(void);
void RTC_Display(void);void TEST_Hal_RTC_Set_Alarm_A(void);
void TEST_Hal_RTC_Set_Alarm_B(void);void RTC_Init(void)
{RCC_OscInitTypeDef        RCC_OscInitStruct;  //配置LSE/LSI时钟RCC_PeriphCLKInitTypeDef  PeriphClkInitStruct;//用来为RTC选择时钟源__HAL_RCC_PWR_CLK_ENABLE();//Enable write accessHAL_PWR_EnableBkUpAccess();//Enable the power clock#ifdef RTC_CLOCK_SOURCE_LSERCC_OscInitStruct.OscillatorType =  RCC_OSCILLATORTYPE_LSI | RCC_OSCILLATORTYPE_LSE;RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;RCC_OscInitStruct.LSEState = RCC_LSE_ON;RCC_OscInitStruct.LSIState = RCC_LSI_OFF;HAL_RCC_OscConfig(&RCC_OscInitStruct);//配置LSE时钟,关闭LSI时钟PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_RTC;PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSE;HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct);//选择LSE时钟为RTC时钟源#elif defined (RTC_CLOCK_SOURCE_LSI)RCC_OscInitStruct.OscillatorType =  RCC_OSCILLATORTYPE_LSI;RCC_OscInitStruct.PLL.PLLState = RCC_PLL_NONE;RCC_OscInitStruct.LSIState = RCC_LSI_ON;HAL_RCC_OscConfig(&RCC_OscInitStruct);//配置LSI时钟PeriphClkInitStruct.PeriphClockSelection = RCC_PERIPHCLK_RTC;PeriphClkInitStruct.RTCClockSelection = RCC_RTCCLKSOURCE_LSI;HAL_RCCEx_PeriphCLKConfig(&PeriphClkInitStruct);//选择LSI时钟为RTC时钟源
#endif /*RTC_CLOCK_SOURCE_LSE*/__HAL_RCC_RTCAPB_CLK_ENABLE();//使能RTC APB外部设备时钟,Enable RTC peripheral Clocks__HAL_RCC_RTC_ENABLE();//使能RTC时钟,Enable RTC Clockhrtc.Instance = RTC;                       //选择RTChrtc.Init.HourFormat = RTC_HOURFORMAT_24;  //指定RTC小时的格式hrtc.Init.AsynchPrediv = RTC_ASYNCH_PREDIV;//指定RTC异步预分法器的值。hrtc.Init.SynchPrediv = RTC_SYNCH_PREDIV;  //指定RTC同步预分配器的值。hrtc.Init.OutPut = RTC_OUTPUT_DISABLE;hrtc.Init.OutPutRemap = RTC_OUTPUT_REMAP_NONE;hrtc.Init.OutPutPolarity = RTC_OUTPUT_POLARITY_HIGH;hrtc.Init.OutPutType = RTC_OUTPUT_TYPE_OPENDRAIN;hrtc.Init.OutPutPullUp = RTC_OUTPUT_PULLUP_NONE;HAL_RTC_Init(&hrtc);if (HAL_RTCEx_BKUPRead(&hrtc, RTC_BKP_DR0) != 0x32F2){//读TAMP_BKPxR寄存器,因为RTC_BKP_DR0=0,所以是读TAMP_BKP0R寄存器Test_RTC_Set_Date_And_Time();//设置时间为24年2月29日星期四23:59:50:00HAL_RTCEx_BKUPWrite(&hrtc, RTC_BKP_DR0, 0x32F2);//写TAMP_BKPxR寄存器,因为RTC_BKP_DR0=0,所以是写TAMP_BKPxR寄存器//将0x32F2写入TAMP_BKP0R寄存器//Writes a data in a RTC Backup data Register0}TEST_Hal_RTC_Set_Alarm_A();TEST_Hal_RTC_Set_Alarm_B();
}//函数功能:显示“年月日和星期几”以及“时分秒”
void RTC_Display(void)
{RTC_DateTypeDef sdatestructureget;//用来保存“年月日和星期几”RTC_TimeTypeDef stimestructureget;//用来保存“时分秒”printf("RTC_IT_SEC\r\n");HAL_RTC_GetTime(NULL, &stimestructureget, RTC_FORMAT_BIN);//读取"RTC时间"//读RTC_TR寄存器bit21:20(HT[1:0]),HT[1:0]表示小时的十位数值//读RTC_TR寄存器bit19:16(HU[3:0]),HU[3:0]表示小时的个位数值//读RTC_TR寄存器bit14:12(MNT[2:0]),MNT[2:0]表示分钟的十位数值//读RTC_TR寄存器bit11:8(MNU[3:0]),MNU[3:0]表示分钟的个位数值//读RTC_TR寄存器bit6:4(ST[2:0]),ST[2:0]表示秒的十位数值//读RTC_TR寄存器bit3:0(SU[3:0]),SU[3:0]表示秒的个位数值//HAL库耍牛氓,我也耍牛氓HAL_RTC_GetDate(NULL, &sdatestructureget, RTC_FORMAT_BIN);//读取"RTC日期"//读RTC_DR寄存器bit23:20(YT[3:0]),YT[3:0]表示年的十位数值//读RTC_DR寄存器bit19:16(YU[3:0]),YU[3:0]表示年的个位数值//读RTC_DR寄存器bit15:13(WDU[2:0]),WDU[2:0]=001b表示星期1;WDU[2:0]=010b表示星期2......WDU[2:0]=111b表示星期日//读RTC_DR寄存器bit12(MT),MT表示月的十位数值//读RTC_DR寄存器bit11:8(MU[3:0]),MU[3:0]表示月的个位数值//读RTC_DR寄存器bit5:4(DT[1:0]),DT[1:0]表示日的十位数值//读RTC_DR寄存器bit3:0(DU[3:0]),DU[3:0]表示日的个位数值//HAL库耍牛氓,我也耍牛氓printf("%02d-%02d-%02d  day:%02d  ", sdatestructureget.Year,sdatestructureget.Month,sdatestructureget.Date,sdatestructureget.WeekDay);printf("%02d:%02d:%02d\r\n", stimestructureget.Hours, stimestructureget.Minutes, stimestructureget.Seconds);//显示时间格式为 : YY-MM-DD hh:mm:ss
}//设置时间为24年2月29日星期四23:59:50:00
void Test_RTC_Set_Date_And_Time(void)
{RTC_TimeTypeDef sTime = {0};  //用来设置时间“时分秒”RTC_DateTypeDef sDate = {0};  //用来设置日期“年月日和星期几”sTime.Hours = 0x23;      //这里是BCD码,0x23表示23小时sTime.Minutes = 0x59;    //这里是BCD码,0x59表示59分钟sTime.Seconds = 0x50;    //这里是BCD码,0x50表示50秒种sTime.SubSeconds = 0x00;//RTC_SSR寄存器bit15:0(SS[15:0])是只读的,这里设置为0x00没有意义sTime.DayLightSaving = RTC_DAYLIGHTSAVING_NONE;//RTC_CR寄存器bit16(ADD1H),ADD1H=0,当前时间不增加1小时//若使用“夏令时”,ADD1H=1,表示当前时间增加1小时sTime.StoreOperation = RTC_STOREOPERATION_RESET;//RTC_CR寄存器bit18(BKP),BKP=0,不使用“夏令时”//现在已经废除了“夏令时”,不要去了解。HAL_RTC_SetTime(&hrtc, &sTime, RTC_FORMAT_BCD);//设置“时分秒”sDate.WeekDay = RTC_WEEKDAY_THURSDAY;//这里是BCD码,RTC_WEEKDAY_THURSDAY表示0x04,星期四sDate.Date = 0x29; //这里是BCD码,0x29表示29日sDate.Month = RTC_MONTH_FEBRUARY;//这里是BCD码,RTC_MONTH_FEBRUARY表示0x02,2月sDate.Year = 0x24; //这里是BCD码,0x24表示24年HAL_RTC_SetDate(&hrtc, &sDate, RTC_FORMAT_BCD);//设置“年月日”
}//使用HAL设置报警,有点呆板
void TEST_Hal_RTC_Set_Alarm_A(void)
{RTC_AlarmTypeDef sAlarm = {0};//用来设置报警时间HAL_RTC_DeactivateAlarm(&hrtc,RTC_ALARM_A);//选择RTC_ALARM_A时,表示停用AlarmA报警://不使能“Alarm A报警”和“Alarm A报警中断”,同时不选择“RTC报警事件”作为触发源//必须先停用AlarmA报警,才能配置AlarmA报警时间sAlarm.Alarm = RTC_ALARM_A; //指定配置RTC报警A寄存器(RTC_ALRMAR)sAlarm.AlarmTime.TimeFormat = RTC_HOURFORMAT_24;  //指定RTC报警小时的格式sAlarm.AlarmDateWeekDaySel = RTC_ALARMDATEWEEKDAYSEL_DATE;//指定RTC警报是按照日期报警sAlarm.AlarmDateWeekDay = 0x01;//每月1号报警//  sAlarm.AlarmDateWeekDaySel = RTC_ALARMDATEWEEKDAYSEL_WEEKDAY;//指定RTC警报是按照星期报警
//  sAlarm.AlarmDateWeekDay = RTC_WEEKDAY_FRIDAY;//每个星期五报警sAlarm.AlarmTime.Hours = 0x00;    //这里是BCD码,0x00表示00小时sAlarm.AlarmTime.Minutes = 0x00;  //这里是BCD码,0x00表示00分钟sAlarm.AlarmTime.Seconds = 0x20;  //这里是BCD码,0x20表示20秒种sAlarm.AlarmTime.SubSeconds = 0x30;//RTC_ALRMASSR寄存器bit27:24(MASKSS[3:0]),bit14:0(SS[14:0])//当选择“RTC_ALARM_A”时,时间写入RTC_ALRMAR//当选择“RTC_ALARM_B”时,时间写入RTC_ALRMBR//  sAlarm.AlarmMask = RTC_ALARMMASK_HOURS|RTC_ALARMMASK_MINUTES|RTC_ALARMMASK_DATEWEEKDAY;//RTC_ALARMMASK_HOURS|RTC_ALARMMASK_MINUTES|RTC_ALARMMASK_DATEWEEKDAY不关注日期小时和分钟,则每分钟报警一次sAlarm.AlarmMask = RTC_ALARMMASK_ALL;//RTC_ALARMMASK_ALL不关注日期,小时,分钟和秒,则每秒种报警一次sAlarm.AlarmSubSecondMask = RTC_ALARMSUBSECONDMASK_ALL;//需要匹配“子秒”HAL_RTC_SetAlarm_IT(&hrtc, &sAlarm, RTC_FORMAT_BCD);HAL_NVIC_SetPriority(RTC_Alarm_IRQn, 5, 0);//设置NVIC中断分组4:4位抢占优先级,0位响应优先级//选择中断优先级组4,即抢占优先级为4位,取值为0~15,响应优先级组为0位,取值为0HAL_NVIC_EnableIRQ(RTC_Alarm_IRQn);
}//使用HAL设置报警,有点呆板
void TEST_Hal_RTC_Set_Alarm_B(void)
{RTC_AlarmTypeDef sAlarm = {0};//用来设置报警时间HAL_RTC_DeactivateAlarm(&hrtc,RTC_ALARM_B);//选择RTC_ALARM_A时,表示停用AlarmB报警://不使能“Alarm B报警”和“Alarm B报警中断”,同时不选择“RTC报警事件”作为触发源//必须先停用AlarmB报警,才能配置AlarmB报警时间sAlarm.Alarm = RTC_ALARM_B; //指定配置RTC报警B寄存器(RTC_ALRMBR)sAlarm.AlarmTime.TimeFormat = RTC_HOURFORMAT_24;  //指定RTC报警小时的格式sAlarm.AlarmDateWeekDaySel = RTC_ALARMDATEWEEKDAYSEL_DATE;//指定RTC警报是按照日期报警sAlarm.AlarmDateWeekDay = 0x01;//每月1号报警//  sAlarm.AlarmDateWeekDaySel = RTC_ALARMDATEWEEKDAYSEL_WEEKDAY;//指定RTC警报是按照星期报警
//  sAlarm.AlarmDateWeekDay = RTC_WEEKDAY_FRIDAY;//每个星期五报警sAlarm.AlarmTime.Hours = 0x00;    //这里是BCD码,0x00表示00小时sAlarm.AlarmTime.Minutes = 0x00;  //这里是BCD码,0x00表示00分钟sAlarm.AlarmTime.Seconds = 0x20;  //这里是BCD码,0x20表示20秒种sAlarm.AlarmTime.SubSeconds = 0x30;//RTC_ALRMASSR寄存器bit27:24(MASKSS[3:0]),bit14:0(SS[14:0])//当选择“RTC_ALARM_A”时,时间写入RTC_ALRMAR//当选择“RTC_ALARM_B”时,时间写入RTC_ALRMBR//  sAlarm.AlarmMask = RTC_ALARMMASK_HOURS|RTC_ALARMMASK_MINUTES|RTC_ALARMMASK_DATEWEEKDAY;//RTC_ALARMMASK_HOURS|RTC_ALARMMASK_MINUTES|RTC_ALARMMASK_DATEWEEKDAY不关注日期小时和分钟,则每分钟报警一次sAlarm.AlarmMask = RTC_ALARMMASK_ALL;//RTC_ALARMMASK_ALL不关注日期,小时,分钟和秒,则每秒种报警一次sAlarm.AlarmSubSecondMask = RTC_ALARMSUBSECONDMASK_ALL;//需要匹配“子秒”HAL_RTC_SetAlarm_IT(&hrtc, &sAlarm, RTC_FORMAT_BCD);HAL_NVIC_SetPriority(RTC_Alarm_IRQn, 5, 0);//设置NVIC中断分组4:4位抢占优先级,0位响应优先级//选择中断优先级组4,即抢占优先级为4位,取值为0~15,响应优先级组为0位,取值为0HAL_NVIC_EnableIRQ(RTC_Alarm_IRQn);
}void RTC_Alarm_IRQHandler(void)
{
//  HAL_RTC_AlarmIRQHandler(&hrtc);uint32_t tmp = READ_REG(RTC->MISR);//Get interrupt statusif ((tmp & RTC_MISR_ALRAMF) != 0U)//RTC ALARM A报警{//当选择“RTC_ALARM_A”时,时间与RTC_ALRMAR相同时报警WRITE_REG(RTC->SCR, RTC_SCR_CALRAF);//Clear the AlarmA interrupt pending bit
//    __HAL_RTC_ALARM_EXTI_CLEAR_IT();
//		LED1_On();//报警时,LED亮LED1_Toggle();}if ((tmp & RTC_MISR_ALRBMF) != 0U)//RTC ALARM A报警{//当选择“RTC_ALARM_B”时,时间与RTC_ALRMBR相同时报警WRITE_REG(RTC->SCR, RTC_SCR_CALRBF);//Clear the AlarmB interrupt pending bit
//    __HAL_RTC_ALARM_EXTI_CLEAR_IT();LED2_Toggle();}__HAL_RTC_ALARM_EXTI_CLEAR_IT();
}

RTC.h程序

#ifndef __RTC_H__
#define __RTC_H__#include "stm32g4xx_hal.h"
//使能int8_t,int16_t,int32_t,int64_t
//使能uint8_t,uint16_t,uint32_t,uint64_t//#define RTC_CLOCK_SOURCE_LSI    //RTC使用CPU内部LSI作为时钟源
#define RTC_CLOCK_SOURCE_LSE#ifdef RTC_CLOCK_SOURCE_LSI
#define RTC_ASYNCH_PREDIV    0x7C
#define RTC_SYNCH_PREDIV     0xF9
#endif#ifdef RTC_CLOCK_SOURCE_LSE
#define RTC_ASYNCH_PREDIV  0x7F
#define RTC_SYNCH_PREDIV   0xFF
#endifextern void RTC_Init(void);
extern void RTC_Display(void);#endif /*__ RTC_H__ */

5、测试结果

6、配置RTC_OUT引脚输出

//在调用HAL_RTC_Init()之前调用RTC_OUTx_Init()
//RTC_OUTx_Init(&hrtc,RTC_OUTPUT_ALARMA,1);//RTC报警器A从RTC_OUT1引脚输出
//RTC_OUTx_Init(&hrtc,RTC_OUTPUT_ALARMB,1);//RTC报警器B从RTC_OUT1引脚输出
//RTC_OUTx_Init(&hrtc,RTC_OUTPUT_ALARMA,2);//RTC报警器A从RTC_OUT2引脚输出
//RTC_OUTx_Init(&hrtc,RTC_OUTPUT_ALARMB,2);//RTC报警器B从RTC_OUT2引脚输出

注意:
配置RTC_OUT1输出“RTC报警器A的报警标志”,RTC_OUT1输出的电平时间和ALRAF的保持时间有关;
配置RTC_OUT2输出“RTC报警器A的报警标志”,RTC_OUT2输出的电平时间和ALRAF的保持时间有关;

配置RTC_OUT1输出“RTC报警器B的报警标志”,RTC_OUT1输出的电平时间和ALRBF的保持时间有关;
配置RTC_OUT2输出“RTC报警器B的报警标志”,RTC_OUT2输出的电平时间和ALRBF的保持时间有关

 

 调用举例:

 中断函数添加一个延时,否则,示波器差,会看不到波形

 

这里是为了演示RTC_OUT1和RTC_OUT2输出。 

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

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

相关文章

Android平台RTMP|RTSP播放器如何回调YUV或RGB数据?

技术选型 我们知道&#xff0c;Android平台一般RTMP|RTSP播放器通常不直接提供回调YUV或RGB数据的功能。如果播放端有视觉分析或类似的需求&#xff0c;需要播放端&#xff0c;能支持YUV或ARG的数据回调&#xff0c;一般来说&#xff0c;可参考的方法如下&#xff1a; 1. 使用…

Xcode 16 RC (16A242) 发布下载,正式版下周公布

Xcode 16 RC (16A242) - Apple 平台 IDE IDE for iOS/iPadOS/macOS/watchOS/tvOS/visonOS 请访问原文链接&#xff1a;https://sysin.org/blog/apple-xcode-16/&#xff0c;查看最新版。原创作品&#xff0c;转载请保留出处。 作者主页&#xff1a;sysin.org Xcode 16 的新功…

3D Gaussian Splatting 论文学习

概述 目前比较常见的渲染方法大致可以分为2种&#xff1a; 将场景中的物体投影到渲染平面&#xff1a;传统的渲染管线就是这种方式&#xff0c;主要针对Mesh数据&#xff0c;可以将顶点直接投影成2D的形式&#xff0c;配合光栅化、深度测试、Alpha混合等就可以得到渲染的图像…

如何使用 ONNX 结合 GPU 加速推理(CUDA 与 cuDNN 简明指南)

前言 在深度学习模型推理中,使用 GPU 进行加速是提升模型推理速度的关键方式之一。 本文将带大家一步步了解如何使用 ONNX Runtime 结合 NVIDIA 的 CUDA 和 cuDNN 进行 GPU 加速。 一、查找ONNX、CUDA与cuDNN之间的对应版本 首先,我们需要确保 ONNX Runtime 与 CUDA 和 cu…

量化投资策略_因子打分选股的案例实现

一&#xff1a;因子打分选股的介绍 因子打分选股是一种量化投资策略&#xff0c;它通过选取多个与股票收益率相关的因子&#xff0c;对股票进行综合评分&#xff0c;然后根据评分来选择股票构建投资组合。以下是构建多因子打分选股模型的一般步骤&#xff1a; 数据预处理&…

Redis——常用数据类型hash

目录 hash常用命令hsethgethdelhkeyshvalshgetallhmgethlenhsetnxhincrbyhdecrby 哈希的编码方式哈希的应用 hash 常用命令 hset HSET key field value [field value ...]//时间复杂度O(1) //返回值&#xff1a;设置成功的键值对的个数hget HGET key field//hdel HDEL key…

【SSRF漏洞】——http协议常见绕过

改变的确很难&#xff0c;但结果值得冒险 本文如有错误之处&#xff0c;还请各位师傅指正 一.ssrf概述 SSRF全称为Server-side Request Fogery,中文含义服务器端请求伪造 SSRF是一种由攻击者构造形成由目标服务端发起请求的一个安全漏洞。一般情况下&#xff0c;SSRF攻击的目标…

Linux 防火墙:iptables (二)

文章目录 SNAT 原理与应用SNAT 应用环境SNAT 原理SNAT 转换前提条件SNAT 格式SNAT 转换规则配置 DNAT 原理与应用DNAT 应用环境DNAT 原理DNAT 转换前提条件DNAT 格式DNAT 转换规则配置 iptables 规则的备份和还原导出&#xff08;备份&#xff09;所有表的规则导入&#xff08;…

PCL 点云基于曲率大小渲染颜色

目录 一、概述 1.1原理 1.2实现步骤 1.3应用场景 二、代码实现 2.1关键函数 2.2完整代码 三、实现效果 3.1原始点云 3.2处理后点云 PCL点云算法汇总及实战案例汇总的目录地址链接&#xff1a; PCL点云算法与项目实战案例汇总&#xff08;长期更新&#xff09; 一、概…

Django笔记一:搭建Django环境与URL路径访问

博主之前学从Java后端开发&#xff0c;后面获取到读研资格&#xff0c;想着未来转算法岗&#xff0c;初学Python&#xff0c;发现Python还挺有趣的&#xff0c;由于之前所学后端缘故&#xff0c;有点后端情节&#xff0c;想学习一下Django框架&#xff08;python的web框架&…

人工智能和机器学习:探讨人工智能和机器学习的最新发展、应用、挑战和未来趋势

人工智能和机器学习是当前科技领域的热点话题&#xff0c;其最新发展、应用、挑战和未来趋势备受关注。 最新发展&#xff1a; 人工智能和机器学习技术在近年来得到了快速发展&#xff0c;尤其是深度学习技术的广泛应用。例如&#xff0c;深度学习在图像识别、语音识别、自然语…

react 基础语法

前置知识 类的回顾 通过class关键字定义一个类 类名首字母大写 class类有constructor构造器 new 一个类得到一个实例 类还有方法&#xff0c;该方法也会在其原型上 static静态数据&#xff0c;访问静态属性通过 类名.id getter和setter getter&#xff1a;定义一个属性&…

网络学习-eNSP配置VRRP

虚拟路由冗余协议(Virtual Router Redundancy Protocol&#xff0c;简称VRRP) VRRP广泛应用在边缘网络中&#xff0c;是一种路由冗余协议&#xff0c;它的设计目标是支持特定情况下IP数据流量失败转移不会引起混乱&#xff0c;允许主机使用单路由器&#xff0c;以及即使在实际…

全球NAND原厂闪存市场格局变化

根据市场研究机构TrendForce的最新跟踪报告&#xff0c;三星&#xff08;Samsung&#xff09;和SK海力士&#xff08;SK hynix-Solidigm&#xff09;在过去的一个季度中扩大了他们在NAND闪存市场的份额&#xff0c;这主要得益于抢占了铠侠&#xff08;Kioxia&#xff09;与西部…

小目标检测顶会新思路!最新成果刷爆遥感SOTA,参数小了18倍

遥感领域的小目标检测一直是个具有挑战性和趣味性的研究方向&#xff0c;同时也是顶会顶刊的常客。但不得不说&#xff0c;今年关于遥感小目标检测的研究热情尤其高涨&#xff0c;已经出现了很多非常优秀的成果。 比如SuperYOLO方法&#xff0c;通过融合多模态数据并执行高分辨…

【重学 MySQL】二十八、SQL99语法新特性之自然连接和 using 连接

【重学 MySQL】二十八、SQL99语法新特性之自然连接和 using 连接 自然连接&#xff08;NATURAL JOIN&#xff09;USING连接总结 SQL99语法在SQL92的基础上引入了一些新特性&#xff0c;其中自然连接&#xff08;NATURAL JOIN&#xff09;和USING连接是较为显著的两个特性。 自…

数据结构(14)——哈希表(1)

欢迎来到博主的专栏&#xff1a;数据结构 博主ID&#xff1a;代码小豪 文章目录 哈希表的思想映射方法&#xff08;哈希函数&#xff09;除留余数法 哈希表insert闭散列负载因子扩容find和erase 哈希表的思想 在以往的线性表中&#xff0c;查找速度取决于线性表是否有序&#…

知识库管理系统在企业数字化转型中的作用

引言 在数字化转型的浪潮中&#xff0c;企业正以前所未有的速度重塑其业务模式、运营流程和组织架构&#xff0c;以适应快速变化的市场环境和客户需求。这一过程中&#xff0c;知识库管理系统作为信息整合与知识共享的核心平台&#xff0c;发挥着举足轻重的作用&#xff0c;不…

【解决】AnimationCurve 运行时丢失数据问题

开发平台&#xff1a;Unity 2022 编程平台&#xff1a;Visual Studio 编程语言&#xff1a;CSharp   一、问题背景 如上图所示的 GracityComponent 组件中&#xff0c;引用 AnimationCurve 作为可调属性。但在实际使用中出现数据丢失问题。大致为以下两种情况&#xff1a; 运…

【重学 MySQL】二十七、七种 join 连接

【重学 MySQL】二十七、七种 join 连接 union 的使用UNION 的基本用法示例UNION ALL 的用法 七种 join 连接代码实现语法格式小结 union 的使用 UNION 在 SQL 中用于合并两个或多个 SELECT 语句的结果集&#xff0c;并默认去除重复的行。如果希望包含重复行&#xff0c;可以使…