您的位置:首页 > 健康 > 美食 > 邯郸网站建设推广_中国临朐门户网站_济南网络优化哪家专业_seo网络优化日常工作内容

邯郸网站建设推广_中国临朐门户网站_济南网络优化哪家专业_seo网络优化日常工作内容

2025/1/10 3:46:07 来源:https://blog.csdn.net/Black__goat/article/details/142889166  浏览:    关键词:邯郸网站建设推广_中国临朐门户网站_济南网络优化哪家专业_seo网络优化日常工作内容
邯郸网站建设推广_中国临朐门户网站_济南网络优化哪家专业_seo网络优化日常工作内容

1.摄像头获取到一帧的图片:
2.将在图片中把赛道识别出来:
利用大津法将图片进行二值化,把大致赛道从图中区分出来:
3.对进行二值化之后的图像进行处理,将非赛道部分都进行补画,最后要得到一个明显的赛道图:
4.根据最终处理好的图片,画出中心线,根据中心线的额轨迹控制舵机的转向:

错误:

1.user/cpu0_main.d:3: *** target pattern contains no ‘%’. Stop.

原因:未知
解决方法:
clean 一下工程
在这里插入图片描述

注意:

1.接线要在断开电源时进行。

1.大津法:找二值化阈值

下图来自【10.8 大津法(OTSU)(数字图像处理,冈萨雷斯版)】https://www.bilibili.com/video/BV1cM8we3EVf?vd_source=3d11b8f0c7b49bfbf7ba333c4bc6f224

下图的示例中和我们智能车要处理的是有一点点的不一样,下图在视频中是想直接分成一明一暗两个部分,是竖着切的,我们处理智能车赛道的时候是横着切的,但是也可以说是一样的,因为在灰度值的存储中已经将他分化成下图那样,因为在进行大津法处理之前,我们是将灰度直方图已经用一个数组表现出来了,如果展现出来的结果其实就可以等效为下图,我们以下图为例子:

1.我们是希望找一个阈值,下图直接分成左边暗的为一类,右边亮的为一类,大津法表示的是,在这个阈值的划分下就会出现我下面用红线的划分,然后这时可以分别计算出的是左右边暗部分的方差,灰度平均值,还有总体图片的灰度平均值(注意这几个值都必须在已知一个确定的阈值才能计算)而这些值能够体现它们两部分分的区别很大的量化指标就是,组内方差要小,而一个组的灰度平均值和总的灰度平均值相差要大。大津是个人,它发现的就是,这两件事是相关的,就是说你的组内方差越小,你的组的灰度平均值到总体平均值的差就越大。
在这里插入图片描述
2.
一式:
计算总体的灰度平均值需要带上两个部分的占比作为一个权值,直接用两部分的均值相加肯定不行,有可能黑的多,有可能白的多,所以需要进行一个加权。
二式:
计算的是组内方差,由两部分的方差加权和构成,由于两部分的方差都希望越小越好,所以组内方差也希望越小越好。说明它们一个组的灰度值都差不多。
三式:
这个式子定义的是组间方差,分别由两部分的灰度均值与总体灰度均值的差值平方的加权和构成,我认为平方只是希望区分更细腻,例如不平方可能组间方差的值就是0~100,进行平方后可能就达到了0 ~1000,对于描述一个阈值能否很好的划分一个灰度图能够有更细腻的描述,因为我们希望一个组的灰度平均值到总体的灰度平均值的差值越大越好,所以得出得组间方差我们也希望越大越好。
四式:
大津证明得事情就是,组间方差与组内方差得和是一个常数,也就代表,你想要最大化你的组间方差与最小化组内方差是等值得。
在这里插入图片描述
在下面这个图中,你可以采用最笨得方法,灰度值的取值为0~255,你想要知道哪个阈值能够很好的实现上面两个目标,那么你可以从0开始代入去计算左右边暗部分的方差,灰度平均值,还有总体图片的灰度平均值,然后计算出来的值再带入上面的式子,将阈值从0 ~255依次尝试,然后找出使得组间方差最大或者组内方差最小的那一个(上面的说过这两件事是等价的,所以大津法的好处就是,这两个值你只需要管一个,而不需要既找最小组内方差,又找最大组间方差)
在这里插入图片描述
在这里插入图片描述

代码(只需要提供图像数组地址和大小即可返回阈值):

//大津法求二值化阈值
//程序,可直接返回一个阈值,同时也将Use_image_information.threshold赋值了
uint8 OTSU_Get_Threshold(uint8* use_image,uint8 row,uint8 col)
{//获取灰度直方图//局部变量uint16 i,j;                         //for循环用uint8 pixel = 0;                   //像素点的灰度值uint16 pixel_sum = row * col;      //像素点个数总和uint16 pixel_graysum = 0;          //图片中灰度值总和uint16 pixel_count[Gray_scale];    //各灰度值个数统计float pixel_pro[Gray_scale];       //各灰度值所占比例//数组初始化for(i = 0;i < Gray_scale;i++) //250次{pixel_count[i] = 0;pixel_pro[i] = 0;}//得到灰度值总和与各灰度值的个数for(i = 0;i < row;i++){for(j = 0;j < col;j++){pixel = (int)use_image[i* row + j];pixel_count[pixel]++;                      //各个灰度值的个数pixel_graysum += (int)use_image[i* row + j];    //灰度值总和}}
//调试语句
/*for(i = 0;i < Gray_scale;i++) //250次
{
tft180_show_int(0,0,pixel_count[i],10);
}
*///计算每个出现的灰度值的个数所占比例for(i = 0;i < Gray_scale;i++){pixel_pro[i] = (float)pixel_count[i] / pixel_sum;}
/*
for(i = 0;i < Gray_scale;i++)
tft180_show_float(0,0,pixel_pro[i],3,4);
*///让测试阈值k从ostu_threshold_s到ostu_threshold_e遍历,最大化组间方差//公式σB^2 = (P1*mg - P1*m1)^2 / P1*(1-P1) = P1*P2*(m1-m2)^2//P1m1*P2m2 = mg//M1是第一组灰度值的的总和//计算P1uint8 k;                       //测试阈值uint8 best_threshold = 0;      //使组内方差最大的阈值uint16 m1 = 0;                 //第一组的灰度值总数uint16 m2 = 0;                 //第二组的灰度值总数uint16 mg = 0;                 //全组的灰度值总数float Bg_variance = 0;         //组内方差(要最大化)float P1 = 0;                  //第一组占全图的比例float P2 = 0;                  //第二组占全图的比例float P1_pre = 0;              //第一组占全图的比例(后续优化大津法)float P2_pre = 0;              //第二组占全图的比例for(k = Use_image_information.otsu_threshold_s;k < Use_image_information.otsu_threshold_e;k++){//得到P1、P2、m1、m2for(i = 0,j = k+1;i < k;i++,j++)           //第一组从0到k,第二组从k+1开始{P1 += pixel_pro[i];P2 += pixel_pro[j];m1 += (i*pixel_count[i]);m2 += (j*pixel_count[j]);}
/*调试语句
tft180_show_int(1,1,m1,4);*///计算mgmg = (int)(P1*m1 + P2*m2);//计算σb^2if((P1*P2*pow((m1-m2),2))> Bg_variance){best_threshold = k;}//重置P1 = 0;P2 = 0;m1 = 0;m2 = 0;mg = 0;}
/*调试语句
tft180_show_int(0,0,best_threshold,4);
获取到使得组间方差最大的阈值
*/return best_threshold;
}

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com