航芯ACM32G103开发板评测 08 ADC Timer外设测试
航芯ACM32G103开发板评测 08 ADC Timer外设测试
1. 软硬件平台
- ACM32G103 Board开发板
- MDK-ARM Keil
2. 定时器Timer
在一般的MCU芯片中,定时器这个外设资源是非常重要的,一般可以分为SysTick定时器(系统滴答定时器)、常规定时器(基本定时器,通用定时器,高级定时器)、专用定时器(看门狗定时器,RTC)
 
在ACM32G103中有着丰富的定时器资源,还包括低功耗定时器lptimer,具体资源如下
 
基础定时器最简单,就只是普通的计数、定时功能。通用定时器在基础定时器的功能上,增加了输入捕获和输出比较等功能。高级定时器在通用定时器的功能上,造假了包含测量输入信号的脉冲宽度(输入捕获),或者产生输出波形(输出比较、PWM、嵌入死区时间的互补PWM)的功能。
 接下来进行基本的定时器定时功能测试。在官方给的SPL库里面只有两个例程,感觉有点少,与stm32相比较,许多的库函数没有完善。原本打算使用HC-SR04超声波模块进行定时器测试,但是发现有不少问题,而且定时精度比较高就放弃了,以后有时间再看看吧,或者看看其他人的东西。
 
基本定时器包含一个16 位自动装载计数器,由各自的可编程预分频器驱动。
 
//嵌套向量中断控制器配置 
void NVIC_Configuration(void)
{NVIC_ClearPendingIRQ(TIM6_IRQn);   NVIC_EnableIRQ(TIM6_IRQn);   
} 
//时钟配置使能
void Clock_Configuration(void)
{__RCC_TIM6_CLK_ENABLE();   
}  
定时器配置函数
 定时器的定时时间主要取决于预分频系数和定时周期。重要的参数Prescaler,Period
 如果需要修改定时器定时时间,只需要修改
TIM_TimeBaseStructure.Period = (TIM_CLOCK_FREQ/1000)*500 - 1;  // 500ms 
修改为
TIM_TimeBaseStructure.Period = (TIM_CLOCK_FREQ/1000)*1000 - 1;  // 1000ms=1s 
void TIM6_Init(void)  
{uint32_t timer_clock; timer_clock = RCC_GetPCLK1Freq(); if (RCC_GetHCLKFreq() != timer_clock)  // if hclk/pclk != 1, then timer clk = pclk * 2  {timer_clock =  timer_clock << 1;     }TIM_TimeBaseStructure.ClockDivision = TIM_CLOCKDIVISION_DIV1; TIM_TimeBaseStructure.CounterMode = TIM_COUNTERMODE_UP; TIM_TimeBaseStructure.RepetitionCounter = 0;  TIM_TimeBaseStructure.Prescaler = (timer_clock/TIM_CLOCK_FREQ) - 1;  TIM_TimeBaseStructure.Period = (TIM_CLOCK_FREQ/1000)*500 - 1;  // 500ms TIM_TimeBase_Init(TIM6, &TIM_TimeBaseStructure);           /* TIM IT enable */TIM_ITConfig(TIM6, TIM_IT_Update, ENABLE);  /* TIM6 enable counter */TIM_Cmd(TIM6, ENABLE);          
}
3.模数转换器ADC
1. ADC简介
将模拟信号(连续信号)转换为数字信号(离散信号)的器件就叫模数转换器(ADC)。
 按原理可分为:并行比较型A/D转换器(FLASH ADC)、逐次比较型A/D转换器(SAR ADC)和双积分式A/D转换器(Double Integral ADC)。
 A/D转换过程通常为4步:采样、保持、量化和编码。如图所示。
 
ADC的主要有三个性能指标:分辨率、转换时间和转换精度。
1.1 分辨率
分辨率:又称为转换精度,指ADC能分辨的最小电压,通常使用二进制有效位表示,反应了ADC对输入模拟量微小变化的分辨能力。当最大输入电压一定时,位数越多,量化单位越小,误差越小,分辨率越高。比如一个12位的ADC,参考电压为3.3V,则其能分辨的最小电压为:
 
1.2 转换时间
转换时间:其倒数为转换速率,指ADC从控制信号到来开始,到输出端得到稳定的数字信号所经历的时间。转换时间通常与ADC类型有关,双积分型ADC的转换时间一般为几十毫秒,属于低速ADC;逐次逼近型ADC的转换时间一般为几十微妙,属于中速ADC;并联比较型ADC的转换时间一般为几十纳秒,属于高速ADC。
1.3 转换精度
转换精度:指ADC输出的数字量所表示的模拟值与实际输入的模拟量之间的偏差,通常为1个或半个最小数字量的模拟变化量,表示为1LSB或1/2LSB。
2.ACM32G103 ADC资源
ACM32G103芯片有2个12位逐次逼近型ADC。ADC1与ADC2紧密耦合,可在双重模式下运行(ADC1 为主器件,ADC2为从器件)。
- 12 位分辨率,可配置10 位、8 位或6 位分辨率
- 转换速率最高可达3Msps
- 20 个可用通道,包括外部信号源和内部信号源
3. ADC初始化配置
首先需要定义需要使用的ADC 通道数量,以及具体的ADC 通道号。确定需要使用到的工作模式(独立模式、双ADC 模式、单端、差分或者是否支持DMA 等),设置ADC CLK,根据需求进行初始化配置。
 ADC采集方式有下面四种:轮询方式,中断方式,外部触发方式,DMA 方式。
 以DMA为案例进行处理。
 ADC_DMA驱动函数
void ADC_DMA_Drive_Iint(void)
{ADC_GPIO_Config();//ADC_GPIO端口引脚初始化配置ADC_Common_Register_Config();//ADC通用寄存器配置ADC_Config();//ADC工作模式配置ADC_DMA_Config();//ADC_DMA请求配置ADC_RegularStart();//使能ADC,开始常规通道的转换
}
ADC_GPIO端口引脚初始化配置
void ADC_GPIO_Config(void)
{GPIO_InitTypeDef GPIO_InitStruct;__RCC_GPIOC_CLK_ENABLE();/* Configure ADC Channel_13 pin as analog input */GPIO_InitStruct.Pin       = GPIO_PIN_3;GPIO_InitStruct.Mode      = GPIO_MODE_ANALOG;GPIO_InitStruct.Pull      = GPIO_NOPULL;GPIO_Init(GPIOC, &GPIO_InitStruct); 
}
ADC通用寄存器配置
void ADC_Common_Register_Config(void)
{ADC_CommonInitTypeDef ADC_CommonInitStructure;ADC_CommonInitStructure.ADC_Mode = ADC_MODE_INDEPENDENT;//双ADC模式选择ADC_CommonInitStructure.ADC_Prescaler = ADC_CLOCK_DIV4;//ADC_CLK分频选择ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAACCESSMODE_DISABLED;//双ADC下DMA功能选择ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TWOSAMPLINGDELAY_5CYCLES;//2个采样阶段之间的延迟ADC_CommonInit(&ADC_CommonInitStructure);
}
ADC工作模式配置
void ADC_Config(void)
{ADC_InitTypeDef ADC_InitStructure;ADC_InitStructure.ADC_Resolution = ADC_RESOLUTION_12B;//分辨率ADC_InitStructure.ADC_ContinuousConvMode = ADC_CONT_DISABLE;//连续转换模式ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;//外部触发边沿选择ADC_InitStructure.ADC_ExternalTrigConv = ADC_EXTERNAL_TIG0;//触发模式ADC_InitStructure.ADC_DataAlign = ADC_DATAALIGN_RIGHT;//数据对齐ADC_InitStructure.ADC_NbrOfConversion = ADC_NUM;//规则通道序列长度 传输的数据长度为:每个通道采集30次 * 1个通道ADC_Init(ADCX, &ADC_InitStructure);//规则通道设置ADC_RegularChannelConfig(ADCX, ADC_CHANNEL_13, ADC_SEQUENCE_SQ1, ADC_SMP_CLOCK_320);
}
ADC_DMA请求配置
void ADC_DMA_Config(void)
{__RCC_DMA1_CLK_ENABLE();DMA_BigEndianConfig(DMA1, DISABLE);DMA_DeInit(DMA1_Channel3);DMA_InitStruct.Mode = DMA_MODE_CIRCULAR;    DMA_InitStruct.DataFlow = DMA_DATAFLOW_P2M;DMA_InitStruct.ReqID = DMA1_REQ0_ADC1;DMA_InitStruct.RawInt = DMA_RAWINT_ENABLE;DMA_InitStruct.SrcInc = DMA_SRCINC_DISABLE;DMA_InitStruct.DestInc = DMA_DESTINC_ENABLE;DMA_InitStruct.SrcWidth = DMA_SRCWIDTH_WORD;   DMA_InitStruct.DestWidth = DMA_DESTWIDTH_WORD;DMA_InitStruct.SrcBurst = DMA_SRCBURST_1;DMA_InitStruct.DestBurst = DMA_DESTBURST_1;DMA_InitStruct.SrcAddr     = (uint32_t)&ADC1->DR;DMA_InitStruct.DestAddr    = (uint32_t)gadcBuffer;DMA_InitStruct.Size        = 1;    DMA_Init(DMA1_Channel3, &DMA_InitStruct);// Enable interruptDMA_ClearFlag(DMA1_Channel3, DMA_FLAG_RTC);DMA_ITConfig(DMA1_Channel3, DMA_IT_TC, ENABLE);// Enable NVIC IRQNVIC_ClearPendingIRQ(DMA1_IRQn);NVIC_SetPriority(DMA1_IRQn, 0x00);NVIC_EnableIRQ(DMA1_IRQn); DMA_Cmd(DMA1_Channel3, ENABLE); 
}
使能ADC,开始常规通道的转换
void ADC_RegularStart(void)
{/* Enable ADC DMA mode */ADC_DMACmd(ADCX, ENABLE);/* Enable the ADC peripheral */ADC_Cmd(ADCX, ENABLE);/* Clear the SR register */ADC_ClearFlag(ADCX, ADC_IT_FLAG_ALL);      /* Start conversion */ADC_SoftwareStartConv(ADCX);}
中断服务函数
void DMA1_IRQHandler(void)
{ADC_DMA_ITC_Callback();
}
void ADC_DMA_ITC_Callback(void)
{ /* Transfer complete interrupt */if (SET == DMA_GetFlagStatus(DMA1_Channel3, DMA_FLAG_TC)){gadc1ItcConunt = 1;DMA_ClearFlag(DMA1_Channel3, DMA_FLAG_TC);}     
}4.测试
- Timer测试函数
#define TIM_CLOCK_FREQ            (10000)  TIM_Base_InitTypeDef TIM_TimeBaseStructure;    volatile uint32_t Timer_Update_Flag;    void Clock_Configuration(void);
void GPIO_Configuration(void);
void NVIC_Configuration(void);   void NVIC_Configuration(void)
{NVIC_ClearPendingIRQ(TIM6_IRQn);   NVIC_EnableIRQ(TIM6_IRQn);   
} void Clock_Configuration(void)
{__RCC_TIM6_CLK_ENABLE();   
}  void GPIO_Configuration(void)  
{// do nothing here 
}/************************************************************************* function   : TIM6_Update_IRQ* Description: TIM6 user Interrupt Handler ************************************************************************/ 
void TIM6_Update_IRQ(void)
{if (TIM6->SR & TIMER_SR_UIF)  {Timer_Update_Flag = 1;  }}void TIM6_Init(void)  
{uint32_t timer_clock; timer_clock = RCC_GetPCLK1Freq(); if (RCC_GetHCLKFreq() != timer_clock)  // if hclk/pclk != 1, then timer clk = pclk * 2  {timer_clock =  timer_clock << 1;     }TIM_TimeBaseStructure.ClockDivision = TIM_CLOCKDIVISION_DIV1; TIM_TimeBaseStructure.CounterMode = TIM_COUNTERMODE_UP; TIM_TimeBaseStructure.RepetitionCounter = 0;  TIM_TimeBaseStructure.Prescaler = (timer_clock/TIM_CLOCK_FREQ) - 1;  TIM_TimeBaseStructure.Period = (TIM_CLOCK_FREQ/1000)*500 - 1;  // 500ms TIM_TimeBase_Init(TIM6, &TIM_TimeBaseStructure);           /* TIM IT enable */TIM_ITConfig(TIM6, TIM_IT_Update, ENABLE);  /* TIM6 enable counter */TIM_Cmd(TIM6, ENABLE);          
}void Timer_Update_Test(void)
{/* Module Clocks Configuration */Clock_Configuration();/* NVIC Configuration */   NVIC_Configuration();Timer_Update_Flag = 0;   TIM6_Init(); while(1){if(Timer_Update_Flag) {printfS("Timer Update Occurs\n"); Timer_Update_Flag = 0;   }}
}
- ADC_DMA测试函数
//采样通道数 
#define ADC_NUM    (1)uint32_t gadcBuffer[ADC_NUM]; 
static volatile uint32_t gadc1ItcConunt = 0;                 #define ADCX    (ADC1)DMA_InitTypeDef DMA_InitStruct;//需配置为全局变量,不然DMA只会触发一次/******************************************************************************
* @brief : DMA adc to memory transfer complete interrupt Callback.
* @param : None
* @return: None
******************************************************************************/ 
void ADC_DMA_ITC_Callback(void)
{ /* Transfer complete interrupt */if (SET == DMA_GetFlagStatus(DMA1_Channel3, DMA_FLAG_TC)){gadc1ItcConunt = 1;DMA_ClearFlag(DMA1_Channel3, DMA_FLAG_TC);}     
}/******************************************************************************
* @brief : ADC GPIO config.
* @param : None
* @return: None
******************************************************************************/
void ADC_GPIO_Config(void)
{GPIO_InitTypeDef GPIO_InitStruct;__RCC_GPIOC_CLK_ENABLE();/* Configure ADC Channel_13 pin as analog input */GPIO_InitStruct.Pin       = GPIO_PIN_3;GPIO_InitStruct.Mode      = GPIO_MODE_ANALOG;GPIO_InitStruct.Pull      = GPIO_NOPULL;GPIO_Init(GPIOC, &GPIO_InitStruct); 
}/******************************************************************************
* @brief : ADC Common register config.
* @param : None
* @return: None
******************************************************************************/
void ADC_Common_Register_Config(void)
{ADC_CommonInitTypeDef ADC_CommonInitStructure;ADC_CommonInitStructure.ADC_Mode = ADC_MODE_INDEPENDENT;//双ADC模式选择ADC_CommonInitStructure.ADC_Prescaler = ADC_CLOCK_DIV4;//ADC_CLK分频选择ADC_CommonInitStructure.ADC_DMAAccessMode = ADC_DMAACCESSMODE_DISABLED;//双ADC下DMA功能选择ADC_CommonInitStructure.ADC_TwoSamplingDelay = ADC_TWOSAMPLINGDELAY_5CYCLES;//2个采样阶段之间的延迟ADC_CommonInit(&ADC_CommonInitStructure);
}/******************************************************************************
* @brief : ADC config.
* @param : None
* @return: None
******************************************************************************/
void ADC_Config(void)
{ADC_InitTypeDef ADC_InitStructure;ADC_InitStructure.ADC_Resolution = ADC_RESOLUTION_12B;//分辨率ADC_InitStructure.ADC_ContinuousConvMode = ADC_CONT_DISABLE;//连续转换模式ADC_InitStructure.ADC_ExternalTrigConvEdge = ADC_EXTERNALTRIGCONVEDGE_NONE;//外部触发边沿选择ADC_InitStructure.ADC_ExternalTrigConv = ADC_EXTERNAL_TIG0;//触发模式ADC_InitStructure.ADC_DataAlign = ADC_DATAALIGN_RIGHT;//数据对齐ADC_InitStructure.ADC_NbrOfConversion = ADC_NUM;//规则通道序列长度 传输的数据长度为:每个通道采集30次 * 1个通道ADC_Init(ADCX, &ADC_InitStructure);//规则通道设置ADC_RegularChannelConfig(ADCX, ADC_CHANNEL_13, ADC_SEQUENCE_SQ1, ADC_SMP_CLOCK_320);
}/******************************************************************************
* @brief : ADC DMA config.
* @param : None
* @return: None
******************************************************************************/
void ADC_DMA_Config(void)
{__RCC_DMA1_CLK_ENABLE();DMA_BigEndianConfig(DMA1, DISABLE);DMA_DeInit(DMA1_Channel3);DMA_InitStruct.Mode = DMA_MODE_CIRCULAR;    DMA_InitStruct.DataFlow = DMA_DATAFLOW_P2M;DMA_InitStruct.ReqID = DMA1_REQ0_ADC1;DMA_InitStruct.RawInt = DMA_RAWINT_ENABLE;DMA_InitStruct.SrcInc = DMA_SRCINC_DISABLE;DMA_InitStruct.DestInc = DMA_DESTINC_ENABLE;DMA_InitStruct.SrcWidth = DMA_SRCWIDTH_WORD;   DMA_InitStruct.DestWidth = DMA_DESTWIDTH_WORD;DMA_InitStruct.SrcBurst = DMA_SRCBURST_1;DMA_InitStruct.DestBurst = DMA_DESTBURST_1;DMA_InitStruct.SrcAddr     = (uint32_t)&ADC1->DR;DMA_InitStruct.DestAddr    = (uint32_t)gadcBuffer;DMA_InitStruct.Size        = 1;    DMA_Init(DMA1_Channel3, &DMA_InitStruct);// Enable interruptDMA_ClearFlag(DMA1_Channel3, DMA_FLAG_RTC);DMA_ITConfig(DMA1_Channel3, DMA_IT_TC, ENABLE);// Enable NVIC IRQNVIC_ClearPendingIRQ(DMA1_IRQn);NVIC_SetPriority(DMA1_IRQn, 0x00);NVIC_EnableIRQ(DMA1_IRQn); DMA_Cmd(DMA1_Channel3, ENABLE); 
}/******************************************************************************
* @brief:  Enable ADC, start conversion of regular channle 
* @param:  None 
* @return: None
******************************************************************************/
void ADC_RegularStart(void)
{/* Enable ADC DMA mode */ADC_DMACmd(ADCX, ENABLE);/* Enable the ADC peripheral */ADC_Cmd(ADCX, ENABLE);/* Clear the SR register */ADC_ClearFlag(ADCX, ADC_IT_FLAG_ALL);      /* Start conversion */ADC_SoftwareStartConv(ADCX);}void ADC_DMA_Drive_Iint(void)
{ADC_GPIO_Config();ADC_Common_Register_Config();ADC_Config();ADC_DMA_Config();ADC_RegularStart();
}/******************************************************************************
* @brief : ADC function test.
* @param : None
* @return: None
******************************************************************************/
void APP_ADC_Test(void)
{uint32_t i;float vol=0.0;printfS("ADC DMA test \r\n");ADC_DMA_Drive_Iint();while(1){ADC_SoftwareStartConv(ADCX);while(!gadc1ItcConunt);gadc1ItcConunt =0;for (i = 0; i < ADC_NUM; i++){//  printfS("Channel_%d = %d\r\n", ((gadcBuffer[i] >> 16) & 0xFF), (gadcBuffer[i] & 0xFFF));vol = (gadcBuffer[i]&0xFFF)*3.3/4095;printf("PA1 Voltage is: %0.1f V \r\n", vol);}DelayMs(1000);}
}
- 测试结果


相关文章:
 
航芯ACM32G103开发板评测 08 ADC Timer外设测试
航芯ACM32G103开发板评测 08 ADC Timer外设测试 1. 软硬件平台 ACM32G103 Board开发板MDK-ARM Keil 2. 定时器Timer 在一般的MCU芯片中,定时器这个外设资源是非常重要的,一般可以分为SysTick定时器(系统滴答定时器)、常规定时…...
 
【Linux学习】生产者-消费者模型
目录 22.1 什么是生产者-消费者模型 22.2 为什么要用生产者-消费者模型? 22.3 生产者-消费者模型的特点 22.4 BlockingQueue实现生产者-消费者模型 22.4.1 实现阻塞队列BlockQueue 1) 添加一个容器来存放数据 2)加入判断Blocking Queue情况的成员函数 3)实现push和pop方法 4)完…...
 
三、案例 - MySQL数据迁移至ClickHouse
MySQL数据迁移至ClickHouse 一、生成测试数据表和数据1.在MySQL创建数据表和数据2.在ClickHouse创建数据表 二、生成模板文件1.模板文件内容2.模板文件参数详解2.1 全局设置2.2 数据读取(Reader)2.3 数据写入(Writer)2.4 性能设置…...
 
[WinForm开源]概率计算器 - Genshin Impact(V1.0)
创作目的:为方便旅行者估算自己拥有的纠缠之缘能否达到自己的目的,作者使用C#开发了一款小型软件供旅行者参考使用。 创作说明:此软件所涉及到的一切概率与规则完全按照游戏《原神》(V4.4.0)内公示的概率与规则(包括保底机制&…...
 
vscode 代码调试from IPython import embed
一、讲解 这种代码调试方法非常的好用。 from IPython import embed上面的代码片段是用于Python中嵌入一个交互式IPython shell的方法。这可以在任何Python脚本或程序中实现,允许在执行到该点时暂停程序,并提供一个交互式环境,以便于检查、…...
 
双活工作关于nacos注册中心的数据迁移
最近在做一个双活的项目,在纠结一个注册中心是在双活机房都准备一个,那主机房的数据如果传过去呢,查了一些资料,最终在官网查到了一个NacosSync 的组件,主要用来做数据传输的,并且支持在线替换注册中心的&a…...
 
5G NR 信道号计算
一、5G NR的频段 增加带宽是增加容量和传输速率最直接的方法,目前5G最大带宽将会达到400MHz,考虑到目前频率占用情况,5G将不得不使用高频进行通信。 3GPP协议定义了从Sub6G(FR1)到毫米波(FR2)的5G目标频谱。 其中FR1是5G的核心频段࿰…...
 
01-Spring实现重试和降级机制
主要用于在模块调用中,出现失败、异常情况下,仍需要进行重复调用。并且在最终调用失败时,可以采用降级措施,返回一般结果。 1、重试机制 我们采用spring 提供的retry 插件,其原理采用aop机制,所以需要额外…...
 
docker部署showdoc
目录 安装 1.拉取镜像 2.创建容器 使用 1.选择语言 2.默认账户/密码:showdoc/123456编辑 3.登陆 4.首页 安装 1.拉取镜像 docker pull star7th/showdoc 2.创建容器 mkdir -p /opt/showdoc/html docker run -d --name showdoc --userroot --privilegedtrue -p 1005…...
 
2.14作业
1.请编程实现二维数组的杨辉三角。 2.请编程实现二维数组计算每一行的和以及列和。 3.请编程实现二维数组计算第二大值。 4.请使用非函数方法实现系统函数strcat,strcmp,strcpy,strlen. strcat: strcmp: strcpy: strlen:...
 
01.数据结构篇-链表
1.找出两个链表的交点 160. Intersection of Two Linked Lists (Easy) Leetcode / 力扣 例如以下示例中 A 和 B 两个链表相交于 c1: A: a1 → a2↘c1 → c2 → c3↗ B: b1 → b2 → b3 但是不会出现以下相交的情况,因为每个节点只有一个…...
 
揭秘产品迭代计划制定:从0到1打造完美迭代策略
产品迭代计划是产品团队确保他们能够交付满足客户需求的产品以及实现其业务目标的重要工具。开发一个成功的产品迭代计划需要仔细考虑产品的目标、客户需求、市场趋势和可用资源。以下是帮助您创建产品迭代计划的一些步骤:建立产品目标、收集客户反馈、分析市场趋势…...
 
Python进阶--下载想要的格言(基于格言网的Python爬虫程序)
注:由于上篇帖子(Python进阶--爬取下载人生格言(基于格言网的Python3爬虫)-CSDN博客)篇幅长度的限制,此篇帖子对上篇做一个拓展延伸。 目录 一、爬取格言网中想要内容的url 1、找到想要的内容 2、抓包分析,找到想…...
 
C语言--------数据在内存中的存储
1.整数在内存中的存储 整数在内存是以补码的形式存在的; 整型家族包括char,int ,long long,short类型; 因为char类型是以ASCII值形式存在,所以也是整形家族; 这四种都包括signed,unsigned两种,即有符号和无符号&am…...
 
【Java】零基础蓝桥杯算法学习——线性动态规划(一维dp)
线性dp——一维动态规划 1、考虑最后一步可以由哪些状态得到,推出转移方程 2、考虑当前状态与哪些参数有关系,定义几维数组来表示当前状态 3、计算时间复杂度,判断是否需要进行优化。 一维动态规划例题:最大上升子序列问题 Java参…...
 
Excel模板1:彩色甘特图
Excel模板1:彩色甘特图 分享地址 当前效果:只需要填写进度, 其余效果都是自动完成的 。 阿里网盘永久分享:https://www.alipan.com/s/cXhq1PNJfdm 省心。能用公式的绝不使用手动输入。  这个区域以及标题可以手动输入…...
 
如何重新安装 macOS
你可以使用电脑的内建恢复系统“macOS 恢复”来重新安装 Mac 操作系统。不但简单快捷,而且重新安装后不会移除你的个人数据。 将 Mac 关机 选取苹果菜单  >“关机”,然后等待 Mac 关机。如果你无法将 Mac 关机,请按住它的电源按钮最长 …...
 
论文阅读-Pegasus:通过网络内一致性目录容忍分布式存储中的偏斜工作负载
论文名称:Pegasus: Tolerating Skewed Workloads in Distributed Storage with In-Network Coherence Directories 摘要 高性能分布式存储系统面临着由于偏斜和动态工作负载引起的负载不平衡的挑战。本文介绍了Pegasus,这是一个利用新一代可编程交换机…...
【PTA|编程题|期末复习】字符串(一)
【C语言/期末复习】字符和字符串函数(附思维导图/例题) 目录 7-1 组织星期信息 输入样例 (repeat3) : 输出样例: 代码 7-2 查找指定字符 输入格式: 输出格式: 输入样例1: 输出样例1: 输入样例2: …...
 
数据库基本操作2
一.DML(Data Manipulation Language) 用来对数据库中表的数据记录进行更新 关键字:增删改 插入insert 删除delete 更新update 1.数据插入 insert into 表(列名1,列名2,列名3……)values&a…...
 
JavaSec-RCE
简介 RCE(Remote Code Execution),可以分为:命令注入(Command Injection)、代码注入(Code Injection) 代码注入 1.漏洞场景:Groovy代码注入 Groovy是一种基于JVM的动态语言,语法简洁,支持闭包、动态类型和Java互操作性,…...
【杂谈】-递归进化:人工智能的自我改进与监管挑战
递归进化:人工智能的自我改进与监管挑战 文章目录 递归进化:人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管?3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...
 
PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建
制造业采购供应链管理是企业运营的核心环节,供应链协同管理在供应链上下游企业之间建立紧密的合作关系,通过信息共享、资源整合、业务协同等方式,实现供应链的全面管理和优化,提高供应链的效率和透明度,降低供应链的成…...
uni-app学习笔记二十二---使用vite.config.js全局导入常用依赖
在前面的练习中,每个页面需要使用ref,onShow等生命周期钩子函数时都需要像下面这样导入 import {onMounted, ref} from "vue" 如果不想每个页面都导入,需要使用node.js命令npm安装unplugin-auto-import npm install unplugin-au…...
 
ESP32读取DHT11温湿度数据
芯片:ESP32 环境:Arduino 一、安装DHT11传感器库 红框的库,别安装错了 二、代码 注意,DATA口要连接在D15上 #include "DHT.h" // 包含DHT库#define DHTPIN 15 // 定义DHT11数据引脚连接到ESP32的GPIO15 #define D…...
vue3 字体颜色设置的多种方式
在Vue 3中设置字体颜色可以通过多种方式实现,这取决于你是想在组件内部直接设置,还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法: 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...
 
2025盘古石杯决赛【手机取证】
前言 第三届盘古石杯国际电子数据取证大赛决赛 最后一题没有解出来,实在找不到,希望有大佬教一下我。 还有就会议时间,我感觉不是图片时间,因为在电脑看到是其他时间用老会议系统开的会。 手机取证 1、分析鸿蒙手机检材&#x…...
 
k8s业务程序联调工具-KtConnect
概述 原理 工具作用是建立了一个从本地到集群的单向VPN,根据VPN原理,打通两个内网必然需要借助一个公共中继节点,ktconnect工具巧妙的利用k8s原生的portforward能力,简化了建立连接的过程,apiserver间接起到了中继节…...
06 Deep learning神经网络编程基础 激活函数 --吴恩达
深度学习激活函数详解 一、核心作用 引入非线性:使神经网络可学习复杂模式控制输出范围:如Sigmoid将输出限制在(0,1)梯度传递:影响反向传播的稳定性二、常见类型及数学表达 Sigmoid σ ( x ) = 1 1 +...
 
【Oracle】分区表
个人主页:Guiat 归属专栏:Oracle 文章目录 1. 分区表基础概述1.1 分区表的概念与优势1.2 分区类型概览1.3 分区表的工作原理 2. 范围分区 (RANGE Partitioning)2.1 基础范围分区2.1.1 按日期范围分区2.1.2 按数值范围分区 2.2 间隔分区 (INTERVAL Partit…...
