汽车辅助系统

news2025/3/12 11:56:31

目录

一,项目描述

二,项目 功能

三,代码实现

(1)倒车雷达

(2)AD(对 雨滴与光敏电阻传感器进行AD采集)

(3)雨刷

(4)灯光

最后总结:


一,项目描述

       当前移动互联网、物联网、云计算、大数据、人工智能为代表的信息技术的 运用促进社会向智能化进化,汽车交通领域智能化成为科技发展的必然趋势,车 联网、汽车驾驶辅助系统(ADAS)是汽车领域创新应用的重点。车联网技术是借 助人、车、环境、云平台之间全方位的连接和信息交互,精确感知和预测周边环 境状态,而 ADAS 作为一种实现人工智能驾驶过渡的技术,其原理是借助车辆上 感知层将检测到的车内外的环境信号转换成电信号,并经过数字信号处理完成智 能判断和车辆的自动控制。ADAS 功能的实现通常需要通过摄像头、激光雷达、 毫米波雷达、红外线探头等感知层、决策层和控制层完成信息的采集、分析和自 动驾驶动作的转换;而光学元件作为车载镜头、激光雷达等感知层信息采集的重 要入口,将受益于智能驾驶市场的发展。

二,项目 功能

该汽车驾驶辅助系统包含四大功能模块:倒车预警,感应雨刷、 自动大灯、中控显示。

(1)倒车预警 倒车预警功能是在倒车过程中检测车辆与后方障碍物的距离,实时在中控屏 进行距离显示。且当距离小于安全距离(可以在移动端进行修改)时,发出警报 声予以提示。

(2)感应雨刷 感应雨刷能够监测前挡风玻璃上是否有水,如果检测到有水,则会自动开启 雨刷,并且会根据雨水量的大小来相应改变雨刷的档位,即雨刷刷动频率。

(4)自动大灯 自动大灯功能能够实时监测行车环境光线的强弱,当检测到光照强度较弱时, 能够自动开启车灯;反之,当光照强度较强时会自动关闭大灯。

(5)中控显示。 中控显示指将其他辅助功能中检测到的环境参数、车辆状态、操作等信息在 中控屏上进行显示

三,代码实现

(1)倒车雷达

hcsr.c(使用定时器4进行距离计算)

void hcsr04_NVIC()
{
	NVIC_InitTypeDef NVIC_InitStructure;
	NVIC_PriorityGroupConfig(NVIC_PriorityGroup_1);
			
	NVIC_InitStructure.NVIC_IRQChannel = TIM4_IRQn;             
	NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0;  
	NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;         
	NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;       
	NVIC_Init(&NVIC_InitStructure);
}

//IO口初始化 及其他初始化
void Hcsr04Init()
{  
    TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;   
    GPIO_InitTypeDef GPIO_InitStructure;
    RCC_APB2PeriphClockCmd(HCSR04_CLK, ENABLE);
   
    GPIO_InitStructure.GPIO_Pin =HCSR04_TRIG;      
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;
    GPIO_Init(HCSR04_PORT, &GPIO_InitStructure);
    GPIO_ResetBits(HCSR04_PORT,HCSR04_TRIG);
     
    GPIO_InitStructure.GPIO_Pin =   HCSR04_ECHO;     
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
    GPIO_Init(HCSR04_PORT, &GPIO_InitStructure);  
    GPIO_ResetBits(HCSR04_PORT,HCSR04_ECHO);    
     
          
    RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM4, ENABLE);   
     
    TIM_DeInit(TIM4);
    TIM_TimeBaseStructure.TIM_Period = (1000-1); 
    TIM_TimeBaseStructure.TIM_Prescaler =(72-1); 
    TIM_TimeBaseStructure.TIM_ClockDivision=TIM_CKD_DIV1;
    TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  
    TIM_TimeBaseInit(TIM4, &TIM_TimeBaseStructure);          
        
    TIM_ClearFlag(TIM4, TIM_FLAG_Update);  
    TIM_ITConfig(TIM4,TIM_IT_Update,ENABLE);    
    hcsr04_NVIC();
    TIM_Cmd(TIM4,DISABLE);     
}


//打开定时器4
static void OpenTimerForHc()  
{
   TIM_SetCounter(TIM4,0);
   msHcCount = 0;
   TIM_Cmd(TIM4, ENABLE); 
}

//关闭定时器4
static void CloseTimerForHc()    
{
   TIM_Cmd(TIM4, DISABLE); 
}

//定时器4终中断
void TIM4_IRQHandler(void)  
{
   if (TIM_GetITStatus(TIM4, TIM_IT_Update) != RESET)  
   {
       TIM_ClearITPendingBit(TIM4, TIM_IT_Update  ); 
       msHcCount++;
   }
}
 

//获取定时器4计数器值
u32 GetEchoTimer(void)
{
   u32 t = 0;
   t = msHcCount*1000;
   t += TIM_GetCounter(TIM4);
   TIM4->CNT = 0;  
   delay_ms(50);
   return t;
}
 
//通过定时器4计数器值推算距离
float Hcsr04GetLength(void )
{
   u32 t = 0;
   int i = 0;
   float lengthTemp = 0;
   float sum = 0;
   while(i!=5)
   {
      TRIG_Send = 1;      
      delay_us(20);
      TRIG_Send = 0;
      while(ECHO_Reci == 0);      
      OpenTimerForHc();        
      i = i + 1;
      while(ECHO_Reci == 1);
      CloseTimerForHc();        
      t = GetEchoTimer();        
      lengthTemp = ((float)t/58.0);//cm
      sum = lengthTemp + sum ;
        
    }
    lengthTemp = sum/5.0;
    return lengthTemp;
}

hcsr.h

#ifndef __HCSR_H
#define __HCSR_H	

#define HCSR04_PORT     GPIOB
#define HCSR04_CLK      RCC_APB2Periph_GPIOB
#define HCSR04_TRIG     GPIO_Pin_11
#define HCSR04_ECHO     GPIO_Pin_10
#define ECHO_Reci  PBin(10)
#define TRIG_Send  PBout(11)
void hcsr04_NVIC(void);
void Hcsr04Init(void);
static void OpenTimerForHc(void);
static void CloseTimerForHc(void);
void TIM4_IRQHandler(void);
void NVIC_Configuration(void);
float Hcsr04GetLength(void );



#endif

(2)AD(对 雨滴与光敏电阻传感器进行AD采集)

#include "stm32f10x.h"                  // Device header
#include "stm32f10x_adc.h"
void AD_Init(void)
{
	
	ADC_InitTypeDef ADC_InitStructure;
	GPIO_InitTypeDef GPIO_InitStructure;
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_ADC1, ENABLE);
	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
	
	RCC_ADCCLKConfig(RCC_PCLK2_Div6);
	
	
	GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AIN;
	GPIO_InitStructure.GPIO_Pin =  GPIO_Pin_2 | GPIO_Pin_3;
	GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
	GPIO_Init(GPIOA, &GPIO_InitStructure);
		
	
	ADC_InitStructure.ADC_Mode = ADC_Mode_Independent;
	ADC_InitStructure.ADC_DataAlign = ADC_DataAlign_Right;
	ADC_InitStructure.ADC_ExternalTrigConv = ADC_ExternalTrigConv_None;
	ADC_InitStructure.ADC_ContinuousConvMode = DISABLE;
	ADC_InitStructure.ADC_ScanConvMode = DISABLE;
	ADC_InitStructure.ADC_NbrOfChannel = 1;
	ADC_Init(ADC1, &ADC_InitStructure);
	
	ADC_Cmd(ADC1, ENABLE);
	
	ADC_ResetCalibration(ADC1);
	while (ADC_GetResetCalibrationStatus(ADC1) == SET);
	ADC_StartCalibration(ADC1);
	while (ADC_GetCalibrationStatus(ADC1) == SET);
}

uint16_t AD_GetValue(uint8_t ADC_Channel)
{
	ADC_RegularChannelConfig(ADC1, ADC_Channel, 1, ADC_SampleTime_55Cycles5);
	ADC_SoftwareStartConvCmd(ADC1, ENABLE);
	while (ADC_GetFlagStatus(ADC1, ADC_FLAG_EOC) == RESET);
	return ADC_GetConversionValue(ADC1);
}

main.c(倒车雷达)

 //倒车雷达
      if(KEY1 ==0) //按键1进行加
				{
			delay_ms(100);
			if(KEY1==0)
				biaozhun+=changdu;
		}
			
		 if(KEY2==0) //按键2进行减
			 {
			delay_ms(100);
			if(KEY2==0)
				biaozhun-=changdu;
		}
			 printf("距离为:%.3fcm\n",Hcsr04GetLength());
    printf("阈值为:%d\n",biaozhun);
     
		 //阈值
		  showhanzi(10,40,4);
		 showhanzi(40,40,5);
		LCD_ShowNum(90,40,biaozhun,4);
		 LCD_ShowString(120,40,"cm");
		//距离
		 showhanzi(10,80,6);
		  showhanzi(40,80,7);
		LCD_ShowNum(90,80,Hcsr04GetLength(),4);
		 LCD_ShowString(120,80,"cm");
    //达到阈值时进行蜂鸣器警报
     if(Hcsr04GetLength()<biaozhun)
		 {
		 GPIO_ResetBits(GPIOB, GPIO_Pin_12);  
		 }
		else 
		 {
			  GPIO_SetBits(GPIOB, GPIO_Pin_12);
		 }

(3)雨刷

if((AD1<4100) &&(AD1>3600))   
		{
			TIM_SetCompare1(TIM2, 500);
 
			 TIM_SetCompare2(TIM2, 500);
			delay_ms(1000);
			 TIM_SetCompare2(TIM2, 500);
			TIM_SetCompare1(TIM2, 500);

			printf("1");
		}
		else if((AD1<3599) &&(AD1>1500))
		{
       TIM_SetCompare1(TIM2, 500);
 
			 TIM_SetCompare2(TIM2, 500);
			delay_ms(1000);
			 TIM_SetCompare2(TIM2, 1000);
			TIM_SetCompare1(TIM2, 1000);
  
			printf("2");
		}
		else
		{
			TIM_SetCompare1(TIM2, 500);
			 TIM_SetCompare2(TIM2, 500);
			delay_ms(500);
			 TIM_SetCompare2(TIM2, 1000);
			TIM_SetCompare1(TIM2, 1000);
			printf("3");
		}

(4)灯光

		//车灯逻辑判断
		if((AD0<4000) &&(AD0>3001))   
		{
				GPIO_ResetBits(GPIOC, GPIO_Pin_13 | GPIO_Pin_14);
			printf("4");
		}
		else if((AD0<3000) &&(AD0>1500))
		{
				GPIO_SetBits(GPIOC, GPIO_Pin_13);
				GPIO_ResetBits(GPIOC, GPIO_Pin_14);
			printf("5");
		}
		else
		{
			 GPIO_SetBits(GPIOC, GPIO_Pin_13 | GPIO_Pin_14);
			printf("6");
		}
}

最后总结:

在进行舵机转动的时候注意一定将舵机接入5V,血的教训,在舵机电压不够的时候将会出现程序死机的 现象,当时以为 中断 的问题,用串口进行调试 ,最后因为 舵机电压不够导致的。需要程序的可以私信哦

小编码字不容易 留一个赞吧

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

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

相关文章

干货分享:网页录屏的免费方法!

“网页怎么录屏呀&#xff0c;在浏览器看到一篇文章&#xff0c;觉得挺有价值的&#xff0c;想保存下来&#xff0c;但是不能下载&#xff0c;也不可以复制粘贴&#xff0c;朋友说可以录下来保存&#xff0c;想问问大家&#xff0c;有什么好用免费的网页录屏方法推荐吗&#xf…

Python入门指南

概述&#xff1a; Python是一种简单易学、功能强大的编程语言&#xff0c;广泛应用于数据分析、Web开发、人工智能等领域。本文将为初学者提供一个Python入门指南&#xff0c;从安装到基本语法&#xff0c;帮助您开始编写Python程序。 第一部分&#xff1a;安装Python 1、进入…

单链表经典OJ题 :分割链表

题目&#xff1a; 给你一个链表的头节点 head 和一个特定值 x&#xff0c;请你对链表进行分隔&#xff0c;使得所有小于x 的节点都出现在 大于或等于 x 的节点之前。 你不需要保留 每个分区中各节点的初始相对位置。 图例&#xff1a; 本题的意思&#xff1a; 给定一个数值&am…

C# Onnx Yolov8 Detect 红绿灯检测

效果 lable GreenCircular GreenLeft GreenRight GreenStraight RedCircular RedLeft RedRight RedStraight 项目 代码 using Microsoft.ML.OnnxRuntime; using Microsoft.ML.OnnxRuntime.Tensors; using OpenCvSharp; using System; using System.Collections.Generic; usi…

从零开始探索C语言(十二)----预处理器、输入输出及文件读写

文章目录 1. 预处理器1.1 预处理器实例1.2 预定义宏1.3 预处理器运算符1.4 参数化的宏 2. 输入和输出2.1 getchar() & putchar() 函数2.2 gets() & puts() 函数 3. 文件读写3.1 打开文件3.2 关闭文件3.3 写入文件3.4 读取文件3.5 二进制 I/O 函数 4. typedef 和 #defin…

YOLOv8改进实战 | 更换主干网络Backbone之轻量化模型Efficientvit

前言 轻量化网络设计是一种针对移动设备等资源受限环境的深度学习模型设计方法。下面是一些常见的轻量化网络设计方法: 网络剪枝:移除神经网络中冗余的连接和参数,以达到模型压缩和加速的目的。分组卷积:将卷积操作分解为若干个较小的卷积操作,并将它们分别作用于输入的不…

【java】【MyBatisPlus】【一】快速入门程序

目录 1、创建空项目mybatisProject 2、创建springboot模块 3、删除多余文件 4、修改pom&#xff0c;引入mybatisplus 5、设置application.yml 6、准备实体Emp 7、创建EmpMapper接口 8、测试MybatisQuickstartApplicationTests 前言&#xff1a;学习MyBatisPlus的基本使…

想要隐藏Word文件内容,如何做?四个方法!

Word文件中有些内容想要隐藏&#xff0c;该如何隐藏&#xff1f;今天分享几个方法给大家 方法一&#xff1a; 最简单的方法&#xff0c;将字体颜色与背景颜色设置为一致的&#xff0c;这样就达到了隐藏的效果&#xff0c;选中文字再修改颜色就可以恢复字体 方法二&#xff1a…

MaaS,云厂商在打一场“翻身仗”

今年以来&#xff0c;大模型的热度&#xff0c;让云计算产业为之沸腾。要举出一个最有力的证明&#xff0c;应该是&#xff1a;MaaS&#xff08;Model as Service&#xff09;这种全新模式的出现&#xff0c;一座座“模型工厂”&#xff0c;已经建起来了。 所谓MaaS&#xff0c…

怎样才能去除视频中的背景音乐,保留人声?

做视频剪辑&#xff0c;二次创作的朋友&#xff0c;需要去除视频中的背景音乐&#xff0c;保留人声&#xff1b;或者去除人声&#xff0c;保留背景音乐。如果请身边做视频的朋友帮忙&#xff0c;可有时不能沟通到位&#xff0c;完成后的效果并不是很理想&#xff0c;就很尴尬了…

Leetcode—283.移动零【简单】

2023每日刷题&#xff08;三&#xff09; Leetcode—283.移动零 双指针法yyds&#xff01; void moveZeroes(int* nums, int numsSize){// 双指针法int left 0, right 0;while(right < numsSize) {if(nums[right] ! 0) {int tmp nums[right];nums[right] 0;nums[left]…

【C++】auto 范围for nullptr

目录 一&#xff0c;auto 1&#xff0c;类型别名思考 2&#xff0c;auto 简介 3&#xff0c;auto 的使用细则 1&#xff0c;auto 与指针和引用结合起来使用 2&#xff0c;同一行定义多个变量 3&#xff0c;auto 不能推导的场景 二&#xff0c;基于范围的for循环 1&…

音频信号的频谱分析实例

在前面的文章 信号频谱分析与功率谱密度 中&#xff0c;我们初步探讨了信号频谱分析的概念&#xff0c;并介绍了其数学工具。本篇文章将结合实例&#xff0c;进一步探讨频谱分析在音频信号处理中的应用。 音频信号的频谱分析是一种将时域中的音频信号转换为频域表示的过程&…

华为云CodeArts IDE for Java安装使用教程

本篇内容主要介绍使用华为云CodeArts IDE for Java创建工程、代码补全、运行调试代码、Build构建和测试相关的主要功能。 一、下载安装华为云CodeArts IDE for Java 华为云CodeArts IDE for Java安装要求 至少需要 2 GB RAM &#xff0c;但是推荐8 GB RAM; 至少需要 2.5 GB 硬…

C# Onnx Yolov8 Detect 指纹检测

效果 项目 代码 using Microsoft.ML.OnnxRuntime; using Microsoft.ML.OnnxRuntime.Tensors; using OpenCvSharp; using System; using System.Collections.Generic; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms;namespace Onnx…

钢水包升降翻转液压系统比例阀放大器

钢水包升降翻转液压系统是一种用于控制钢水包升降和翻转的液压系统。该系统主要由液压泵、液压缸、控制阀和一些辅助元件组成。 钢水包升降翻转液压系统的液压泵将油从油箱中抽出&#xff0c;将油压力提高到一定值&#xff0c;然后通过控制阀将油分配到液压缸中。液压缸内的活…

https证书

SSL证书的作用是确保通过网站传输的数据在客户端和服务器之间是安全、私密的。 它通过建立安全的通信通道来防止数据泄露、中间人攻击以及篡改等安全威胁&#xff0c;提供了身份认证和数据加密的功能。 这样可以确保用户在网站上提交的敏感信息&#xff0c;如个人数据、公司信…

linux常见命令-时间日期类、搜索查找类、压缩和解压类

一、时间日期类 1.date 指令-显示当前日期 基本语法 1) date (功能描述:显示当前时间) 2) date %Y (功能描述:显示当前年份) 3) date %m (功能描述:显示当前月份) 4) date %d (功能描述:显示当前是哪一天) 5) date "%Y-%m-%d %H:%M:%S" (功能描述:显示年月…

0基础学习VR全景平台篇第111篇:全景图拼接和编辑 - PTGui Pro教程

上课&#xff01;全体起立~ 大家好&#xff0c;欢迎观看蛙色官方系列全景摄影课程&#xff01; 前情回顾&#xff1a;上节&#xff0c;我们将源图像导入了PTGui&#xff0c;也设置好了各项参数。 下面我们就开始拼接全景图&#xff0c;并且在编辑器里进行一系列检查错位和设…