首页 > 编程语言 >基于基于MATLAB车牌出入库计时计费系统源码GU

基于基于MATLAB车牌出入库计时计费系统源码GU

时间:2024-10-26 23:19:48浏览次数:3  
标签:字符 基于 end GUI GU 源码 white 识别 车牌

  • 课题介绍

随着汽车数量的增加,城市交通状况日益受到人们的重视,如何进行有效的交通管理更是成为了人们关注的焦点。智能交通系统通过车辆检测装置对过往的车辆实施检测,提取有关交通数据,达到监控、管理和指挥交通的目的。因此,它已成为世界交通领域研究的重要课题。 车牌识别系统作为智能交通系统的一个重要组成部分,已在高速公路、城市交通和停车场等项目的管理中占有无可取代的重要地位。它在不影响汽车状态的情况下,由计算机自动完成车牌的识别,从而降低交通管理工作的复杂度。

该课题为基于MATLAB的汽车出入库识别系统,带有丰富的人机交互GUI界面。目前毕业设计选题中,传统车牌识别不易得到高分,必须要在此基础上有所创新方得可以避开其他雷同课题,,不会轻易被导师被否决。因此建议在车牌识别基础上加入出入库,判别是否为库内车牌,并且实行计时收费。整个设计在一个GUI界面上完成。

传统基础版:中规中矩的车牌识别

靓点1版本:可做成 复杂背景的车牌识别

靓点2版本:可做成 具备判断是否为库内车牌的车牌识别,并且计时计费(本课题)

靓点3版本:可做成 具备语音播报的车牌识别

  • 基本流程

①图像预处理:在整个车牌识别系统中,由于采集进来的图像为真彩图,再加上实际采集环境的影响以及采集硬件等原因,图像质量并不高,其背景和噪声会影响字符的正确分割。和识别,所以在进行车牌分割和识别处理之前,需要先对车牌图像进行图像预处理操作。

②车牌定位:首先对车牌的二值图片进行形态学滤波,使车牌区域形成一个连通区域,然后根据车牌的先验知识对所得到的连通区域进行筛选,获取车牌区域的具体位置,完成从图片中提取车牌的任务。

③车牌分割:首先对车牌进行水平投影,去除水平边框;再对车牌进行垂直投影。通过对车牌进行投影分析可知,与最大值峰中心对应的为车牌中第二个字符和第三个字符的间隔,与第二大峰中心距离对应的即为车牌字符的宽度,并以此为依据对车牌进行分割。

④字符识别:本文采用模板匹配方法来对车牌进行识别。识别过程中,首先建立标准字库,再将分割所得到的字符进行归一化,将归一化处理后的字符与标准字库里的字符逐一比较,最后把误差最小的字符作为结果显示出来。

  • GUI设计图(学习好GUI,有助于毕业后从事UI界面设计类工作,如深圳创维,康佳,彩虹电视等需要大量该类岗位,适合女孩子居多,该类工作居于程序员和文员之间

                              GUI界面设计图

GUI制作说明:GUI是MATLAB的人机交互式GUI界面,有GUI界面,所有操作可在一个界面上完成,可以为毕设增分不少。GUI可在MATLAB命令行窗口输入guide回车快速打开,GUI常用的控件有axes,edit,putton,text几个组件,不同组件之间通过回调函数来进行连接,触发操作,可教学GUI制作,以及友情推荐同类岗位工作。

  • 代码附录

1、车牌载入

[filename,filepath]=uigetfile('.jpg','输入车牌图像');% 直接自动读入%

file=strcat(filepath,filename); %strcat函数:连接字符串;把filepath的字符串与filename的连接,即路径/文件名

I=imread(file);

axes(handles.axes1)%让车牌显示在axes1控件中

imshow(I)%显示

title(‘车牌’)

2、图像预处理

I1=rgb2gray(I);  %灰度处理

I2=edge(I1,'roberts',0.15,'both');  %边缘检测

se=[1;1;1];  

I3=imerode(I2,se);  

se=strel('rectangle',[25,25]);  

I4=imclose(I3,se);  %闭运算,去除杂质影响

I5=bwareaopen(I4,2000);  %膨胀操作

3、车牌定位

[y,x,z]=size(I5);  

myI=double(I5);  

tic

 white_y=zeros(y,1);  

 for i=1:y  

    for j=1:x  

             if(myI(i,j,1)==1)   

                white_y(i,1)= white_y(i,1)+1;   

            end    

     end         

 end  

 [temp MaxY]=max(white_y);  

 PY1=MaxY;  

 while ((white_y(PY1,1)>=5)&&(PY1>1))  

        PY1=PY1-1;  

 end      

 PY2=MaxY;  

 while ((white_y(PY2,1)>=5)&&(PY2<y))  

        PY2=PY2+1;  

 end  

 IY=I(PY1:PY2,:,:);  

 white_x=zeros(1,x);  

    

 PX1=1;  %%%31再34

 while ((white_x(1,PX1)<3)&&(PX1<x))  

       PX1=PX1+1;  

 end      

 PX2=x;  

 while ((white_x(1,PX2)<3)&&(PX2>PX1))  

        PX2=PX2-1;  

 end  

 PX1=PX1-2;  

 PX2=PX2+3;  

 dw=I(PY1:PY2-8,PX1:PX2,:);  

 axes(handles.axes2)

 imshow(dw)

 title('定位的车牌')

4、字符分割

% 切割出 7 个字符  

y1=10;y2=0.25;flag=0;word1=[];  

while flag==0  

    [m,n]=size(d);  

    left=1;wide=0;  

    while sum(d(:,wide+1))~=0  

        wide=wide+1;  

    end  

    if wide<y1   % 认为是左侧干扰  

        d(:,[1:wide])=0;  

        d=qiege(d);  

    else  

        temp=qiege(imcrop(d,[1 1 wide m]));  

        [m,n]=size(temp);  

        all=sum(sum(temp));  

        two_thirds=sum(sum(temp([round(m/3):2*round(m/3)],:)));  

        if two_thirds/all>y2  

            flag=1;word1=temp;   % WORD 1  

        end  

        d(:,[1:wide])=0;d=qiege(d);  

    end  

end  

% 分割出第二个字符  

[word2,d]=getword(d);  

% 分割出第三个字符  

[word3,d]=getword(d);  

% 分割出第四个字符  

[word4,d]=getword(d);  

% 分割出第五个字符  

[word5,d]=getword(d);  

% 分割出第六个字符  

[word6,d]=getword(d);  

% 分割出第七个字符  

[word7,d]=getword(d);  

5、字符识别

 liccode=char(['0':'9' 'A':'Z' '京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼']);%SubBw2=zeros(40,20);

l=1;

for I=1:7;

    ii=int2str(I);

    t=imread([ii,'.jpg']);

    SegBw2=imresize(t,[40 20],'nearest');

    SegBw2=double(SegBw2)>20;

    if l==1 %第一位汉字识别

        kmin=37;

        kmax=43;

    elseif l==2 %第二位字母识别

        kmin=11;

        kmax=36;

    else l>=3   %第三位后字母或数字识别

        kmin=1;

        kmax=36;

        

    end

    for k2=kmin:kmax

        fname=strcat('字符模板\',liccode(k2),'.jpg');

        SamBw2=imread(fname);

        SamBw2=double(SamBw2)>1;

        for i=1:40

            for j=1:20

                SubBw2(i,j)=SegBw2(i,j)-SamBw2(i,j);

            end

        end

        %相当于两幅图相减得第三幅图

        Dmax=0;

        for k1=1:40;

            for l1=1:20

                if(SubBw2(k1,l1)>0 || SubBw2(k1,l1)<0)

                    Dmax=Dmax+1;

                end

            end

        end

        Error(k2)=Dmax;

    end

    Error1=Error(kmin:kmax);

    MinError=min(Error1);

    findc=find(Error1==MinError);

    Code(l*2-1)=liccode(findc+kmin-1);

    Code(l*2)=' ';

    l=l+1;

end

t=toc;

set(handles.text4,'string',Code)

  • 运行效果图

                                部分运行效果图

标签:字符,基于,end,GUI,GU,源码,white,识别,车牌
From: https://blog.csdn.net/2401_84457171/article/details/143130937

相关文章

  • 基于CT与MRI图像融合matlab程序及结果
    请注意该程序处理的图像必须是灰度图像,不能是彩图。Matlab程序:clear%装载原始图像001.mat;002.mat并显示。[X,map]=imread('003.Tif');X1=X;map1=map;figure(2);X1=imread('003.Tif');subplot(2,2,1);imshow(X1);title('图像001');X2=imread('004.Tif');subpl......
  • JAVA毕设2533基于web的电影购票系统的设计与实现
    项目包含:源码,文档,讲解视频运行环境:推荐jdk1.8开发工具:Eclipse、MyEclipe以及idea(推荐)操作系统:windows108G内存以上(其他windows)浏览器:GoogleChrome(推荐)、Edge、360浏览器;数据库:MySQL5.7;数据库可视化工具:NavicatPremium推荐)以及其他Navicat版本tomcat:6.0或以上......
  • 大数据毕业设计:基于python招聘数据分析可视化系统 爬虫 可视化大屏 Django框架 (源码)✅
    博主介绍:✌全网粉丝10W+,前互联网大厂软件研发、集结硕博英豪成立工作室。专注于计算机相关专业毕业设计项目实战6年之久,选择我们就是选择放心、选择安心毕业✌感兴趣的可以先收藏起来,点赞、关注不迷路✌1、毕业设计:2025年计算机专业毕业设计选题汇总(建议收藏)✅......
  • SpringBoot自动配置原理:底层源码分析
    大家好,我是此林。今天和大家分享面试常被问到的SpringBoot自动配置原理。SpringBoot之所以因为其“开箱即用”的特性备受开发者欢迎,其中一个重要的原因就是自动配置。今天我们就来扒一扒,SpringBoot的自动配置到底是如何运作的,底层如何帮助我们省去繁琐的配置。在SpringBo......
  • 基于SpringBoot+Vue+uniapp的学生知识成果展示与交流的详细设计和实现(源码+lw+部署文
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......
  • redis第152节答疑 redis源码分析String重要总结
    redis的string类型,如果数字大于10000,就不去共享整数中去取,然后就变成了embstr或者raw,为什么不是new一个redisobject,并且编码为int对于Redis的字符串类型(String),当字符串表示的是一个整数值时,Redis会根据具体情况选择不同的编码方式。对于数字大于10000的情况,Redis不会将其编......
  • jsp ssm 校园新闻管理系统 新闻发布系统 news 项目源码 web java
    一、项目简介本项目是一套基于SSM的校园新闻管理系统,主要针对计算机相关专业的和需要项目实战练习的Java学习者。包含:项目源码、数据库脚本、软件工具等。项目都经过严格调试,确保可以运行!二、技术实现​后端技术:Spring、SpringMVC、MyBatis前端技术:JSP、HTML、CSS、Ja......
  • jsp ssm 智能图书馆图书推荐系统 图书管理 项目源码 web java
    一、项目简介本项目是一套基于SSM的智能图书馆图书推荐系统,主要针对计算机相关专业的和需要项目实战练习的Java学习者。包含:项目源码、数据库脚本、软件工具等。项目都经过严格调试,确保可以运行!二、技术实现​后端技术:Spring、SpringMVC、MyBatis前端技术:JSP、HTML、C......
  • 基于Springboot无人驾驶车辆路径规划系统(源码+定制+开发)
    博主介绍:  ✌我是阿龙,一名专注于Java技术领域的程序员,全网拥有10W+粉丝。作为CSDN特邀作者、博客专家、新星计划导师,我在计算机毕业设计开发方面积累了丰富的经验。同时,我也是掘金、华为云、阿里云、InfoQ等平台的优质作者。通过长期分享和实战指导,我致力于帮助更多学生......
  • 基于令牌桶算法实现一个限流器
    序言:本文章基于令牌桶算法实现了简单的一个限流器1令牌桶算法实现原理令牌生成:在固定的时间间隔内,算法会向一个桶中放入一定数量的令牌。令牌的生成速率是固定的,通常以每秒钟生成的令牌数来表示。桶的容量:桶有一个最大容量,如果桶满了,新的令牌将被丢弃。这意味着即使在......