当前位置:   article > 正文

基于GRNN广义回归神经网络的车牌字符分割和识别matlab仿真_广义回归神经网络的应用

广义回归神经网络的应用

目录

一、理论基础

二、核心MATLAB程序

三、MATLAB仿真测试结果


一、理论基础

1.1理论概述

       广义回归神经网络(General Regression Neural Network,GRNN)是一种基于神经网络的非线性回归预测模型,广泛应用于模式识别、预测分析等领域。在车牌字符分割和识别中,GRNN 可以用于实现车牌字符的分类和位置预测。

      GRNN 是一种基于神经网络的分析工具,适用于解决回归和模式识别问题。GRNN 具有较好的非线性映射能力,可广泛应用于复杂系统的预测和控制。GRNN 的核心思想是利用径向基函数(Radial Basis Function,RBF)作为激活函数,将输入数据映射到高维特征空间,再通过线性回归方法进行预测。GRNN 结构由输入层、隐藏层和输出层组成。其中,输入层负责接收输入数据,隐藏层通过 RBF 函数将输入数据映射到高维特征空间,输出层为线性回归模型,对隐藏层输出进行加权求和,得到最终预测结果。

车牌字符分割和识别是车辆识别的重要组成部分,主要包括以下步骤:

  1. 车牌定位:首先需要确定车牌在图像中的位置。常用的方法有基于图像处理和机器学习方法。基于图像处理的方法可以通过对图像进行二值化、形态学处理等操作,检测出车牌区域。基于机器学习的方法可以利用支持向量机(SVM)、神经网络等算法,对车牌区域进行分类和定位。
  2. 字符分割:在车牌定位完成后,需要对车牌上的字符进行分割。字符分割可以采用基于图像处理的方法或机器学习方法。基于图像处理的方法可以通过对字符进行连通域分析、形态学处理等操作,实现字符分割。基于机器学习方法可以利用聚类算法、神经网络等算法,对字符进行分类和分割。
  3. 字符识别:字符分割完成后,需要对每个字符进行识别。字符识别通常采用基于深度学习的方法,如卷积神经网络(CNN)、循环神经网络(RNN)等。这些方法可以利用大量的标注数据进行训练,提高字符识别准确率。

1.2基于GRNN广义回归神经网络的车牌字符分割和识别

      GRNN通常被用来进行函数逼近。它具有一个径向基隐含层和一个特殊的线性层。第一层和第二层的神经元数目都与输入的样本向量对的数目相等。GRNN结构如图1所示,整个网络包括四层神经元:输入层、模式层、求和层与输出层。

       输入层的神经元数目与学习样本中输入向量的维数m相等,每个神经元都是一个简单的分布单元,这些神经元直接将输入变量传递到隐含层中。模式层的神经元数目即为学习样本的数目n,每个神经元都分别对应一个不同的学习样本,模式层中第i个神经元的传递函数为:

       由此可以看出,当选择出学习样本之后,GRNN网络的结构与权值都是完全确定的,因而训练GRNN网络要比训练BP网络和RBF网络便捷得多。 

二、核心MATLAB程序

  1. clc;
  2. clear;
  3. close all;
  4. warning off;
  5. addpath 'func\'
  6. %神经网络训练
  7. net = func_grnn_train();
  8. for ii = 1:22
  9. word1=imresize(tmps{1},[40 20]);
  10. word2=imresize(tmps{2},[40 20]);
  11. word3=imresize(tmps{3},[40 20]);
  12. word4=imresize(tmps{4},[40 20]);
  13. word5=imresize(tmps{5},[40 20]);
  14. word6=imresize(tmps{6},[40 20]);
  15. word7=imresize(tmps{7},[40 20]);
  16. %第1
  17. words = word1;
  18. wordss = func_yuchuli(words);
  19. wordsss = sim(net,wordss');
  20. [V,I] = max(wordsss);
  21. d = I;
  22. y{1} = func_check(d);
  23. %第2个
  24. words = word2;
  25. wordss = func_yuchuli(words);
  26. wordsss = sim(net,wordss');
  27. [V,I] = max(wordsss);
  28. d = I;
  29. y{2} = func_check(d);
  30. %第3
  31. words = word3;
  32. wordss = func_yuchuli(words);
  33. wordsss = sim(net,wordss');
  34. [V,I] = max(wordsss);
  35. d = I;
  36. y{3} = func_check(d);
  37. %第4个
  38. words = word4;
  39. wordss = func_yuchuli(words);
  40. wordsss = sim(net,wordss');
  41. [V,I] = max(wordsss);
  42. d = I;
  43. y{4} = func_check(d);
  44. %第5
  45. words = word5;
  46. wordss = func_yuchuli(words);
  47. wordsss = sim(net,wordss');
  48. [V,I] = max(wordsss);
  49. d = I;
  50. y{5} = func_check(d);
  51. %第6个
  52. words = word6;
  53. wordss = func_yuchuli(words);
  54. wordsss = sim(net,wordss');
  55. [V,I] = max(wordsss);
  56. d = I;
  57. y{6} = func_check(d);
  58. %第7
  59. words = word7;
  60. wordss = func_yuchuli(words);
  61. wordsss = sim(net,wordss');
  62. [V,I] = max(wordsss);
  63. d = I;
  64. y{7} = func_check(d);
  65. figure(1);
  66. subplot(241);imshow(word1);title(num2str(y{1}));
  67. subplot(242);imshow(word2);title(num2str(y{2}));
  68. subplot(243);imshow(word3);title(num2str(y{3}));
  69. subplot(244);imshow(word4);title(num2str(y{4}));
  70. subplot(245);imshow(word5);title(num2str(y{5}));
  71. subplot(246);imshow(word6);title(num2str(y{6}));
  72. subplot(247);imshow(word7);title(num2str(y{7}));
  73. pause(2);
  74. end
  1. NAME = ['车牌图片test\',num2str(ii),'.jpg'];
  2. I =imread(NAME);
  3. figure(1);
  4. subplot(121);
  5. imshow(I);
  6. title('原图');
  7. I1=rgb2gray(I);
  8. subplot(122);
  9. imshow(I1);
  10. title('灰度图');
  11. %小波变换车牌定位
  12. Ip = func_position(I,I1,1.2,80);
  13. figure(2);
  14. subplot(131);
  15. imshow(Ip);
  16. title('车牌区域');
  17. %通过心态学处理,提取车牌区域
  18. Ip = double(bwareaopen(Ip,100));
  19. %膨胀
  20. se = strel('ball',100,50);
  21. Ip2 = imdilate(Ip,se);
  22. %确定灰度阈值
  23. level = graythresh(uint8(Ip2));
  24. Ip3 = Ip2;
  25. %二值化
  26. [R,C] = size(Ip2);
  27. for i = 1:R
  28. for j = 1:C
  29. if Ip2(i,j)>255*level
  30. Ip3(i,j) = 1;
  31. else
  32. Ip3(i,j) = 0;
  33. end
  34. end
  35. end
  36. subplot(132);
  37. imshow(Ip3);
  38. title('去掉干扰');
  39. Ipos = func_Pai_Position(I,Ip3);
  40. subplot(133);
  41. imshow(Ipos);
  42. title('车牌提取');
  43. pause(0.05);

三、MATLAB仿真测试结果

A10-50

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/303310
推荐阅读
相关标签
  

闽ICP备14008679号