嵌入式蓝桥杯做题总结
第十二届省赛
按键代码
——自认为比较巧妙,定时器3被设置为10ms进入一次中断,代替了HAL_Delay(10)的方法消抖;
运用状态机机思想实现检测多个按键检测——且分为两个状态,其中一个状态PB1和PB2的按键不可使用
struct Key key[4] = {0, 0, 0};
uint8_t f;
void HAL_TIM_PeriodElapsedCallback(TIM_HandleTypeDef *htim)
{if (htim->Instance == TIM3){key[0].Key_sta = HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_0);key[2].Key_sta = HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_1);key[3].Key_sta = HAL_GPIO_ReadPin(GPIOB, GPIO_PIN_2);key[1].Key_sta = HAL_GPIO_ReadPin(GPIOA, GPIO_PIN_0);}//注意B2和B3对应Key[2]和Key[3];而B4对应Key[1];// Note that B2 and B3 correspond to Key[2] and Key[3]; B4 corresponds to Key[1];if (Para_flag==0) f=2;else f=4;//让按键B2~B3不可以在界面一中使用//注意上面的赋值// Make keys B2 to B3 unavailable in interface 1// Note the above assignmentfor (int i=0; i<f; i++){switch (key[i].sta){case 0:if (key[i].Key_sta==0){key[i].sta=1;}break;case 1:if (key[i].Key_sta==0){key[i].sta=2;}else{key[i].sta=0;}break;case 2:if(key[i].Key_sta==1) {key[i].sta=0;if(key[i].time<100){key[i].flag=1;key[i].time=0;}}else{key[i].time++;if (key[i].time>=100){key[i].long_flag=1;key[i].time=0;}}break;}}
}
//注意Time是用于检测长按按键的,本体用不上
菜单函数
在菜单中实现了按键二次检测 伏笔回收
#include "menu.h"
uint8_t data1=2, data2=4, data3=2;
double data4=3.5, data5=2;
char text1[30] = " ", text2[30] = " ",text3[30] = " ", text4[30] = " ";
char flag_m=0,Para_flag=0,PWM_Flag=1;void Menu(void)
{if (key[0].flag==1){flag_m=!flag_m;LCD_Clear(Black);//每次展示菜单前先清屏key[0].flag=0;}if (key[1].flag==1){PWM_Flag=!PWM_Flag;key[1].long_flag=0;key[1].flag=0;}//PWM和低电平的设置if (PWM_Flag==0) __HAL_TIM_SetCompare(&htim15, TIM_CHANNEL_1, 20);else __HAL_TIM_SetCompare(&htim15, TIM_CHANNEL_1, 0);if (flag_m==0){Para_flag = 0;show_Data();}else{Para_flag = 1;show_Para();}
}
void show_Data(void)
{data3=8-data1-data2;sprintf(text1, " Data ");sprintf(text2, " CNBR:%d ",data1);sprintf(text3, " VNBR:%d ",data2);sprintf(text4, " IDLE:%d ",data3);LCD_DisplayStringLine(Line2, (unsigned char *)text1);LCD_DisplayStringLine(Line4, (unsigned char *)text2);LCD_DisplayStringLine(Line6, (unsigned char *)text3);LCD_DisplayStringLine(Line8, (unsigned char *)text4);
}void show_Para(void)
{sprintf(text1, " Para ");sprintf(text2, " CNBR:%.2f ",data4);sprintf(text3, " VNBR:%.2f ",data5);LCD_DisplayStringLine(Line2, (unsigned char *)text1);LCD_DisplayStringLine(Line4, (unsigned char *)text2);LCD_DisplayStringLine(Line6, (unsigned char *)text3);if (key[2].flag==1){data4+=0.5;data5+=0.5;key[2].long_flag=0;key[2].flag=0;}if (key[3].flag==1){data4-=0.5;data5-=0.5;key[3].long_flag=0;key[3].flag=0;}
}
我认为最难的就是串口部分
也可能是我的方法过于难了,应该可以使用先把串口数据存到数组,然后在数组中依靠下标来检测错误
遇到的难题--就是串口接收时检测到数据不符合格式,虽然重新开始存入数据,但是数据缓存区的数据没有被清空,会被带到下一次数据中,因此在寻找清空缓存区的方法过程中浪费很多时间,所幸也找到了对应的方法--暂时关闭中断接收,再在while循环中打开
//printf函数重写
int fputc(int c, FILE *stream)
{uint8_t ch[1]={c};HAL_UART_Transmit(&huart1, (unsigned char *)ch, 1, 0xFFFF);return c;
}uint8_t rx=0;
uint8_t Index=0;
char temp_t[5];
char temp_n[5];
char temp_time[11];
char temp_minute[3];
char trash;
uint8_t usart_state=0;//用于标志是否接收完数据 是否可以进入处理函数//方法1 在串口处初步处理信息——出现bug是无法清除串口缓存区导致的
//串口接收中断函数
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{if (huart->Instance == USART1){if (Index<4){HAL_UART_Receive_IT(&huart1, &rx, 1);temp_t[Index++]=rx;}else if(Index==4){HAL_UART_Receive_IT(&huart1, &rx, 1);if (rx!=':'){//目的:出现错误时会打印出两个Error,尝试在出现错误后读取数据并清空数据来解决问题//方法一:失败——找不到对应的寄存器//把剩下的数据读出即可//实现方法while(sr&rx_flag)xxx=dr
// while(USART1->ISR&0x10)
// {
// HAL_UART_Receive_IT(&huart1, &rx, 1);
// trash=rx;
// }//方法二:这个函数似乎不起作用
// __HAL_UART_FLUSH_DRREGISTER(&huart1);
// //方法三:似乎也不起作用
// while(__HAL_UART_GET_FLAG(&huart1,UART_FLAG_RXNE)==SET)
// {
// HAL_UART_Receive_IT(&huart1, &rx, 1);
// }
// __HAL_UART_CLEAR_FLAG(&huart1,UART_FLAG_RXNE);//方法三:直接在这关闭串口中断接收,然后在while循环中再打开 效果出奇地好//可能关闭中断接收后,对应的缓存区的数据也被清除了HAL_UART_AbortReceive_IT(&huart1);Index=0;printf("Erorr\r\n");}else{Index++;}}else if (Index<9){HAL_UART_Receive_IT(&huart1, &rx, 1);temp_n[(Index++)-5]=rx;}else if (Index==9){HAL_UART_Receive_IT(&huart1, &rx, 1);if (rx!=':'){
// while(__HAL_UART_GET_FLAG(&huart1,UART_FLAG_RXNE)==SET)
// {
// HAL_UART_Receive_IT(&huart1, &rx, 1);
// }
// __HAL_UART_CLEAR_FLAG(&huart1,UART_FLAG_RXNE);HAL_UART_AbortReceive_IT(&huart1);Index=0;printf("Erorr\r\n");}else{Index++;}}else if (Index>9)//前大段数字{if(Index<20){HAL_UART_Receive_IT(&huart1, &rx, 1);temp_time[(Index++)-10]=rx;}else//只有分{HAL_UART_Receive_IT(&huart1, &rx, 1);temp_minute[(Index++)-20] = rx;}}if (Index==22){usart_state=1; Index=0;//表示一组数据接收完成 置标志位 可以进入数据处理函数}
// if (Index==22)
// {
// for (int i=0;i<4;i++) printf("%c", temp_t[i]);
// printf(":");
// for (int i=0;i<4;i++) printf("%c", temp_n[i]);
// printf(":");
// for (int i=0;i<12;i++) printf("%c", temp_time[i]);
// }}
}
#include "Myusart.h"struct In in[8]={0};
uint8_t yn=0;//是否在车库内
uint8_t outcar_index=0;
double Money=0;
uint16_t Time_parking=0;
struct Time temp_time_struct;void USART_Deal(void)
{if (usart_state==1){//置零以便下次工作usart_state=0;//先把字符串数组的最后一位置为'\0'——必要操作temp_n[4]='\0';temp_t[4]='\0';temp_time[10]='\0';temp_minute[2]='\0';//对时间进行处理//注意strtol最大只能转int32_t的数 uint64_t number=strtol(temp_time, NULL, 10);//字符串数字转int类型uint8_t number1=strtol(temp_minute, NULL, 10);temp_time_struct.Y=number/1000000;//yeartemp_time_struct.M=number/10000%100;//monthtemp_time_struct.D=number/100%100;//daytemp_time_struct.h=number%100;//hourtemp_time_struct.m=number1;//min//Error情况if ((temp_time_struct.M>12)&& (temp_time_struct.D>31)&& (temp_time_struct.h>23)&& (temp_time_struct.m>59)){printf("Erorr\r\n");return ;}//遍历结构体数组寻找number1;//min是否已经停在车库for(int i=0; i<8; i++){if (in[i].YN==1){if (!strcmp(temp_n, in[i].num)){outcar_index=i;yn=1;//出停车库//并把对应车辆所有清零}else {yn=0;}}else {yn=0;}}//是否在车库内之后的操作if (yn==1){//出停车库//并把对应车辆所有清零in[outcar_index].YN=0;Time_parking = (temp_time_struct.Y-in[outcar_index].t.Y)*8760+(temp_time_struct.M-in[outcar_index].t.M)*720+(temp_time_struct.D-in[outcar_index].t.D)*24+(temp_time_struct.h-in[outcar_index].t.h)+(bool)(temp_time_struct.m-in[outcar_index].t.m);if(!(strcmp(temp_t, "CNBR\0"))){Money=Time_parking*data4;data1--;}if ((!strcmp(temp_t, "VNBR\0"))){Money=Time_parking*data5;data2--;}printf("%s:%s:%d:%.2f\r\n", temp_t, temp_n, Time_parking, Money);printf("%d\r\n", in[outcar_index].YN);}else//进入停车库 记录信息{//判断车位是否已满 如果已满则取消操作data3=8-data1-data2;if ((data3-1)<0){printf("Erorr\r\n");return ;}else{if(!(strcmp(temp_t, "CNBR\0"))){data1++;}if ((!strcmp(temp_t, "VNBR\0"))){data2++;}}//寻找结构体数组中的空位uint8_t temp_index=0;for(int i=0; i<8; i++){if (in[i].YN==0){temp_index=i;}}//赋值strcpy(in[temp_index].type, temp_t);strcpy(in[temp_index].num, temp_n);//注意strtol最大只能转int32_t的数 uint64_t number=strtol(temp_time, NULL, 10);//字符串数字转int类型uint8_t number1=strtol(temp_minute, NULL, 10);in[temp_index].t.Y=number/1000000;//yearin[temp_index].t.M=number/10000%100;//monthin[temp_index].t.D=number/100%100;//dayin[temp_index].t.h=number%100;//hourin[temp_index].t.m=number1;//minin[temp_index].YN=1;printf("%s-",in[temp_index].type);printf("%s-",in[temp_index].num);printf("%d-%d-%d-%d-%d\r\n",in[temp_index].t.Y,in[temp_index].t.M,in[temp_index].t.D,in[temp_index].t.h,in[temp_index].t.m);}}}
串口代码的优化
这次采取的方法是先把数据存到数组中,再根据下标判断数据是否符合规范
void HAL_UART_RxCpltCallback(UART_HandleTypeDef *huart)
{if (huart->Instance == USART1){HAL_UART_Receive_IT(&huart1, &rx, 1);data[data_index++] = rx;if (data_index>=22){//关闭串口接收中断——清空缓存区,以免有多余信息HAL_UART_AbortReceive_IT(&huart1);data_index=0;usart_state=1;
// printf("%s", data);}}
}
void Usart_Deal_Better(void)
{if (usart_state==1){//置零以便下次工作usart_state=0;if (!(data[3]==':')&&!(data[9]==':'))//判断':'格式{printf("Error");return ;}//判断数字是否正确strncpy(temp_time, data+10, 10);strncpy(temp_minute, data+20, 2);temp_time[10]='\0';temp_minute[2]='\0';uint64_t number=strtol(temp_time, NULL, 10);//字符串数字转int类型uint8_t number1=strtol(temp_minute, NULL, 10);temp_time_struct.Y=number/1000000;//yeartemp_time_struct.M=number/10000%100;//monthtemp_time_struct.D=number/100%100;//daytemp_time_struct.h=number%100;//hourtemp_time_struct.m=number1;//minif ((temp_time_struct.Y>2099)||(temp_time_struct.Y<2000)||(temp_time_struct.M>12)||(temp_time_struct.D>31)||(temp_time_struct.h>23)||(temp_time_struct.m>59)){printf("Error\r\n");return ;}//判断是否在停车场中//复制编号出来strncpy(temp_n, data+5, 4); for (int i=0; i<8; i++){if (in[i].YN==1){if (!strcmp(temp_n, in[i].num))//如果在停车场中{if (strncmp(data, in[i].type, 4)){printf("Error\r\n");return ;}else {outcar_index=i;yn=1;break;}}else//不在停车场中{yn=0;}}else yn=0;}uint8_t temp_index=0;//用于寻找结构体数组内的空位if (yn==0)//新来的{if (strncmp(data,"CNBR", 4)&&strncmp(data,"VNBR", 4))//判断停车类型{printf("Error\r\n");return ;}else//类型输入正确{data3=8-data1-data2;if ((data3-1)<=0){printf("Error\r\n");return ;}else//停车位充足{if (!strncmp(data,"CNBR", 4)){data1++;}if (!strncmp(data,"VNBR", 4)){data2++;}for (int i=0; i<8; i++)//寻找结构体数组中的空位{if (in[i].YN==0){temp_index=i;break;}}//登记信息strncpy(in[temp_index].type, data, 4);strncpy(in[temp_index].num, data+5, 4);strncpy(temp_time, data+10, 10);strncpy(temp_minute, data+20, 2);temp_time[10]='\0';temp_minute[2]='\0';uint64_t number=strtol(temp_time, NULL, 10);//字符串数字转int类型uint8_t number1=strtol(temp_minute, NULL, 10);in[temp_index].t.Y=temp_time_struct.Y;in[temp_index].t.M=temp_time_struct.M;in[temp_index].t.D=temp_time_struct.D;in[temp_index].t.h=temp_time_struct.h;in[temp_index].t.m=temp_time_struct.m;in[temp_index].YN=1;printf("%s-",in[temp_index].type);printf("%s-",in[temp_index].num);printf("%d-%d-%d-%d-%d\r\n",in[temp_index].t.Y,in[temp_index].t.M,in[temp_index].t.D,in[temp_index].t.h,in[temp_index].t.m);}}}else//出停车库 {in[outcar_index].YN=0;strncpy(temp_t, data, 4);Time_parking = (temp_time_struct.Y-in[outcar_index].t.Y)*8760+(temp_time_struct.M-in[outcar_index].t.M)*720+(temp_time_struct.D-in[outcar_index].t.D)*24+(temp_time_struct.h-in[outcar_index].t.h);if ((temp_time_struct.m-in[outcar_index].t.m>0)){Time_parking++;} if(!(strcmp(temp_t, "CNBR\0"))){Money=Time_parking*data4;data1--;}if ((!strcmp(temp_t, "VNBR\0"))){Money=Time_parking*data5;data2--;}printf("%s:%s:%d:%.2f\r\n", temp_t, temp_n, Time_parking, Money);}}
}
十三届省赛
IIC部分
IIC的读写eeprom和读读eeprom之间必须要有时间间隔,否则会出现写入错误或者读出错误

例如图中的Delay10ms

ADC采样部分
由于之前ADC采集两个电位器电压是用了不同的两个ADC,而这次题目要求是用同一个ADC的不同通道,这就涉及到了ADC多通道采集的问题了
首先cubemx配置,打开对应的输入引脚

再打开扫描模式,连续转换,DMA转运

再

代码甚至只需要一句
自己创建一个数组存储数据
HAL_ADC_Start_DMA(&hadc2, (uint32_t *)ADC_value,2);
仔细看芯片手册,板子上的电压采集是J11和J12口,因为没看清楚,导致浪费了3个小时检查错误

且要注意一直打开DMA转运会严重拖慢程序的执行,即导致板子上程序运行极为缓慢,所以可以在交互后需要获取ADC的值时打开ADC_DMA转运,接收好数据后立马关闭,这样就不会太大地影响板子的运行速度了
if (B4==0)//Data{HAL_ADC_Start_DMA(&hadc2, (uint32_t *)ADC_value,2);HAL_Delay(10);data1=ADC_value[0]*3.3/4096;data2=ADC_value[1]*3.3/4096;recd1++;recd1_5++;recdPA4_buff[PA4_Index++]=data1;recdPA5_buff[PA5_Index++]=data2;if (recd2<data1) {recd2=data1;}if (recd3>data1) {recd3=data1;}if (recd2_5<data2) {recd2_5=data2;}if (recd3_5>data2) {recd3_5=data2;}HAL_ADC_Stop_DMA(&hadc2);//记得关闭DMA,否则会导致程序运行缓慢}
相关文章:
嵌入式蓝桥杯做题总结
第十二届省赛 按键代码 ——自认为比较巧妙,定时器3被设置为10ms进入一次中断,代替了HAL_Delay(10)的方法消抖; 运用状态机机思想实现检测多个按键检测——且分为两个状态,其中一个状态PB1和PB2的按键不…...
Spring Boot 常用注解大全
以下是Spring Boot中常用的注解及其详细解释以及相应的代码示例: SpringBootApplication: 这个注解用于标识一个Spring Boot应用的主类。它整合了 Configuration,EnableAutoConfiguration 和 ComponentScan。 SpringBootApplication public class Demo…...
(MATLAB)第十二章-数列与极限
目录 12.1 数列 12.1.1 数列求和 1. 累计求和函数sum() 2. 忽略NaN累计求和函数 nansum() 3. 求此元素位置之前的元素和函数cumsum() 4. 求梯形累计和函数cumtrapz() 12.1.2 数列求积 1. 元素连续相乘函数 prod() 2. 求累计积函数 cumprod() 3. 阶乘函数 ffactorial(n…...
OJ输入问题+准备
写在之前: 发现题目输入是这样的: 我的问题:如何通过空格分割这些输入的字符串并分别保存!!(C语言scanf好解决一点但我选择C....) C引入了ostringstream、istringstream、stringstream这三个类…...
软考高级:主动攻击和被动攻击概念和例题
作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。 热门文章推荐&am…...
cuda python torch 虚拟环境配置
以下是Pytorch和CUDA对应的版本 以下是Pytorch和Python对应的版本 检查cuda与Python版本是否匹配 import torch print(torch.__version__) print(torch.cuda.is_available()) print(torch.empty(3,4,devicecuda))cuda 删除cuda conda uninstall cudatoolkit --forceconda u…...
激光炸弹 刷题笔记
前置知识 二维前缀和 子矩阵的和 刷题笔记 {二维前缀和}-CSDN博客 思路 参考二维前缀和 将子矩阵的和 做成动态矩阵 一个个矩阵搜索 符合要求边长 矩阵中的元素和最大值 将x1,y1用i-k,j-k表示即可 x2,y2用i,j表示 代码 #include<iostream> #include<…...
Vue3学习记录(三)--- 组合式API之生命周期和模板引用
一、生命周期 1、简介 生命周期,指的是一个 Vue 实例从创建到销毁的完整阶段,强调的是一个时间段。 生命周期钩子函数,指的是 Vue 实例提供的内置函数,函数的参数为一个回调函数。这些钩子函数会在实例生命周期的某些固定…...
Batch Normalization和Layer Normalization和Group normalization
文章目录 前言一、Group normalization二、批量规范化(Batch Normalization)三、层规范化(Layer Normalization) 前言 批量规范化和层规范化在神经网络中的每个批次或每个层上进行规范化,而GroupNorm将特征分成多个组,并在每个组内…...
命名实体识别NER(综合代码示例)
一、命名实体识别发展方向 二、中文数据集 CCKS2017开放的中文的电子病例测评相关的数据。 评测任务一:https://biendata.com/competition/CCKS2017_1/ 评测任务二:https://biendata.com/competition/CCKS2017_2/ CCKS2018开放的音乐领域的实体识别任务…...
关于jQuery日历插件:daterangepicker
关于options singleDatePicker: false 双日历,true 单日历 timePicker:false 不显示时分秒,true 显示时分秒 timePickerIncreament:1 默认值 {singleDatePicker : false, //是否显示单日历框 dateLimit : { days : 30 }, //起…...
【贪心算法】最大子序和
给你一个整数数组 nums ,请你找出一个具有最大和的连续子数组(子数组最少包含一个元素),返回其最大和。 子数组是数组中的一个连续部分。 示例 1: 输入:nums [-2,1,-3,4,-1,2,1,-5,4] 输出:6…...
爬虫逆向网站案例
一、相关网页 东方财富人气排行榜 二、查找url 三、寻找curl并复制 四、打开Convert curl commands to code (curlconverter.com) 五、修改并执行代码 import requestscookies {st_si: 73974981954644,st_pvi: 39724919122964,st_sp: 2024-03-05%2018%3A27%3A22,st_inirUrl:…...
蓝桥杯复习之前缀和
题目链接:https://www.luogu.com.cn/problem/P8649 思路: 看到区间和,第一反应肯定是前缀和,我们求出前缀和后对前缀和数组每一个值模k,然后对一个数组的值查看前面有几个相同的,举个例子:…...
动态规划(算法竞赛、蓝桥杯)--背包DP求具体方案
1、B站视频链接:E20 背包DP 求具体方案_哔哩哔哩_bilibili #include <bits/stdc.h> using namespace std; const int N1010; int v[N],w[N]; int f[N][N],p[N][N];int main(){int n,m;cin>>n>>m;for(int i1;i<n;i)cin>>v[i]>>w[i…...
go写mysql取得自增字段值
场景:有多张表,依据其中一张表的自增字段取得 id 值作为对象ID,然后使用这个Id插入到其他它表中。 如下一张 MySQL 的 innodb 表 X,用 go 编写程序,不指定 a 的值,指定 b 和 c 的值,往表 X 插入…...
Vue 3的Composition API和vue2的不同之处
Vue 3的Composition API是Vue.js框架的一个重要更新,它提供了一种新的组件逻辑组织和复用方式。在Vue 2中,我们通常使用Options API(data、methods、computed等)来组织组件的逻辑,但这种组织方式在处理复杂组件时可能会…...
go语言基础 -- 面向对象编程
go语言面向对象编程思想 面向对象编程离不开封装、继承、多态三个特性,go语言与其他c、java不太一样,没有类的概念,面向对象的实现也有些区别,下面分别描述。 go语言封装 结构体中字段如欲对外隐藏,首字母小写&…...
HarmonyOS—编译构建概述
编译构建是将应用/服务的源代码、资源、第三方库等,通过编译工具转换为可直接在硬件设备上运行的二进制机器码,然后再将二进制机器码封装为HAP/APP软件包,并为HAP/APP包进行签名的过程。其中,HAP是可以直接运行在模拟器或真机设备…...
下载element-ui 资源,图标 element-icons.woff,element-icons.ttf 无法解码文件字体
css下载地址:https://unpkg.com/element-ui2.15.14/lib/theme-chalk/index.css js下载地址:https://unpkg.com/element-ui2.15.14/lib/index.js 图标及文字文件下载地址: element-icons.woff:: https://unpkg.com/element-…...
LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器的上位机配置操作说明
LBE-LEX系列工业语音播放器|预警播报器|喇叭蜂鸣器专为工业环境精心打造,完美适配AGV和无人叉车。同时,集成以太网与语音合成技术,为各类高级系统(如MES、调度系统、库位管理、立库等)提供高效便捷的语音交互体验。 L…...
从深圳崛起的“机器之眼”:赴港乐动机器人的万亿赛道赶考路
进入2025年以来,尽管围绕人形机器人、具身智能等机器人赛道的质疑声不断,但全球市场热度依然高涨,入局者持续增加。 以国内市场为例,天眼查专业版数据显示,截至5月底,我国现存在业、存续状态的机器人相关企…...
[10-3]软件I2C读写MPU6050 江协科技学习笔记(16个知识点)
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16...
Module Federation 和 Native Federation 的比较
前言 Module Federation 是 Webpack 5 引入的微前端架构方案,允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...
C# 类和继承(抽象类)
抽象类 抽象类是指设计为被继承的类。抽象类只能被用作其他类的基类。 不能创建抽象类的实例。抽象类使用abstract修饰符声明。 抽象类可以包含抽象成员或普通的非抽象成员。抽象类的成员可以是抽象成员和普通带 实现的成员的任意组合。抽象类自己可以派生自另一个抽象类。例…...
自然语言处理——Transformer
自然语言处理——Transformer 自注意力机制多头注意力机制Transformer 虽然循环神经网络可以对具有序列特性的数据非常有效,它能挖掘数据中的时序信息以及语义信息,但是它有一个很大的缺陷——很难并行化。 我们可以考虑用CNN来替代RNN,但是…...
智能仓储的未来:自动化、AI与数据分析如何重塑物流中心
当仓库学会“思考”,物流的终极形态正在诞生 想象这样的场景: 凌晨3点,某物流中心灯火通明却空无一人。AGV机器人集群根据实时订单动态规划路径;AI视觉系统在0.1秒内扫描包裹信息;数字孪生平台正模拟次日峰值流量压力…...
【数据分析】R版IntelliGenes用于生物标志物发现的可解释机器学习
禁止商业或二改转载,仅供自学使用,侵权必究,如需截取部分内容请后台联系作者! 文章目录 介绍流程步骤1. 输入数据2. 特征选择3. 模型训练4. I-Genes 评分计算5. 输出结果 IntelliGenesR 安装包1. 特征选择2. 模型训练和评估3. I-Genes 评分计…...
Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习)
Aspose.PDF 限制绕过方案:Java 字节码技术实战分享(仅供学习) 一、Aspose.PDF 简介二、说明(⚠️仅供学习与研究使用)三、技术流程总览四、准备工作1. 下载 Jar 包2. Maven 项目依赖配置 五、字节码修改实现代码&#…...
RSS 2025|从说明书学习复杂机器人操作任务:NUS邵林团队提出全新机器人装配技能学习框架Manual2Skill
视觉语言模型(Vision-Language Models, VLMs),为真实环境中的机器人操作任务提供了极具潜力的解决方案。 尽管 VLMs 取得了显著进展,机器人仍难以胜任复杂的长时程任务(如家具装配),主要受限于人…...
