航芯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…...
IDEA运行Tomcat出现乱码问题解决汇总
最近正值期末周,有很多同学在写期末Java web作业时,运行tomcat出现乱码问题,经过多次解决与研究,我做了如下整理: 原因: IDEA本身编码与tomcat的编码与Windows编码不同导致,Windows 系统控制台…...
第19节 Node.js Express 框架
Express 是一个为Node.js设计的web开发框架,它基于nodejs平台。 Express 简介 Express是一个简洁而灵活的node.js Web应用框架, 提供了一系列强大特性帮助你创建各种Web应用,和丰富的HTTP工具。 使用Express可以快速地搭建一个完整功能的网站。 Expre…...
JVM垃圾回收机制全解析
Java虚拟机(JVM)中的垃圾收集器(Garbage Collector,简称GC)是用于自动管理内存的机制。它负责识别和清除不再被程序使用的对象,从而释放内存空间,避免内存泄漏和内存溢出等问题。垃圾收集器在Ja…...
【机器视觉】单目测距——运动结构恢复
ps:图是随便找的,为了凑个封面 前言 在前面对光流法进行进一步改进,希望将2D光流推广至3D场景流时,发现2D转3D过程中存在尺度歧义问题,需要补全摄像头拍摄图像中缺失的深度信息,否则解空间不收敛…...
大语言模型如何处理长文本?常用文本分割技术详解
为什么需要文本分割? 引言:为什么需要文本分割?一、基础文本分割方法1. 按段落分割(Paragraph Splitting)2. 按句子分割(Sentence Splitting)二、高级文本分割策略3. 重叠分割(Sliding Window)4. 递归分割(Recursive Splitting)三、生产级工具推荐5. 使用LangChain的…...
spring:实例工厂方法获取bean
spring处理使用静态工厂方法获取bean实例,也可以通过实例工厂方法获取bean实例。 实例工厂方法步骤如下: 定义实例工厂类(Java代码),定义实例工厂(xml),定义调用实例工厂ÿ…...
Element Plus 表单(el-form)中关于正整数输入的校验规则
目录 1 单个正整数输入1.1 模板1.2 校验规则 2 两个正整数输入(联动)2.1 模板2.2 校验规则2.3 CSS 1 单个正整数输入 1.1 模板 <el-formref"formRef":model"formData":rules"formRules"label-width"150px"…...
九天毕昇深度学习平台 | 如何安装库?
pip install 库名 -i https://pypi.tuna.tsinghua.edu.cn/simple --user 举个例子: 报错 ModuleNotFoundError: No module named torch 那么我需要安装 torch pip install torch -i https://pypi.tuna.tsinghua.edu.cn/simple --user pip install 库名&#x…...
嵌入式学习笔记DAY33(网络编程——TCP)
一、网络架构 C/S (client/server 客户端/服务器):由客户端和服务器端两个部分组成。客户端通常是用户使用的应用程序,负责提供用户界面和交互逻辑 ,接收用户输入,向服务器发送请求,并展示服务…...
A2A JS SDK 完整教程:快速入门指南
目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库ÿ…...
