车牌识别Python程序

更新时间:2023-05-14 01:55:12 阅读: 评论:0

# -*- coding: utf-8 -*-
__author__ = 'd1bysj'
import pymysql
db = t(host = '',  # 远程主机的ip地址,
大相                    ur = '',  # MySQL用户名
                    db = '',  # databa
                    passwd = '',  # 数据库密码
                    port = 3306,  #数据库监听端口,默认3306
                    chart = "utf8")  #指定utf8编码的连接
cur= db.cursor()
sql="lect * from x"
try:
clo是什么意思    ute(sql)
    re=cur.fetchall()
    for it in re:
        name = it[0]
        num  = it[1]
        print(name,num)
except Exception as e:
    rai  e
finally:
    db.clo()
import cv2
import numpy as np
from numpy.linalg import norm
import sys
神经紧张import os
import json
SZ = 20  # 训练图片长宽
MAX_WIDTH = 1000  # 原始图片最大宽度
Min_Area = 2000  # 车牌区域允许最大面积
PROVINCE_START = 1000
# 读取图片文件
def imreadex(filename):
    return cv2.imdecode(np.fromfile(filename, dtype=np.uint8), cv2.IMREAD_COLOR)
def point_limit(point):
    if point[0] < 0:
        point[0] = 0
    if point[1] < 0:
        point[1] = 0
# 根据设定的阈值和图片直方图,找出波峰,用于分隔字符
def find_waves(threshold, histogram):
    up_point = -1  # 上升点
    is_peak = Fal
    if histogram[0] > threshold:
        up_point = 0
        is_peak = True
    wave_peaks = []
    for i, x in enumerate(histogram):
        if is_peak and x < threshold:
            if i - up_point > 2:
                is_peak = Fal
                wave_peaks.append((up_point, i))
        elif not is_peak and x >= threshold:
            is_peak = True
            up_point = i
    if is_peak and up_point != -1 and i - up_point > 4:
        wave_peaks.append((up_point, i))
    return wave_peaks
# 根据找出的波峰,分隔图片,从而得到逐个字符图片
def perate_card(img, waves):
    part_cards = []
    for wave in waves:
        part_cards.append(img[:, wave[0]:wave[1]])
    return part_cards
# 来自opencvsample,用于svm如何打开任务管理器训练
def deskew(img):
休假式治疗    m = s(img)
    if abs(m['mu02']) < 1e-2:
        py()
    skew = m['mu11'] / m['mu02']
    M = np.float32([[1, skew, -0.5 * SZ * skew], [0, 1, 0]])
    img = cv2.warpAffine(img, M, (SZ, SZ), flags=cv2.WARP_INVERSE_MAP | cv2.INTER_LINEAR)
    return img
# 来自opencvsample,用于svm训练
def preprocess_hog(digits):
    samples = []
    for img in digits:
        gx = cv2.Sobel(img, cv2.CV_32F, 1, 0)
        gy = cv2.Sobel(img, cv2.CV_32F, 0, 1)
        mag, ang = cv2.cartToPolar(gx, gy)
        bin_n = 16
        bin = np.int32(bin_n * ang / (2 * np.pi))
        bin_cells = bin[:10, :10], bin[10:, :10], bin[:10, 10:], bin[10:, 10:]
        mag_cells = mag[:10, :10], mag[10:, :10], mag[:10, 10:], mag[10:, 10:]
        hists = [np.bincount(b.ravel(), m.ravel(), bin_n) for b, m in zip(bin_cells, mag_cells)]
        hist = np.hstack(hists)
        # transform to Hellinger kernel
        eps = 1e-7
        hist /= hist.sum() + eps
        hist = np.sqrt(hist)
        hist /= norm(hist) + eps
        samples.append(hist)
    return np.float32(samples)
# 不能保证包括所有省份
provinces = [
"zh_cuan", "",
"zh_e", "",
"zh_gan", "",
"zh_gan1", "",
"zh_gui", "",
"zh_gui1", "",
"zh_hei", "",
"zh_hu", "",
"zh_ji", "",
"zh_jin", "",
"zh_jing", "",
"zh_jl", "",
"zh_liao", "",
"zh_lu", "",
"zh_meng", "",
"zh_min", "",
"zh_ning", "",
"zh_qing", "",
"zh_qiong", "",
"zh_shan", "",紫苏汤
"zh_su", "",
"zh_sx", "",
"zh_wan", "",
"zh_xiang", "",
"zh_xin", "马桥小学",
"zh_yu", "",
"zh_yu1", "",
"zh_yue", "",
"zh_yun", "",
"zh_zang", "",
"zh_zhe", ""
]
class StatModel(object):
    def load(lf, fn):
        lf.model = lf.model.load(fn)
    def save(lf, fn):
        lf.model.save(fn)
class SVM(StatModel):
    def __init__(lf, C=1, gamma=0.5):
        lf.model = cv2.ml.SVM_create()
        lf.model.tGamma(gamma)
        lf.model.tC(C)
        lf.model.tKernel(cv2.ml.SVM_RBF)
        lf.model.tType(cv2.ml.SVM_C_SVC)
    # 训练svm
    def train(lf, samples, respons):
        ain(samples, cv2.ml.ROW_SAMPLE, respons)
    # 字符识别
    def predict(lf, samples):
        r = lf.model.predict(samples)
        return r[1].ravel()
class CardPredictor:
    def __init__(lf):
        # 车牌识别的部分参数保存在js支教教师中,便于根据图片分辨率做调整
        f = open('config.js')
        j = json.load(f)
        for c in j["config"]:
            print(c)
            if c["open"]:
                lf.cfg = c.copy()
                break
        el:
            rai RuntimeError('没有设置有效配置参数')

本文发布于:2023-05-14 01:55:12,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/89/895169.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:图片   参数   波峰   车牌
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图