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

MSPM0G3507_2024电赛自动行驶小车(H题)_问题与感悟

这次电赛题目选的简单了,还规定不能使用到摄像头,这让我之前学习的Opencv 4与树莓派无用武之地了,但我当时对于三子棋题目饶有兴趣,但架不住队友想稳奖,只能选择这个H题了......

之后我还想抽空将这个E题三子棋题目做做,写篇博客实现一下......

这篇文就将一些过程中 遇到的问题 与 可能的解决法 讲一下.....

目录

MSPM0G3507库函数问题与修改:

端口状态读取函数问题:

串口接收函数存在强制类型转换:

汇编文件定义的数据处理栈过小:

直流电机干扰磁场:

题目思路:

PID角度惯导:

PID角度惯导视频:

第一题:

第一题视频:

第二题:

第二题视频:

 第三题:

第三题视频:

主函数与状态安排:

网上查阅资料贴出:


MSPM0G3507库函数问题与修改:

端口状态读取函数问题:

在尝试通过读取引脚高低电平来获取八路寻迹的端口状态时,发现它的引脚读取函数设计有些奇特,返回值不是类似于STM32的那种0和1,

我们发现 DL_GPIO_readPins(GPIOA, DL_GPIO_PIN_15) ,低电平就返回0,而高电平返回的不是1,而是引脚的编号......

串口接收函数存在强制类型转换:

在使用串口时发现 STATIC INLINE uint8 t DL UART receiveData(UART Regs *uart)

存在强制类型转换的现象:

这会将十六进制发送过来的数据强制转换为0~255的十进制数据,这是个多此一举的冗余步骤

随后去掉了这个强制类型转换:

汇编文件定义的数据处理栈过小:

在进行串口与数据接收时,我写了一个函数用于解算数据包以及计算角度,没想到在进行通信测试时,串口一直没有执行printf返回给上位机任何数据,后来才发现是在解算步骤卡住了:

以下是我解算JY901B陀螺仪 数据包定义的数据变量与函数,该函数在串口中断中调用:

数据变量:

最终结算好的数据存在了float Angle_R[3];

#include <string.h>uint8_t RX_BUFFER[10];typedef struct
{float angle[3];
}Angle;struct SAngle//角度
{short Angle[3];short T;
};struct SAngle stcAngle;
float Angle_R[3];void JY901_Process(uint8_t RxData);

函数:


void JY901_Process(uint8_t RxData)
{static uint8_t state=0;static uint8_t bufsize=0;switch(state){case 0://搜索到帧头if(RxData==0x55)	{ state=1;}else state=0;break;case 1://搜索到角度帧if(RxData==0x53)	{ state=2;}else state=0; //否则重新搜素break;case 2:RX_BUFFER[bufsize]=RxData;bufsize++;if(bufsize==9){state=3;bufsize=0;}break;case 3:memcpy(&stcAngle,&RX_BUFFER[0],8);for(uint8_t j = 0; j < 3; j++){Angle_R[j] = (float)stcAngle.Angle[j]/32768*180;}state = 0;break;}}

随后为了解决这个问题,将汇编文件的栈大小进行了修改:

修改后:

直流电机干扰磁场:

中途发现陀螺仪存在左右飘逸的现象,起初怀疑是直流电机磁场对它有影响,就将直流电机的外壳接地了,结果发现影响更大了,就不在接地了.....

题目思路:

PID角度惯导:

这是将电机速度闭环之后,再对角度闭环的结果:可以使小车保持在一个角度:

 //用于初始化pid参数的函数
void PID_Init(PID *pid, float p, float i, float d, float maxI, float maxOut)
{pid->kp = p;pid->ki = i;pid->kd = d;pid->maxIntegral = maxI;pid->maxOutput = maxOut;
}//进行一次pid计算
//参数为(pid结构体,目标值,反馈值),计算结果放在pid结构体的output成员中
void PID_Calc(PID *pid, float reference, float feedback)
{//更新数据pid->lastError = pid->error; //将旧error存起来pid->error = reference - feedback; //计算新error//计算微分float dout = (pid->error - pid->lastError) * pid->kd;//计算比例float pout = pid->error * pid->kp;//计算积分pid->integral += pid->error * pid->ki;//积分限幅if(pid->integral > pid->maxIntegral) pid->integral = pid->maxIntegral;else if(pid->integral < -pid->maxIntegral) pid->integral = -pid->maxIntegral;//计算输出pid->output = pout+dout + pid->integral;//输出限幅if(pid->output > pid->maxOutput) pid->output =   pid->maxOutput;else if(pid->output < -pid->maxOutput) pid->output = -pid->maxOutput;
}//首先定义PID结构体用于存放一个PID的数据
typedef struct
{float kp, ki, kd; //三个系数float error, lastError; //误差、上次误差float integral, maxIntegral; //积分、积分限幅float output, maxOutput; //输出、输出限幅
}PID;PID mypid = {0}; //创建一个PID结构体变量
PID_Init(&mypid, 1.5, 0, 3, 80, 100); //初始化PID参数

角度PID计算惯导部分:


char imu2(float angle)
{char flag = 0;float chazhi_angle;chazhi_angle = fabs(Angle_R[2] - angle);targetValue=angle;float feedbackValue = Angle_R[2]; //这里获取到被控对象的反馈值PID_Calc(&mypid, targetValue, feedbackValue); //进行PID计算,结果在output成员变量设定执行器输出大小(mypid.output);SPEEED[0]=mypid.output;SPEEED[1]=mypid.output*(-1);SPEEED[2]=mypid.output;SPEEED[3]=mypid.output*(-1);I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动if(chazhi_angle<3) {return 1;}return 0;
}

PID角度惯导视频:

PID角度惯导视频

第一题:

就将小车四个电机闭环,保持同速即可,使用状态机的思维去写的,写一个状态就测试一次小车的具体运行程序结果,看是否需要添加或修改其余传感器逻辑......

这里我有个空闲状态,一旦切换到空闲状态,小车就会对0度进行角度惯导......

//任务1
void TASK_1(void)
{GET_FTT_PORT_status();if(DL_GPIO_readPins(GPIOA, DL_GPIO_PIN_16)==0){beep(1);led(1);	delay_ms(10);	  beep(0);led(0);status1 =1;status3=99;}//选择状态进入switch(status1){case 0:target_angle_F=1;target_angle=0;system_idie_state();     break;   //系统空闲状态:case 1: //无脑直线 //GET_FTT_PORT_status();target_angle_F=0;target_angle=0;         SPEEED[0]=45*(-1);SPEEED[1]=45;SPEEED[2]=45;SPEEED[3]=45*(-1);I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动//任意检测到线if(L1==1 || L2==1 || L3==1|| L4==1|| L5==1|| L6==1|| L7==1|| L8==1){SPEEED[0]=0;SPEEED[1]=0;SPEEED[2]=0;SPEEED[3]=0;I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动beep(1);led(1);delay_ms(15);beep(0);led(0);status1=0;}break;}			
}

第一题视频:

2024电赛自动行驶小车(H题)_第一问

第二题:

这题的A->B部分就是先靠PID直线,然后巡线,然后想办法通过陀螺仪反馈使小车转到差不多180度的位置,陀螺仪因为读取方式不同,其实转到180度正还是不容易的......

然后我定的是-178度位置,为了防止它缓慢偏出线,我又增加了179的惯导在直行的逻辑中,(但这样简单粗暴的添加使得我的小车挺抖......)

//任务2  不许删动
//放置时 先正放再 向左边斜放 
void TASK_2(void)
{GET_FTT_PORT_status();         //获得巡线返回if(DL_GPIO_readPins(GPIOA, DL_GPIO_PIN_15)==0){	  beep(1);led(1);	delay_ms(10); beep(0);led(0);		status2=1;status1=99;status3=99;}switch (status2){case 0:system_idie_state();    break;case 1://A->B 无脑直线		target_angle_F=0;//imu2(0);         //惯导直行SPEEED[0]=45*(-1);SPEEED[1]=45;SPEEED[2]=45;SPEEED[3]=45*(-1);I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动//任意检测到线if(L1==1 || L2==1 || L3==1|| L4==1|| L5==1|| L6==1|| L7==1|| L8==1){beep(1);led(1);delay_ms(15);beep(0);led(0);status2=2;status=1;}break;case 2://B->C 巡线 FTT_judge_status();//判定巡线系统状态target_angle_F=0;//	//先清零系统预设方向status_Direction=0;//八路寻迹判断系统状态,一般会传给status_Direction数值FTT_judge_status();//选择状态进入switch(status){case 0:system_idie_state();     break;   //系统空闲状态:case 1:system_follow_straight();break;	 //系统直线寻迹状态(可带小弧度偏转) case 2:system_Turn_left();      break;   //小车左转调整状态case 3:system_Turn_right();     break;   //小车右转调整状态//case 4:system_stop();           break;   //停车}	//已经到C了if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 &&(fabs(Angle_R[2]+180)<=15)){beep(1);led(1);delay_ms(15);beep(0);led(0);//imu2(-60);   //偏正//targetValue=-44;target_angle_F=0;while(imu2_my(-175)==0)status2=3;status=0;		}//有可能是巡线时遇到调整角度黑线在夹缝		else if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0){//imu2(-120);         //惯导偏正(向右)	system_Turn_right();}	break;case 3://C->D  无脑执行imu2_my(-177);         //惯导直行 175SPEEED[0]=45*(-1);SPEEED[1]=45;SPEEED[2]=45;SPEEED[3]=45*(-1);I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动//任意检测到线if(L1==1 || L2==1 || L3==1|| L4==1|| L5==1|| L6==1|| L7==1|| L8==1){beep(1);led(1);delay_ms(15);beep(0);led(0);status2=4;status=1;}break;case 4://D->A   //	//先清零系统预设方向status_Direction=0;//八路寻迹判断系统状态,一般会传给status_Direction数值FTT_judge_status();//选择状态进入switch(status){case 0:system_idie_state();     break;   //系统空闲状态:case 1:system_follow_straight();break;	 //系统直线寻迹状态(可带小弧度偏转) case 2:system_Turn_left();      break;   //小车左转调整状态case 3:system_Turn_right();     break;   //小车右转调整状态//case 4:system_stop();           break;   //停车}	//已经到A了if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 &&(fabs(Angle_R[2])<=22)){SPEEED[0]=0;SPEEED[1]=0;SPEEED[2]=0;SPEEED[3]=0;I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动beep(1);led(1);delay_ms(15);beep(0);led(0);target_angle_F=0;target_angle=0;while(imu2_my(0)==0)   //偏正status=0;status2=9;status1=0;}//有可能是巡线时遇到调整角度黑线在夹缝		else if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 && Angle_R[2]>0){system_Turn_right();//惯导偏正(向右)}//有可能是巡线时遇到调整角度黑线在夹缝		else if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 && Angle_R[2]<0){//imu2(10);         //惯导偏正(向右)system_Turn_right();}break;}
}

第二题视频:

2024电赛自动行驶小车(H题)_第二问

 第三题:

第二题会做,这题其实也没问题...


//任务 3
void TASK_3(void)
{if(DL_GPIO_readPins(GPIOA, DL_GPIO_PIN_14)==0) {beep(1);led(1);	delay_ms(10);	  beep(0);led(0); status3 =1;status2=9;status1=9;}switch(status3){case 0:system_idie_state(); break;case 1://A->C 惯导后直线行驶target_angle=-33;//target_angle_F=0;while(imu2(-33)==0)status3=2;break;case 2://imu2(-37);//targetValue=-10;target_angle=-33;SPEEED[0]=55*(-1);SPEEED[1]=55;SPEEED[2]=55;SPEEED[3]=55*(-1);I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动//任意检测到线if(L1==1 || L2==1 || L3==1|| L4==1|| L5==1|| L6==1|| L7==1|| L8==1){beep(1);led(1);delay_ms(15);beep(0);led(0);target_angle=0;status3=3;status=1;status2=99;status1=99;}			break;case 3://C-> B//	//先清零系统预设方向status_Direction=0;//八路寻迹判断系统状态,一般会传给status_Direction数值FTT_judge_status();target_angle_F=0;//选择状态进入switch(status){case 0:system_idie_state();     break;   //系统空闲状态:case 1:system_follow_straight();break;	 //系统直线寻迹状态(可带小弧度偏转) case 2:system_Turn_left();      break;   //小车左转调整状态case 3:system_Turn_right();     break;   //小车右转调整状态//case 4:system_stop();           break;   //停车}				//已经到B了if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 &&(fabs(Angle_R[2])>=156)){beep(1);led(1);delay_ms(15);beep(0);led(0);//while(imu2(-148)==0)   //偏正status=0;		status3=4;status2=99;status1=99;}//有可能是巡线时遇到调整角度黑线在夹缝		else if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 && Angle_R[2]>0){system_Turn_right();  //惯导偏正(向右)}//有可能是巡线时遇到调整角度黑线在夹缝		else if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 && Angle_R[2]<0){//imu2(10);         //惯导偏正(向右)system_Turn_left();}					break;case 4://调整好角度target_angle_F=0;while(imu2_my(-163)==0)//target_angle=-63;//while(imu2(-63)==0)status3=5;	status2=99; status1=99;break;case 5:// B->D  target_angle_F=0;imu2_my(-138);system_Turn_left();SPEEED[0]=55*(-1);SPEEED[1]=55;SPEEED[2]=55;SPEEED[3]=55*(-1);I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动//任意检测到线if(L1==1 || L2==1 || L3==1|| L4==1|| L5==1|| L6==1|| L7==1|| L8==1){beep(1);led(1);delay_ms(15);beep(0);led(0);status3=6;status=1;}					case 6 ://D->A //	//先清零系统预设方向status_Direction=0;target_angle_F=0;//八路寻迹判断系统状态,一般会传给status_Direction数值FTT_judge_status();//选择状态进入switch(status){case 0:system_idie_state();     break;   //系统空闲状态:case 1:system_follow_straight();break;	 //系统直线寻迹状态(可带小弧度偏转) case 2:system_Turn_left();      break;   //小车左转调整状态case 3:system_Turn_right();     break;   //小车右转调整状态//case 4:system_stop();           break;   //停车}	//已经到A了if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 &&(fabs(Angle_R[2])<=22)){SPEEED[0]=0;SPEEED[1]=0;SPEEED[2]=0;SPEEED[3]=0;I2C_Write_Len(MOTOR_FIXED_SPEED_ADDR,SPEEED,4);						//控制电机转动beep(1);led(1);delay_ms(15);beep(0);led(0);//target_angle_F=0;target_angle_F=1;target_angle=0;while(imu2(0)==0)   //偏正status=0;		status3=7;status2=9;status1=0;}//有可能是巡线时遇到调整角度黑线在夹缝		else if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 && Angle_R[2]>0){system_Turn_right();//惯导偏正(向右)}//有可能是巡线时遇到调整角度黑线在夹缝		else if(L1==0&&L2==0&&L3==0&&L4==0&&L5==0&&L6==0&&L7==0&&L8==0 && Angle_R[2]<0){//imu2(10);         //惯导偏正(向右)system_Turn_right();}break;		}
}

第三题视频:

 这里就直接放第四问的视频了...第四问就是将第三问重复执行4次......

2024电赛自动行驶小车(H题)_第四问

主函数与状态安排:

主函数中有些任务状态变量statusx的初始值并不是0,这是为了防止进入其余状态时执行它的状态0操作(小车惯导0度 )的行为,并且,进入其余状态时,也应合理安排这些状态变量,使其不要互相串搞.....

网上查阅资料贴出:

PID超详细教程——PID原理+串级PID+C代码+在线仿真调参-CSDN博客

相关文章:

MSPM0G3507_2024电赛自动行驶小车(H题)_问题与感悟

这次电赛题目选的简单了&#xff0c;还规定不能使用到摄像头&#xff0c;这让我之前学习的Opencv 4与树莓派无用武之地了&#xff0c;但我当时对于三子棋题目饶有兴趣&#xff0c;但架不住队友想稳奖&#xff0c;只能选择这个H题了...... 之后我还想抽空将这个E题三子棋题目做…...

C语言:指针(2)

一.数组名 在了解数组名前我们先看一段代码 int arr[10] {1,2,3,4,5,6,7,8,9,10}; int *p &arr[0]; 根据我们上一篇学习的知识&#xff0c;我们知道&arr[0]是数组第一个元素的地址&#xff0c;这时我们再看另一段代码的运行结果。 #include <stdio.h> int ma…...

数组——二维数组

数组(中) 二维数组 定义 二维数组本质上是一个行列式的组合&#xff0c;也就是说二维数组是有行和列两部分构成。二维数组数据是通过行列进行解读。 二维数组可被视为一个特殊的一维数组&#xff0c;相当于二维数组又是一个一维数组&#xff0c;只不过它的元素是一维数组。 …...

深入 Vue 组件与状态管理的教程

目录 深入 Vue 组件与状态管理的教程第一部分&#xff1a;深入组件1. 理解插槽&#xff08;Slots&#xff09;的使用1.1 基础插槽示例1.2 具名插槽1.3 作用域插槽 第二部分&#xff1a;Vue Router1. 学习 Vue Router 的基本配置1.1 基本路由配置1.2 嵌套路由1.3 路由参数 2. 导…...

Spring Boot 实现异步处理多个并行任务

在现代Web应用开发中&#xff0c;异步处理和多任务并行处理对于提高系统的响应性和吞吐量至关重要。Spring Boot 提供了多种机制来实现异步任务处理&#xff0c;本文将介绍如何利用这些机制来优化您的应用程序性能。 1. 引言 在高负载情况下&#xff0c;如果所有的请求都采用…...

TiDB系列之:使用Flink TiDB CDC Connector采集数据

TiDB系列之&#xff1a;使用Flink TiDB CDC Connector采集数据 一、依赖项二、Maven依赖三、SQL Client JAR四、如何创建 TiDB CDC 表五、连接器选项六、可用元数据七、特征一次性处理启动阅读位置多线程读取DataStream Source 八、数据类型映射 TiDB CDC 连接器允许从 TiDB 数…...

每日一道算法题 最接近的三数之和

题目 16. 最接近的三数之和 - 力扣&#xff08;LeetCode&#xff09; Python class Solution:def threeSumClosest(self, nums: List[int], target: int) -> int:nums.sort()nlen(nums)ans0min_diffinf # infinite 无穷for i in range(n-2):tmpnums[i]li1rn-1while l<…...

搭建自己的金融数据源和量化分析平台(六):下载并存储沪深两市上市公司财报

基于不依赖wind、某花顺等第三方平台数据的考虑&#xff0c;尝试直接从财报中解析三大报表进而计算ROE等财务指标&#xff0c;因此需要下载沪深两市的上市公司财报数据&#xff0c;便于后续从pdf中解析三大报表。 深市爬虫好做&#xff0c;先放深市爬虫&#xff1a; 根据时间段…...

C语言-常见关键字详解

一、const 关键字const用于声明常量&#xff0c;赋值后&#xff0c;其值不能再被修改。 示例&#xff1a; const int MAX_COUNT 100; 二、static static关键字在不同情境下有不同作用&#xff1a; 1.函数中的静态变量&#xff1a;保留变量状态&#xff0c;仅初始化一次&a…...

异步编程之std::future(一): 使用

目录 1.概述 2.std::future的基本用法 3.使用 std::shared_future 4.std::future的使用场景 5.总结 1.概述 在编程实践中&#xff0c;我们常常需要使用异步调用。通过异步调用&#xff0c;我们可以将一些耗时、阻塞的任务交给其他线程来执行&#xff0c;从而保证当前线程的…...

Vue3 + JS项目配置ESLint Pretter

前言 如果在开发大型项目 同时为多人协作开发 那么 ESLint 在项目中极为重要 在使用 ESLint 的同时 也需要使用 Pretter插件 统一对代码进行格式化 二者相辅相成 缺一不可 1. 安装 VsCode 插件 在 VsCode 插件市场搜索安装 ESLint 和 Pretter 2. 安装依赖 这里直接在 pac…...

JavaScript (十四)——JavaScript typeof和类型转换

目录 JavaScript typeof, null, 和 undefined typeof 操作符 null undefined undefined 和 null 的区别 JavaScript 类型转换 JavaScript 数据类型 JavaScript 类型转换 将数字转换为字符串 将布尔值转换为字符串 将日期转换为字符串 将字符串转换为数字 一元运算符…...

CTF-web 基础

网络协议 OSI七层参考模型&#xff1a;一个标准的参考模型 物理层 网线&#xff0c;网线接口等。 数据链路层 可以处理物理层传入的信息。 网络层 比如IP地址 传输层 控制传输的内容的传输&#xff0c;在传输的过程中将要传输的信息分块传输完成之后再进行合并。 应用…...

CP AUTOSAR标准之ChineseV2XNetwork(AUTOSAR_SWS_ChineseV2XNetwork)(更新中……)

1 简介和功能概述 本文档指定了AUTOSAR基础软件模块中国车辆对接网络(CnV2xNet)的功能、API和配置。   中国车联网网络(CnV2xNet)与中国车联网消息(CnV2xMsg)、中国车联网管理(CnV2xMgt)、中国车联网安全(CnV2xSec)以及AUTOSAR BSW模块以太网接口(EthIf)共同构成了AUTOSAR架构…...

【hloc】 项目流程

hloc 项目流程 1. 数据集准备2. 特征提取3. 匹配特征4. 三维重建5. 定位6. 结果评估7. 示例脚本 这个项目涉及到了视觉定位和三维重建的一系列步骤&#xff0c;从特征提取、匹配、三维重建到定位和结果评估。通过提供的脚本文件&#xff0c;用户可以方便地运行整个流程。 1. 数…...

鸿蒙系统开发【应用接续】基本功能

应用接续 介绍 基于ArkTS扩展的声明式开发范式编程语言编写的一个分布式视频播放器&#xff0c;主要包括一个直播视频播放界面&#xff0c;实现视频播放时可以从一台设备迁移到另一台设备继续运行&#xff0c;来选择更合适的设备继续执行播放功能以及PAD视频播放时协同调用手…...

nextTick方法的作用是什么?什么时候会用到

nextTick 方法在 Vue.js 中扮演着重要的角色&#xff0c;它用于在下次 DOM 更新循环结束之后执行延迟回调。这主要用于确保在 Vue 完成 DOM 更新后执行依赖于 DOM 的操作。 作用 确保 DOM 更新完成&#xff1a;Vue 的 DOM 更新是异步的&#xff0c;当你修改了数据后&#xff0…...

多 NodeJS 环境管理

前言 对于某个项目依赖特定版本的 NodeJS&#xff0c;或几个项目的 NodeJS 版本冲突时&#xff0c;需要在系统中安装多个版本的 NodeJS&#xff0c;这时可以使用一些工具来进行多个 NodeJS 的管理。 有很多类似的 NodeJS 管理工具&#xff0c;如 nvm, nvs, n 等&#xff0c;接…...

解决网站被植入跳转木马病毒

概述 网站被植入跳转木马病毒是一种常见的安全威胁&#xff0c;它可能导致网站用户被重定向到恶意站点。本文将指导您如何检测、清除这类木马病毒以及采取预防措施。 步骤1&#xff1a;确认感染 首先&#xff0c;需要确认您的网站确实受到了跳转木马的影响。 示例&#xff…...

Node.js(6)——npm软件包管理

npm npm是Node.js标准的软件包管理器。 使用&#xff1a; 初始化清单文件&#xff1a;npm init-y(得到package.json文件&#xff0c;有则略过此命令)下载软件包&#xff1a;npm i 软件包名称使用软件包 示例&#xff1a; 初始状态下npm文件夹下只有server.js,下载软件包前看…...

业务系统对接大模型的基础方案:架构设计与关键步骤

业务系统对接大模型&#xff1a;架构设计与关键步骤 在当今数字化转型的浪潮中&#xff0c;大语言模型&#xff08;LLM&#xff09;已成为企业提升业务效率和创新能力的关键技术之一。将大模型集成到业务系统中&#xff0c;不仅可以优化用户体验&#xff0c;还能为业务决策提供…...

[2025CVPR]DeepVideo-R1:基于难度感知回归GRPO的视频强化微调框架详解

突破视频大语言模型推理瓶颈,在多个视频基准上实现SOTA性能 一、核心问题与创新亮点 1.1 GRPO在视频任务中的两大挑战 ​安全措施依赖问题​ GRPO使用min和clip函数限制策略更新幅度,导致: 梯度抑制:当新旧策略差异过大时梯度消失收敛困难:策略无法充分优化# 传统GRPO的梯…...

【杂谈】-递归进化:人工智能的自我改进与监管挑战

递归进化&#xff1a;人工智能的自我改进与监管挑战 文章目录 递归进化&#xff1a;人工智能的自我改进与监管挑战1、自我改进型人工智能的崛起2、人工智能如何挑战人类监管&#xff1f;3、确保人工智能受控的策略4、人类在人工智能发展中的角色5、平衡自主性与控制力6、总结与…...

1688商品列表API与其他数据源的对接思路

将1688商品列表API与其他数据源对接时&#xff0c;需结合业务场景设计数据流转链路&#xff0c;重点关注数据格式兼容性、接口调用频率控制及数据一致性维护。以下是具体对接思路及关键技术点&#xff1a; 一、核心对接场景与目标 商品数据同步 场景&#xff1a;将1688商品信息…...

c++ 面试题(1)-----深度优先搜索(DFS)实现

操作系统&#xff1a;ubuntu22.04 IDE:Visual Studio Code 编程语言&#xff1a;C11 题目描述 地上有一个 m 行 n 列的方格&#xff0c;从坐标 [0,0] 起始。一个机器人可以从某一格移动到上下左右四个格子&#xff0c;但不能进入行坐标和列坐标的数位之和大于 k 的格子。 例…...

React19源码系列之 事件插件系统

事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...

镜像里切换为普通用户

如果你登录远程虚拟机默认就是 root 用户&#xff0c;但你不希望用 root 权限运行 ns-3&#xff08;这是对的&#xff0c;ns3 工具会拒绝 root&#xff09;&#xff0c;你可以按以下方法创建一个 非 root 用户账号 并切换到它运行 ns-3。 一次性解决方案&#xff1a;创建非 roo…...

Nginx server_name 配置说明

Nginx 是一个高性能的反向代理和负载均衡服务器&#xff0c;其核心配置之一是 server 块中的 server_name 指令。server_name 决定了 Nginx 如何根据客户端请求的 Host 头匹配对应的虚拟主机&#xff08;Virtual Host&#xff09;。 1. 简介 Nginx 使用 server_name 指令来确定…...

DIY|Mac 搭建 ESP-IDF 开发环境及编译小智 AI

前一阵子在百度 AI 开发者大会上&#xff0c;看到基于小智 AI DIY 玩具的演示&#xff0c;感觉有点意思&#xff0c;想着自己也来试试。 如果只是想烧录现成的固件&#xff0c;乐鑫官方除了提供了 Windows 版本的 Flash 下载工具 之外&#xff0c;还提供了基于网页版的 ESP LA…...

BCS 2025|百度副总裁陈洋:智能体在安全领域的应用实践

6月5日&#xff0c;2025全球数字经济大会数字安全主论坛暨北京网络安全大会在国家会议中心隆重开幕。百度副总裁陈洋受邀出席&#xff0c;并作《智能体在安全领域的应用实践》主题演讲&#xff0c;分享了在智能体在安全领域的突破性实践。他指出&#xff0c;百度通过将安全能力…...