پلاک‌خوان خودرو

تغییرات پروژه از تاریخ 1392/12/24 تا تاریخ 1393/02/06
<img src="http://upload7.ir/imgs/2014-03/70398319034692122089.jpg" style="width:600px;-webkit-border-radius:20px;-moz-border-radius: 20px;border-radius: 20px;	box-shadow: 0px 0px 7px 1px #202020;-webkit-box-shadow: 0px 0px 7px 1px #202020;-moz-box-shadow: 0px 0px 7px 1px #202020;">

<h1 style="color:#851401">مقدمه</h1>
<p>
سیستم پلاک خوان یکی از مهترین سیستم ها در کنترل ترافیک است که با استفاده از میتوان رانندگان متخلف و نوع خلاف را ثبت کرد.
عملکرد این سیستم به گونه ای است که با استفاده از دوربین های مخصوصی که در سطح شهر و اتوبان ها قرار داده شده اند و برنامه تشخیص تخلف از لحظاتی که در آنها تخلفی صورت گرفته عکس برداری شده و سیستم تشخیص محل پلاک خودرو محل پلاک را بدست آورده و در اختیار سیستم پلاک خوان که موضوع این پروژه میباشد قرار میدهد و این سیستم اعداد و حروف پلاک را استخراج کرده و برای فرد متخلف جریمه ثبت شود.هدف اصلی این پروژه مکانیزه کردن که علاوه بر کاهش نیروی انسانی و کاهش هزینه ها افزایش دقت و سرعت در تصمیم گیری و انجام کارها است.
<br/>
علاوه بر هدف اصلی که ذکر شد از این سیستم میتوان در سیستم های دیگر مانند پارکینگ های عمومی و یا خصوصی استفاده کرد.در پارکینگ های عمومی میتوان با تشخیص شماره پلاک ساعت ورود را در سیستم ذخیره کرده و در هنگام خروج مدت زمان حضور در پارکینگ معلوم گردد و دیگر نیازی به ثبت توسط نیروی انسانی نیست.همچنین میتوان با ذخیره کردن پلاک ماشین ها برای مدت خاصی یک پایگاه داده ایجاد کرد و در مسایل امنیتی از آن استفاده نمود.در پارکینگ های خصوصی نیز میتوان از این جهت در این سیستم استفاده کرد که پلاک خودرو های افراد ساختمان در سیستم ذخیره شود و هنگامی که خودرویی با یکی از پلاک های ذخیره شده در مقابل دوربین قرار گرفت درب پارکینگ باز شده و دیگر نیازی به استفاده از دستگاه کنترل از راه نباشد.
</p>
<h1 style="color:#851401">کارهای مرتبط</h1>
<p>
الگوریتم مورد استفاده در این پروژه از دو قسمت تشکیل شده است.
</p>
<ul>
<li>تفکیک اعداد و حروف</li>
<li>تشخیص اعداد و حروف</li>
</ul>
<p>
جهت تفکیک اعداد از تصویر که به صورت باینری تبدیل شده برای تشخیص هر عدد ابتدا از پایین سمت چپ شروع کرده و به سمت راست حرکت میکنیم.هرگاه به مقداری برابر با مقدا شروع رسیدیم پهنای باند طی شده را محاسبه میکنیم.اگر از مقدار از پیش تعیین شده بیشتر باشد مقدار اولیه جهت شروع عملیات را افزایش  داده و عملیات را تکرار میکنیم.حال حال اگر از مقدار اولیه کمتر یا مساوی بود این دو نقطه مرز ابتدایی و انتهایی عدد اول از سمت چپ را مشخص میکند.سپس همین روش را برای بقیه تصویر انجام میدهیم تا در نهایت هشت عدد بدست بیاوریم.
اگر تمام مراحل انجام شده ولی کمتر از هشت عدد بدست آمد آنگاه پهنای باند را کمتر در نظر میگیریم و مراحل قبل را دوباره تکرار میکنیم.
از نقاط ضعف این الگوریتم میتوان به این اشاره کرد که در بعضی موارد یه عدد نصف شده و یا دو عدد به عنوان یک عدد نمایش داده میشوند.

در تشخیص اعداد که ورودی آن اعداد جدا شده از قسمت قبل است,توسط الگوریتمی ورودی ها به شبکه عصبی داده شده و آنگاه شبکه عصبی تصویر داده شده را با تصاویر داخل پایگاه داده خود که هنگام آموزش آنها را دریافت و دسته بندی کرده است تطبیق داده و پس از الگوریتم های درونیابی,تقریب و تصمیم,بیشترین احتمال اینکه به کدام عدد نزدیک تر است را به عنوان خروجی قرار خواهد داد.
برای آنکه از اشتباهات احتمالی جلوگیری شود,در قسمت آموزش میبایست از بانک اطلاعاتی کاملی استفاده کرد.
از عوامل ایجاد خطا در این سیستم میتوان به این اشاره کرد که در بعضی موارد عکس ها تار هستند و یا در پلاک نویز وجود دارد که احتمال تشخیص صحیح را کاهش میدهند.
</p>
<h1 style="color:#851401">کارهای آینده</h1مرتبط</h1>
همانطور که در مقدمه ذکر شد،مرحله اول خواندن پلاک خودرو تفکیک حروف و اعداد پلاک میباشد.برای تفکیک ابتدا لازم است که پلاک در شرایط مناسبی قرار گیرد.برای مثال ممکن است به دلایل مختلفی مانند اتصال نامناسب روی خودرو،پلاک نسبت به افق دارای زاویه باشد و در نتیجه حروف و اعداد دارای زاویه باشند و تشخیص آنها مشکل باشد و از احتمال درست تشخیص دادن کاسته شود.از مشکلات دیگر میتوان به وجود نویز در پلاک اشاره کرد که در تشخیص حروف اخلال ایجاد میکند.
برای برطرف کردن این مشکلات از الگوریتم های GaussianBlur و threshold  استفاده میکنیم.
با استفاده از الگوریتم اول نویز های احتمالی پلاک تا کاهش داده و با استفاده از الگوریتم threshold عکس را به صورت باینری تبدیل میکنیم.باینری کردن تصاویر انواع مختلفی دارد که عبارتند از :
</p>
<ul>
<li>Threshold Binary</li>
<li>Inverted Threshold Binary</li>
<li>Truncate</li>
<li>Threshold to Zero</li>
<li>Inverted Threshold to Zero</li>
<li>OTSU Threshold</li>
</ul>
<p>
به دلیل اینکه تصاویر به صورت خودکار گرفته شده و خودرو ها در حال حرکت هستند،در بسیاری از موارد تصاویر شرایط مناسبی جمله نور مناسب را نخواهند داشت.به همین دلیل در این پروژه از نوع otsu_thresholding استفاده شده است،زیرا این الگوریتم تصویر را به صورت محلی به صورت باینری تبدیل میکند و از مشکلاتی مانند سیاه شدن کامل قسمتی از تصویر به دلیل نا مناسب بودن نور جلوگیری میکند.
</p>
<table>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;">
  	<img src="http://upload7.ir/imgs/2014-04/59627280347074792218.jpg">
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;">
  	<img src="http://upload7.ir/imgs/2014-04/63707635858853074375.jpg">
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;">
  	<img src="http://upload7.ir/imgs/2014-04/43479760235668739591.jpg">
  </td>

</tr>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;">
  	<p >تصویر اولیه همراه با نویز</p>
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;">
  	<p >تصویر نتیجه با الگوریتم Blur</p>
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;">
  	<p >تصویر نتیجه با الگوریتم Otsu Threshold</p>
  </td>

</tr>
</table>
<p>
با توجه به نتیجه تصویری که با استفاده از الگوریتم otsu threshold بدست آمده است،مشاهده میشود که نویز ها و علامت های اضافی که در پلاک بیشتر کشور ها وجود دارد،کمتر شده و یا از بین رفته اند.
برای تفکیک حروف و اعداد از یکدیگر راه های مختلفی وجود.در روند این پروژه از سه الگوریتم مختلف استفاده شده است:

</p>
<p style="font-size:1.5em;">
	۱.با استفاده از کتابخانه pytesser
</p>
<p>
این کتابخانه که با استفاده با استفاده از opencv و OCR نوشته شده است و قابل استفاده میباشد،با استفاده از نمونه های بسیار آموزش دیده و قادر به تشخیص متون در تصاویر در زبان های تعریف شده با دقت بالایی میباشد.
</p>
<table>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<img src="http://upload7.ir/imgs/2014-04/43479760235668739591.jpg">
  </td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  <td>
  	<img src="http://upload7.ir/imgs/2014-04/55815389679709882209.png">
  </td>
</tr>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >تصویر ورودی</p>
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >نتیجه با استفاده از pytesser</p>
  </td>
</tr>
</table>
<p style="font-size:1.5em;">
	۲.با استفاده از کتابخانه CvBlob
</p>
این کتابخانه که توسط مایکروسافت در سال ۲۰۰۵ پیاده سازی شده و هماهنگ با opencv میباشد،در تصویر داده شده،تمامی لکه ها را پیدا کرده و آنها را با خط کشیدن نمایش میدهد.از مشکلات آن میتوان به این اشاره کرد که نویز های کوچک را نیز به عنوان لکه تشخیص داده و برای تشخیص حروف و اعداد میبایست تمامی آنها را امتحان نمود و پردازش این قسمت کمی بیشتر میشود.
</p>
<table>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<img src="http://upload7.ir/imgs/2014-04/16650822126892224321.jpg">
  </td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  <td>
  	<img src="http://upload7.ir/imgs/2014-04/08455688736151502583.png">
  </td>


</tr>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >تصویر ورودی</p>
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >نتیجه با استفاده از cvblob</p>
  </td>


</tr>
</table>
<p style="font-size:1.5em;">
	۳.تفکیک با استفاده از تراکم
</p>
<p>
الگوریتم مورد استفاده در این قسمت به این صورت است که از سمت چپ تصویر شروع کرده و به سمت راست حرکت میکنیم.برای تشخیص هر حرف یا عدد به این صورت عمل میکنیم که هنگامی که رنگی مخالف با رنگ پس زمینه نمایان شد،آن مکان را نقطه شروع حرف در نظر گرفته و هنگامی که تراکم رنگ مخالف به صفر رسید،به عنوان نقطه پایان آن حرف علامت گذاری میکنیم.با توجه به تعداد حرف و عدد خاص در هر کشور،با توجه به پلاک مورد نظر این الگوریتم را تکرار میکنیم تا تمامی حروف جدا شوند و از جدا شدن تکه های اضافی جلوگیری شود.
</p>
<table>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<img src="http://upload7.ir/imgs/2014-04/62919965824757397849.jpg">
  </td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  <td>
  	<img src="http://upload7.ir/imgs/2014-04/59623978944580084961.jpg">
  </td>
</tr>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >تصویر ورودی</p>
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >حروف و اعداد به صورت تفکیک شده</p>
  </td>
</tr>
</table>
<p>
<p style="font-size:1.5em;">
	۴.استفاده از خوطوط تصویر
</p>
<p>
در این روش تمامی خطوط داخل تصویر را در نظر گرفته،سپس مستطیل هایی که محاط بر این خطوط هستن جمع آوری میکنیم.برای کاهش مستطیل های اضافی که در اطراف نویز ها قرار دارند،شرطی مانند حداقل طول و عرض قابل قبول قرار داده و تعدادی از آنها را حذف میکنیم.
</p>
<table>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<img src="http://upload7.ir/imgs/2014-04/24641043728173622943.jpg">
  </td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  <td>
  	<img src="http://upload7.ir/imgs/2014-04/69699805714045477454.jpg">
  </td>


</tr>
<tr>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >تصویر ورودی</p>
  </td>
  <td align="center" valign="middle" style="text-align:center;vertical-align:middle;width:50%;">
  	<p >پیدا کردن محل حروف و اعداد</p>
  </td>
</tr>
</table>
اگرچه این در این الگوریتم ها سعی شده تشخیص به بهترین صورت انجام شود،اما ممکن هست به دلیل کیفیت کم عکس ها و یا وجود نویز هایی که قادر به حذف آنها نبودیم،یک حرف به دو حرف تشخیص داده شود(مانند 11 به جای 0 ) و یا l  بجای I تشخیص داده شود.با استفاده از قوانین پلاک گذاری(مانند عدم استفاده از حروف کوچک به دلیل تشابه بعضی از حروف و عدم استفاده از عدد صفر به دلیل تشابه با پرچ پلاک)،میتوان از این نوع مشکلات جلوگیری کرد و تشخیص دقیق تری داشته باشیم.
</p>
<h1 style="color:#851401"> مراجع </h1>
<ul>
<li>Pishchulin, L. (2010). Matching Algorithms for Image Recognition.</li>
<li>Of, F., & Technology, I. (2007). BRNO UNIVERSITY OF TECHNOLOGY PRINCIPLES OF AUTOMATIC NUMBER PLATE.</li>
</ul>
</p>

<h1 style="color:#851401"> پیوندهای مفید </h1>
+ [کتابخانه اپن‌سی‌وی](http://opencv.org)
+ [اپن‌سی‌وی در پایتون](http://docs.opencv.org/trunk/doc/py_tutorials/py_tutorials.html)
+ [نصب اپن‌سی‌وی در ابونتو](https://help.ubuntu.com/community/OpenCV)
+ [نمونه محصول](http://farsiocr.ir/%D8%B3%DB%8C%D8%B3%D8%AA%D9%85-%D8%AA%D8%B4%D8%AE%DB%8C%D8%B5-%D9%BE%D9%84%D8%A7%DA%A9-%D8%AE%D9%88%D8%AF%D8%B1%D9%88-%D8%A8%D8%A7-%D8%B3%D9%88%D8%B1%D8%B3-%DA%A9%D8%AF-cpp/)