比赛因为疫情凉了,没事干写写文章吧
视频效果:https://www.bilibili.com/video/BV1qU4y157dV
啥也不说先上图片看效果
项目介绍:Android端从摄像头中获取的含有交通标志物图片进行识别。
交通标志物包括:直行、掉头、左转、右转、禁止通行、禁止直行
项目实现步骤:
1、准备图片 每种标志物的图片120张就足够
2、通过EasyDL物体检测去训练图片
3、训练完后EasyDL可以下载一个对应的应用例程
4、将应用例程迁移到自己的程序里面
步骤一
如何获取图片呢?
可以通过摄像头录到的视频来一帧一帧的把图片给提取出来。
python+opencv来实现。
直接上代码:
import cv2
cap=cv2.VideoCapture("turnright (11).avi")#输入视频
isOpened=cap.isOpened
i=0
while(isOpened):
if i==10:
break
else:
i=i+1
(flag,frame)=cap.read()
fileName='turnright'+str(i)+'.jpg'#照片名字
print(fileName)
if flag==True:
cv2.imwrite(fileName,frame,[cv2.IMWRITE_JPEG_CHROMA_QUALITY,100])#输出照片
上面代码自行测试调试理解
步骤二
百度大脑训练图片,网站操作视频来训练图片
https://ai.baidu.com/easydl/vision/
训练完成后
步骤三
下载训练好的SDK
通过官方文档调试
步骤四
阅读API文档移植到自己的程序里面
只需要从例程中移植出TestInferDetectionTask类
/**
* 通用arm 物体检测
*/
public class TestInferDetectionTask{
private static final int NUM_OF_RUNS = 1;
private static final int NUM_OF_API_CALLS = 1;
private static final float CONFIDENCE = 0.5f;
private static final String TAG = "TestInferDetectionTask";
private static final String SERIAL_NUM = "BC57-01EC-32B2-BF02";
public static Rect rect=null;