日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python车牌识别使用训练集_TensorFlow车牌识别完整版代码(含车牌数据集)

發(fā)布時間:2023/12/31 python 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python车牌识别使用训练集_TensorFlow车牌识别完整版代码(含车牌数据集) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在之前發(fā)布的一篇博文《MNIST數(shù)據(jù)集實現(xiàn)車牌識別--初步演示版》中,我們演示了如何使用TensorFlow進行車牌識別,但是,當時采用的數(shù)據(jù)集是MNIST數(shù)字手寫體,只能分類0-9共10個數(shù)字,無法分類省份簡稱和字母,局限性較大,無實際意義。

經(jīng)過圖像定位分割處理,博主收集了相關省份簡稱和26個字母的圖片數(shù)據(jù)集,結合前述博文中貼出的python+TensorFlow代碼,實現(xiàn)了完整的車牌識別功能。本著分享精神,在此送上全部代碼和車牌數(shù)據(jù)集。

省份簡稱訓練+識別代碼(保存文件名為train-license-province.py)(拷貝代碼請務必注意python文本縮進,只要有一處縮進錯誤,就無法得到正確結果,或者出現(xiàn)異常):

#!/usr/bin/python3.5

# -*- coding: utf-8 -*-

import sys

import os

import time

import random

import numpy as np

import tensorflow as tf

from PIL import Image

SIZE = 1280

WIDTH = 32

HEIGHT = 40

NUM_CLASSES = 6

iterations = 300

SAVER_DIR = "train-saver/province/"

PROVINCES = ("京","閩","粵","蘇","滬","浙")

nProvinceIndex = 0

time_begin = time.time()

# 定義輸入節(jié)點,對應于圖片像素值矩陣集合和圖片標簽(即所代表的數(shù)字)

x = tf.placeholder(tf.float32, shape=[None, SIZE])

y_ = tf.placeholder(tf.float32, shape=[None, NUM_CLASSES])

x_image = tf.reshape(x, [-1, WIDTH, HEIGHT, 1])

# 定義卷積函數(shù)

def conv_layer(inputs, W, b, conv_strides, kernel_size, pool_strides, padding):

L1_conv = tf.nn.conv2d(inputs, W, strides=conv_strides, padding=padding)

L1_relu = tf.nn.relu(L1_conv + b)

return tf.nn.max_pool(L1_relu, ksize=kernel_size, strides=pool_strides, padding='SAME')

# 定義全連接層函數(shù)

def full_connect(inputs, W, b):

return tf.nn.relu(tf.matmul(inputs, W) + b)

if __name__ =='__main__' and sys.argv[1]=='train':

# 第一次遍歷圖片目錄是為了獲取圖片總數(shù)

input_count = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/training-set/chinese-characters/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

input_count += 1

# 定義對應維數(shù)和各維長度的數(shù)組

input_images = np.array([[0]*SIZE for i in range(input_count)])

input_labels = np.array([[0]*NUM_CLASSES for i in range(input_count)])

# 第二次遍歷圖片目錄是為了生成圖片數(shù)據(jù)和標簽

index = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/training-set/chinese-characters/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

filename = dir + filename

img = Image.open(filename)

width = img.size[0]

height = img.size[1]

for h in range(0, height):

for w in range(0, width):

# 通過這樣的處理,使數(shù)字的線條變細,有利于提高識別準確率

if img.getpixel((w, h)) > 230:

input_images[index][w+h*width] = 0

else:

input_images[index][w+h*width] = 1

input_labels[index][i] = 1

index += 1

# 第一次遍歷圖片目錄是為了獲取圖片總數(shù)

val_count = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/validation-set/chinese-characters/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

val_count += 1

# 定義對應維數(shù)和各維長度的數(shù)組

val_images = np.array([[0]*SIZE for i in range(val_count)])

val_labels = np.array([[0]*NUM_CLASSES for i in range(val_count)])

# 第二次遍歷圖片目錄是為了生成圖片數(shù)據(jù)和標簽

index = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/validation-set/chinese-characters/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

filename = dir + filename

img = Image.open(filename)

width = img.size[0]

height = img.size[1]

for h in range(0, height):

for w in range(0, width):

# 通過這樣的處理,使數(shù)字的線條變細,有利于提高識別準確率

if img.getpixel((w, h)) > 230:

val_images[index][w+h*width] = 0

else:

val_images[index][w+h*width] = 1

val_labels[index][i] = 1

index += 1

with tf.Session() as sess:

# 第一個卷積層

W_conv1 = tf.Variable(tf.truncated_normal([8, 8, 1, 16], stddev=0.1), name="W_conv1")

b_conv1 = tf.Variable(tf.constant(0.1, shape=[16]), name="b_conv1")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 2, 2, 1]

pool_strides = [1, 2, 2, 1]

L1_pool = conv_layer(x_image, W_conv1, b_conv1, conv_strides, kernel_size, pool_strides, padding='SAME')

# 第二個卷積層

W_conv2 = tf.Variable(tf.truncated_normal([5, 5, 16, 32], stddev=0.1), name="W_conv2")

b_conv2 = tf.Variable(tf.constant(0.1, shape=[32]), name="b_conv2")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 1, 1, 1]

pool_strides = [1, 1, 1, 1]

L2_pool = conv_layer(L1_pool, W_conv2, b_conv2, conv_strides, kernel_size, pool_strides, padding='SAME')

# 全連接層

W_fc1 = tf.Variable(tf.truncated_normal([16 * 20 * 32, 512], stddev=0.1), name="W_fc1")

b_fc1 = tf.Variable(tf.constant(0.1, shape=[512]), name="b_fc1")

h_pool2_flat = tf.reshape(L2_pool, [-1, 16 * 20*32])

h_fc1 = full_connect(h_pool2_flat, W_fc1, b_fc1)

# dropout

keep_prob = tf.placeholder(tf.float32)

h_fc1_drop = tf.nn.dropout(h_fc1, keep_prob)

# readout層

W_fc2 = tf.Variable(tf.truncated_normal([512, NUM_CLASSES], stddev=0.1), name="W_fc2")

b_fc2 = tf.Variable(tf.constant(0.1, shape=[NUM_CLASSES]), name="b_fc2")

# 定義優(yōu)化器和訓練op

y_conv = tf.matmul(h_fc1_drop, W_fc2) + b_fc2

cross_entropy = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(labels=y_, logits=y_conv))

train_step = tf.train.AdamOptimizer((1e-4)).minimize(cross_entropy)

correct_prediction = tf.equal(tf.argmax(y_conv, 1), tf.argmax(y_, 1))

accuracy = tf.reduce_mean(tf.cast(correct_prediction, tf.float32))

# 初始化saver

saver = tf.train.Saver()

sess.run(tf.global_variables_initializer())

time_elapsed = time.time() - time_begin

print("讀取圖片文件耗費時間:%d秒" % time_elapsed)

time_begin = time.time()

print ("一共讀取了 %s 個訓練圖像, %s 個標簽" % (input_count, input_count))

# 設置每次訓練op的輸入個數(shù)和迭代次數(shù),這里為了支持任意圖片總數(shù),定義了一個余數(shù)remainder,譬如,如果每次訓練op的輸入個數(shù)為60,圖片總數(shù)為150張,則前面兩次各輸入60張,最后一次輸入30張(余數(shù)30)

batch_size = 60

iterations = iterations

batches_count = int(input_count / batch_size)

remainder = input_count % batch_size

print ("訓練數(shù)據(jù)集分成 %s 批, 前面每批 %s 個數(shù)據(jù),最后一批 %s 個數(shù)據(jù)" % (batches_count+1, batch_size, remainder))

# 執(zhí)行訓練迭代

for it in range(iterations):

# 這里的關鍵是要把輸入數(shù)組轉(zhuǎn)為np.array

for n in range(batches_count):

train_step.run(feed_dict={x: input_images[n*batch_size:(n+1)*batch_size], y_: input_labels[n*batch_size:(n+1)*batch_size], keep_prob: 0.5})

if remainder > 0:

start_index = batches_count * batch_size;

train_step.run(feed_dict={x: input_images[start_index:input_count-1], y_: input_labels[start_index:input_count-1], keep_prob: 0.5})

# 每完成五次迭代,判斷準確度是否已達到100%,達到則退出迭代循環(huán)

iterate_accuracy = 0

if it%5 == 0:

iterate_accuracy = accuracy.eval(feed_dict={x: val_images, y_: val_labels, keep_prob: 1.0})

print ('第 %d 次訓練迭代: 準確率 %0.5f%%' % (it, iterate_accuracy*100))

if iterate_accuracy >= 0.9999 and it >= 150:

break;

print ('完成訓練!')

time_elapsed = time.time() - time_begin

print ("訓練耗費時間:%d秒" % time_elapsed)

time_begin = time.time()

# 保存訓練結果

if not os.path.exists(SAVER_DIR):

print ('不存在訓練數(shù)據(jù)保存目錄,現(xiàn)在創(chuàng)建保存目錄')

os.makedirs(SAVER_DIR)

saver_path = saver.save(sess, "%smodel.ckpt"%(SAVER_DIR))

if __name__ =='__main__' and sys.argv[1]=='predict':

saver = tf.train.import_meta_graph("%smodel.ckpt.meta"%(SAVER_DIR))

with tf.Session() as sess:

model_file=tf.train.latest_checkpoint(SAVER_DIR)

saver.restore(sess, model_file)

# 第一個卷積層

W_conv1 = sess.graph.get_tensor_by_name("W_conv1:0")

b_conv1 = sess.graph.get_tensor_by_name("b_conv1:0")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 2, 2, 1]

pool_strides = [1, 2, 2, 1]

L1_pool = conv_layer(x_image, W_conv1, b_conv1, conv_strides, kernel_size, pool_strides, padding='SAME')

# 第二個卷積層

W_conv2 = sess.graph.get_tensor_by_name("W_conv2:0")

b_conv2 = sess.graph.get_tensor_by_name("b_conv2:0")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 1, 1, 1]

pool_strides = [1, 1, 1, 1]

L2_pool = conv_layer(L1_pool, W_conv2, b_conv2, conv_strides, kernel_size, pool_strides, padding='SAME')

# 全連接層

W_fc1 = sess.graph.get_tensor_by_name("W_fc1:0")

b_fc1 = sess.graph.get_tensor_by_name("b_fc1:0")

h_pool2_flat = tf.reshape(L2_pool, [-1, 16 * 20*32])

h_fc1 = full_connect(h_pool2_flat, W_fc1, b_fc1)

# dropout

keep_prob = tf.placeholder(tf.float32)

h_fc1_drop = tf.nn.dropout(h_fc1, keep_prob)

# readout層

W_fc2 = sess.graph.get_tensor_by_name("W_fc2:0")

b_fc2 = sess.graph.get_tensor_by_name("b_fc2:0")

# 定義優(yōu)化器和訓練op

conv = tf.nn.softmax(tf.matmul(h_fc1_drop, W_fc2) + b_fc2)

for n in range(1,2):

path = "test_images/%s.bmp" % (n)

img = Image.open(path)

width = img.size[0]

height = img.size[1]

img_data = [[0]*SIZE for i in range(1)]

for h in range(0, height):

for w in range(0, width):

if img.getpixel((w, h)) < 190:

img_data[0][w+h*width] = 1

else:

img_data[0][w+h*width] = 0

result = sess.run(conv, feed_dict = {x: np.array(img_data), keep_prob: 1.0})

max1 = 0

max2 = 0

max3 = 0

max1_index = 0

max2_index = 0

max3_index = 0

for j in range(NUM_CLASSES):

if result[0][j] > max1:

max1 = result[0][j]

max1_index = j

continue

if (result[0][j]>max2) and (result[0][j]<=max1):

max2 = result[0][j]

max2_index = j

continue

if (result[0][j]>max3) and (result[0][j]<=max2):

max3 = result[0][j]

max3_index = j

continue

nProvinceIndex = max1_index

print ("概率: [%s %0.2f%%] [%s %0.2f%%] [%s %0.2f%%]" % (PROVINCES[max1_index],max1*100, PROVINCES[max2_index],max2*100, PROVINCES[max3_index],max3*100))

print ("省份簡稱是: %s" % PROVINCES[nProvinceIndex])

城市代號訓練+識別代碼(保存文件名為train-license-letters.py):

#!/usr/bin/python3.5

# -*- coding: utf-8 -*-

import sys

import os

import time

import random

import numpy as np

import tensorflow as tf

from PIL import Image

SIZE = 1280

WIDTH = 32

HEIGHT = 40

NUM_CLASSES = 26

iterations = 500

SAVER_DIR = "train-saver/letters/"

LETTERS_DIGITS = ("A","B","C","D","E","F","G","H","J","K","L","M","N","P","Q","R","S","T","U","V","W","X","Y","Z","I","O")

license_num = ""

time_begin = time.time()

# 定義輸入節(jié)點,對應于圖片像素值矩陣集合和圖片標簽(即所代表的數(shù)字)

x = tf.placeholder(tf.float32, shape=[None, SIZE])

y_ = tf.placeholder(tf.float32, shape=[None, NUM_CLASSES])

x_image = tf.reshape(x, [-1, WIDTH, HEIGHT, 1])

# 定義卷積函數(shù)

def conv_layer(inputs, W, b, conv_strides, kernel_size, pool_strides, padding):

L1_conv = tf.nn.conv2d(inputs, W, strides=conv_strides, padding=padding)

L1_relu = tf.nn.relu(L1_conv + b)

return tf.nn.max_pool(L1_relu, ksize=kernel_size, strides=pool_strides, padding='SAME')

# 定義全連接層函數(shù)

def full_connect(inputs, W, b):

return tf.nn.relu(tf.matmul(inputs, W) + b)

if __name__ =='__main__' and sys.argv[1]=='train':

# 第一次遍歷圖片目錄是為了獲取圖片總數(shù)

input_count = 0

for i in range(0+10,NUM_CLASSES+10):

dir = './train_images/training-set/letters/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

input_count += 1

# 定義對應維數(shù)和各維長度的數(shù)組

input_images = np.array([[0]*SIZE for i in range(input_count)])

input_labels = np.array([[0]*NUM_CLASSES for i in range(input_count)])

# 第二次遍歷圖片目錄是為了生成圖片數(shù)據(jù)和標簽

index = 0

for i in range(0+10,NUM_CLASSES+10):

dir = './train_images/training-set/letters/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

filename = dir + filename

img = Image.open(filename)

width = img.size[0]

height = img.size[1]

for h in range(0, height):

for w in range(0, width):

# 通過這樣的處理,使數(shù)字的線條變細,有利于提高識別準確率

if img.getpixel((w, h)) > 230:

input_images[index][w+h*width] = 0

else:

input_images[index][w+h*width] = 1

#print ("i=%d, index=%d" % (i, index))

input_labels[index][i-10] = 1

index += 1

# 第一次遍歷圖片目錄是為了獲取圖片總數(shù)

val_count = 0

for i in range(0+10,NUM_CLASSES+10):

dir = './train_images/validation-set/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

val_count += 1

# 定義對應維數(shù)和各維長度的數(shù)組

val_images = np.array([[0]*SIZE for i in range(val_count)])

val_labels = np.array([[0]*NUM_CLASSES for i in range(val_count)])

# 第二次遍歷圖片目錄是為了生成圖片數(shù)據(jù)和標簽

index = 0

for i in range(0+10,NUM_CLASSES+10):

dir = './train_images/validation-set/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

filename = dir + filename

img = Image.open(filename)

width = img.size[0]

height = img.size[1]

for h in range(0, height):

for w in range(0, width):

# 通過這樣的處理,使數(shù)字的線條變細,有利于提高識別準確率

if img.getpixel((w, h)) > 230:

val_images[index][w+h*width] = 0

else:

val_images[index][w+h*width] = 1

val_labels[index][i-10] = 1

index += 1

with tf.Session() as sess:

# 第一個卷積層

W_conv1 = tf.Variable(tf.truncated_normal([8, 8, 1, 16], stddev=0.1), name="W_conv1")

b_conv1 = tf.Variable(tf.constant(0.1, shape=[16]), name="b_conv1")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 2, 2, 1]

pool_strides = [1, 2, 2, 1]

L1_pool = conv_layer(x_image, W_conv1, b_conv1, conv_strides, kernel_size, pool_strides, padding='SAME')

# 第二個卷積層

W_conv2 = tf.Variable(tf.truncated_normal([5, 5, 16, 32], stddev=0.1), name="W_conv2")

b_conv2 = tf.Variable(tf.constant(0.1, shape=[32]), name="b_conv2")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 1, 1, 1]

pool_strides = [1, 1, 1, 1]

L2_pool = conv_layer(L1_pool, W_conv2, b_conv2, conv_strides, kernel_size, pool_strides, padding='SAME')

# 全連接層

W_fc1 = tf.Variable(tf.truncated_normal([16 * 20 * 32, 512], stddev=0.1), name="W_fc1")

b_fc1 = tf.Variable(tf.constant(0.1, shape=[512]), name="b_fc1")

h_pool2_flat = tf.reshape(L2_pool, [-1, 16 * 20*32])

h_fc1 = full_connect(h_pool2_flat, W_fc1, b_fc1)

# dropout

keep_prob = tf.placeholder(tf.float32)

h_fc1_drop = tf.nn.dropout(h_fc1, keep_prob)

# readout層

W_fc2 = tf.Variable(tf.truncated_normal([512, NUM_CLASSES], stddev=0.1), name="W_fc2")

b_fc2 = tf.Variable(tf.constant(0.1, shape=[NUM_CLASSES]), name="b_fc2")

# 定義優(yōu)化器和訓練op

y_conv = tf.matmul(h_fc1_drop, W_fc2) + b_fc2

cross_entropy = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(labels=y_, logits=y_conv))

train_step = tf.train.AdamOptimizer((1e-4)).minimize(cross_entropy)

correct_prediction = tf.equal(tf.argmax(y_conv, 1), tf.argmax(y_, 1))

accuracy = tf.reduce_mean(tf.cast(correct_prediction, tf.float32))

sess.run(tf.global_variables_initializer())

time_elapsed = time.time() - time_begin

print("讀取圖片文件耗費時間:%d秒" % time_elapsed)

time_begin = time.time()

print ("一共讀取了 %s 個訓練圖像, %s 個標簽" % (input_count, input_count))

# 設置每次訓練op的輸入個數(shù)和迭代次數(shù),這里為了支持任意圖片總數(shù),定義了一個余數(shù)remainder,譬如,如果每次訓練op的輸入個數(shù)為60,圖片總數(shù)為150張,則前面兩次各輸入60張,最后一次輸入30張(余數(shù)30)

batch_size = 60

iterations = iterations

batches_count = int(input_count / batch_size)

remainder = input_count % batch_size

print ("訓練數(shù)據(jù)集分成 %s 批, 前面每批 %s 個數(shù)據(jù),最后一批 %s 個數(shù)據(jù)" % (batches_count+1, batch_size, remainder))

# 執(zhí)行訓練迭代

for it in range(iterations):

# 這里的關鍵是要把輸入數(shù)組轉(zhuǎn)為np.array

for n in range(batches_count):

train_step.run(feed_dict={x: input_images[n*batch_size:(n+1)*batch_size], y_: input_labels[n*batch_size:(n+1)*batch_size], keep_prob: 0.5})

if remainder > 0:

start_index = batches_count * batch_size;

train_step.run(feed_dict={x: input_images[start_index:input_count-1], y_: input_labels[start_index:input_count-1], keep_prob: 0.5})

# 每完成五次迭代,判斷準確度是否已達到100%,達到則退出迭代循環(huán)

iterate_accuracy = 0

if it%5 == 0:

iterate_accuracy = accuracy.eval(feed_dict={x: val_images, y_: val_labels, keep_prob: 1.0})

print ('第 %d 次訓練迭代: 準確率 %0.5f%%' % (it, iterate_accuracy*100))

if iterate_accuracy >= 0.9999 and it >= iterations:

break;

print ('完成訓練!')

time_elapsed = time.time() - time_begin

print ("訓練耗費時間:%d秒" % time_elapsed)

time_begin = time.time()

# 保存訓練結果

if not os.path.exists(SAVER_DIR):

print ('不存在訓練數(shù)據(jù)保存目錄,現(xiàn)在創(chuàng)建保存目錄')

os.makedirs(SAVER_DIR)

# 初始化saver

saver = tf.train.Saver()

saver_path = saver.save(sess, "%smodel.ckpt"%(SAVER_DIR))

if __name__ =='__main__' and sys.argv[1]=='predict':

saver = tf.train.import_meta_graph("%smodel.ckpt.meta"%(SAVER_DIR))

with tf.Session() as sess:

model_file=tf.train.latest_checkpoint(SAVER_DIR)

saver.restore(sess, model_file)

# 第一個卷積層

W_conv1 = sess.graph.get_tensor_by_name("W_conv1:0")

b_conv1 = sess.graph.get_tensor_by_name("b_conv1:0")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 2, 2, 1]

pool_strides = [1, 2, 2, 1]

L1_pool = conv_layer(x_image, W_conv1, b_conv1, conv_strides, kernel_size, pool_strides, padding='SAME')

# 第二個卷積層

W_conv2 = sess.graph.get_tensor_by_name("W_conv2:0")

b_conv2 = sess.graph.get_tensor_by_name("b_conv2:0")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 1, 1, 1]

pool_strides = [1, 1, 1, 1]

L2_pool = conv_layer(L1_pool, W_conv2, b_conv2, conv_strides, kernel_size, pool_strides, padding='SAME')

# 全連接層

W_fc1 = sess.graph.get_tensor_by_name("W_fc1:0")

b_fc1 = sess.graph.get_tensor_by_name("b_fc1:0")

h_pool2_flat = tf.reshape(L2_pool, [-1, 16 * 20*32])

h_fc1 = full_connect(h_pool2_flat, W_fc1, b_fc1)

# dropout

keep_prob = tf.placeholder(tf.float32)

h_fc1_drop = tf.nn.dropout(h_fc1, keep_prob)

# readout層

W_fc2 = sess.graph.get_tensor_by_name("W_fc2:0")

b_fc2 = sess.graph.get_tensor_by_name("b_fc2:0")

# 定義優(yōu)化器和訓練op

conv = tf.nn.softmax(tf.matmul(h_fc1_drop, W_fc2) + b_fc2)

for n in range(2,3):

path = "test_images/%s.bmp" % (n)

img = Image.open(path)

width = img.size[0]

height = img.size[1]

img_data = [[0]*SIZE for i in range(1)]

for h in range(0, height):

for w in range(0, width):

if img.getpixel((w, h)) < 190:

img_data[0][w+h*width] = 1

else:

img_data[0][w+h*width] = 0

result = sess.run(conv, feed_dict = {x: np.array(img_data), keep_prob: 1.0})

max1 = 0

max2 = 0

max3 = 0

max1_index = 0

max2_index = 0

max3_index = 0

for j in range(NUM_CLASSES):

if result[0][j] > max1:

max1 = result[0][j]

max1_index = j

continue

if (result[0][j]>max2) and (result[0][j]<=max1):

max2 = result[0][j]

max2_index = j

continue

if (result[0][j]>max3) and (result[0][j]<=max2):

max3 = result[0][j]

max3_index = j

continue

if n == 3:

license_num += "-"

license_num = license_num + LETTERS_DIGITS[max1_index]

print ("概率: [%s %0.2f%%] [%s %0.2f%%] [%s %0.2f%%]" % (LETTERS_DIGITS[max1_index],max1*100, LETTERS_DIGITS[max2_index],max2*100, LETTERS_DIGITS[max3_index],max3*100))

print ("城市代號是: 【%s】" % license_num)

車牌編號訓練+識別代碼(保存文件名為train-license-digits.py):

#!/usr/bin/python3.5

# -*- coding: utf-8 -*-

import sys

import os

import time

import random

import numpy as np

import tensorflow as tf

from PIL import Image

SIZE = 1280

WIDTH = 32

HEIGHT = 40

NUM_CLASSES = 34

iterations = 1000

SAVER_DIR = "train-saver/digits/"

LETTERS_DIGITS = ("0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","J","K","L","M","N","P","Q","R","S","T","U","V","W","X","Y","Z")

license_num = ""

time_begin = time.time()

# 定義輸入節(jié)點,對應于圖片像素值矩陣集合和圖片標簽(即所代表的數(shù)字)

x = tf.placeholder(tf.float32, shape=[None, SIZE])

y_ = tf.placeholder(tf.float32, shape=[None, NUM_CLASSES])

x_image = tf.reshape(x, [-1, WIDTH, HEIGHT, 1])

# 定義卷積函數(shù)

def conv_layer(inputs, W, b, conv_strides, kernel_size, pool_strides, padding):

L1_conv = tf.nn.conv2d(inputs, W, strides=conv_strides, padding=padding)

L1_relu = tf.nn.relu(L1_conv + b)

return tf.nn.max_pool(L1_relu, ksize=kernel_size, strides=pool_strides, padding='SAME')

# 定義全連接層函數(shù)

def full_connect(inputs, W, b):

return tf.nn.relu(tf.matmul(inputs, W) + b)

if __name__ =='__main__' and sys.argv[1]=='train':

# 第一次遍歷圖片目錄是為了獲取圖片總數(shù)

input_count = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/training-set/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

input_count += 1

# 定義對應維數(shù)和各維長度的數(shù)組

input_images = np.array([[0]*SIZE for i in range(input_count)])

input_labels = np.array([[0]*NUM_CLASSES for i in range(input_count)])

# 第二次遍歷圖片目錄是為了生成圖片數(shù)據(jù)和標簽

index = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/training-set/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

filename = dir + filename

img = Image.open(filename)

width = img.size[0]

height = img.size[1]

for h in range(0, height):

for w in range(0, width):

# 通過這樣的處理,使數(shù)字的線條變細,有利于提高識別準確率

if img.getpixel((w, h)) > 230:

input_images[index][w+h*width] = 0

else:

input_images[index][w+h*width] = 1

input_labels[index][i] = 1

index += 1

# 第一次遍歷圖片目錄是為了獲取圖片總數(shù)

val_count = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/validation-set/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

val_count += 1

# 定義對應維數(shù)和各維長度的數(shù)組

val_images = np.array([[0]*SIZE for i in range(val_count)])

val_labels = np.array([[0]*NUM_CLASSES for i in range(val_count)])

# 第二次遍歷圖片目錄是為了生成圖片數(shù)據(jù)和標簽

index = 0

for i in range(0,NUM_CLASSES):

dir = './train_images/validation-set/%s/' % i # 這里可以改成你自己的圖片目錄,i為分類標簽

for rt, dirs, files in os.walk(dir):

for filename in files:

filename = dir + filename

img = Image.open(filename)

width = img.size[0]

height = img.size[1]

for h in range(0, height):

for w in range(0, width):

# 通過這樣的處理,使數(shù)字的線條變細,有利于提高識別準確率

if img.getpixel((w, h)) > 230:

val_images[index][w+h*width] = 0

else:

val_images[index][w+h*width] = 1

val_labels[index][i] = 1

index += 1

with tf.Session() as sess:

# 第一個卷積層

W_conv1 = tf.Variable(tf.truncated_normal([8, 8, 1, 16], stddev=0.1), name="W_conv1")

b_conv1 = tf.Variable(tf.constant(0.1, shape=[16]), name="b_conv1")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 2, 2, 1]

pool_strides = [1, 2, 2, 1]

L1_pool = conv_layer(x_image, W_conv1, b_conv1, conv_strides, kernel_size, pool_strides, padding='SAME')

# 第二個卷積層

W_conv2 = tf.Variable(tf.truncated_normal([5, 5, 16, 32], stddev=0.1), name="W_conv2")

b_conv2 = tf.Variable(tf.constant(0.1, shape=[32]), name="b_conv2")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 1, 1, 1]

pool_strides = [1, 1, 1, 1]

L2_pool = conv_layer(L1_pool, W_conv2, b_conv2, conv_strides, kernel_size, pool_strides, padding='SAME')

# 全連接層

W_fc1 = tf.Variable(tf.truncated_normal([16 * 20 * 32, 512], stddev=0.1), name="W_fc1")

b_fc1 = tf.Variable(tf.constant(0.1, shape=[512]), name="b_fc1")

h_pool2_flat = tf.reshape(L2_pool, [-1, 16 * 20*32])

h_fc1 = full_connect(h_pool2_flat, W_fc1, b_fc1)

# dropout

keep_prob = tf.placeholder(tf.float32)

h_fc1_drop = tf.nn.dropout(h_fc1, keep_prob)

# readout層

W_fc2 = tf.Variable(tf.truncated_normal([512, NUM_CLASSES], stddev=0.1), name="W_fc2")

b_fc2 = tf.Variable(tf.constant(0.1, shape=[NUM_CLASSES]), name="b_fc2")

# 定義優(yōu)化器和訓練op

y_conv = tf.matmul(h_fc1_drop, W_fc2) + b_fc2

cross_entropy = tf.reduce_mean(tf.nn.softmax_cross_entropy_with_logits(labels=y_, logits=y_conv))

train_step = tf.train.AdamOptimizer((1e-4)).minimize(cross_entropy)

correct_prediction = tf.equal(tf.argmax(y_conv, 1), tf.argmax(y_, 1))

accuracy = tf.reduce_mean(tf.cast(correct_prediction, tf.float32))

sess.run(tf.global_variables_initializer())

time_elapsed = time.time() - time_begin

print("讀取圖片文件耗費時間:%d秒" % time_elapsed)

time_begin = time.time()

print ("一共讀取了 %s 個訓練圖像, %s 個標簽" % (input_count, input_count))

# 設置每次訓練op的輸入個數(shù)和迭代次數(shù),這里為了支持任意圖片總數(shù),定義了一個余數(shù)remainder,譬如,如果每次訓練op的輸入個數(shù)為60,圖片總數(shù)為150張,則前面兩次各輸入60張,最后一次輸入30張(余數(shù)30)

batch_size = 60

iterations = iterations

batches_count = int(input_count / batch_size)

remainder = input_count % batch_size

print ("訓練數(shù)據(jù)集分成 %s 批, 前面每批 %s 個數(shù)據(jù),最后一批 %s 個數(shù)據(jù)" % (batches_count+1, batch_size, remainder))

# 執(zhí)行訓練迭代

for it in range(iterations):

# 這里的關鍵是要把輸入數(shù)組轉(zhuǎn)為np.array

for n in range(batches_count):

train_step.run(feed_dict={x: input_images[n*batch_size:(n+1)*batch_size], y_: input_labels[n*batch_size:(n+1)*batch_size], keep_prob: 0.5})

if remainder > 0:

start_index = batches_count * batch_size;

train_step.run(feed_dict={x: input_images[start_index:input_count-1], y_: input_labels[start_index:input_count-1], keep_prob: 0.5})

# 每完成五次迭代,判斷準確度是否已達到100%,達到則退出迭代循環(huán)

iterate_accuracy = 0

if it%5 == 0:

iterate_accuracy = accuracy.eval(feed_dict={x: val_images, y_: val_labels, keep_prob: 1.0})

print ('第 %d 次訓練迭代: 準確率 %0.5f%%' % (it, iterate_accuracy*100))

if iterate_accuracy >= 0.9999 and it >= iterations:

break;

print ('完成訓練!')

time_elapsed = time.time() - time_begin

print ("訓練耗費時間:%d秒" % time_elapsed)

time_begin = time.time()

# 保存訓練結果

if not os.path.exists(SAVER_DIR):

print ('不存在訓練數(shù)據(jù)保存目錄,現(xiàn)在創(chuàng)建保存目錄')

os.makedirs(SAVER_DIR)

# 初始化saver

saver = tf.train.Saver()

saver_path = saver.save(sess, "%smodel.ckpt"%(SAVER_DIR))

if __name__ =='__main__' and sys.argv[1]=='predict':

saver = tf.train.import_meta_graph("%smodel.ckpt.meta"%(SAVER_DIR))

with tf.Session() as sess:

model_file=tf.train.latest_checkpoint(SAVER_DIR)

saver.restore(sess, model_file)

# 第一個卷積層

W_conv1 = sess.graph.get_tensor_by_name("W_conv1:0")

b_conv1 = sess.graph.get_tensor_by_name("b_conv1:0")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 2, 2, 1]

pool_strides = [1, 2, 2, 1]

L1_pool = conv_layer(x_image, W_conv1, b_conv1, conv_strides, kernel_size, pool_strides, padding='SAME')

# 第二個卷積層

W_conv2 = sess.graph.get_tensor_by_name("W_conv2:0")

b_conv2 = sess.graph.get_tensor_by_name("b_conv2:0")

conv_strides = [1, 1, 1, 1]

kernel_size = [1, 1, 1, 1]

pool_strides = [1, 1, 1, 1]

L2_pool = conv_layer(L1_pool, W_conv2, b_conv2, conv_strides, kernel_size, pool_strides, padding='SAME')

# 全連接層

W_fc1 = sess.graph.get_tensor_by_name("W_fc1:0")

b_fc1 = sess.graph.get_tensor_by_name("b_fc1:0")

h_pool2_flat = tf.reshape(L2_pool, [-1, 16 * 20*32])

h_fc1 = full_connect(h_pool2_flat, W_fc1, b_fc1)

# dropout

keep_prob = tf.placeholder(tf.float32)

h_fc1_drop = tf.nn.dropout(h_fc1, keep_prob)

# readout層

W_fc2 = sess.graph.get_tensor_by_name("W_fc2:0")

b_fc2 = sess.graph.get_tensor_by_name("b_fc2:0")

# 定義優(yōu)化器和訓練op

conv = tf.nn.softmax(tf.matmul(h_fc1_drop, W_fc2) + b_fc2)

for n in range(3,8):

path = "test_images/%s.bmp" % (n)

img = Image.open(path)

width = img.size[0]

height = img.size[1]

img_data = [[0]*SIZE for i in range(1)]

for h in range(0, height):

for w in range(0, width):

if img.getpixel((w, h)) < 190:

img_data[0][w+h*width] = 1

else:

img_data[0][w+h*width] = 0

result = sess.run(conv, feed_dict = {x: np.array(img_data), keep_prob: 1.0})

max1 = 0

max2 = 0

max3 = 0

max1_index = 0

max2_index = 0

max3_index = 0

for j in range(NUM_CLASSES):

if result[0][j] > max1:

max1 = result[0][j]

max1_index = j

continue

if (result[0][j]>max2) and (result[0][j]<=max1):

max2 = result[0][j]

max2_index = j

continue

if (result[0][j]>max3) and (result[0][j]<=max2):

max3 = result[0][j]

max3_index = j

continue

license_num = license_num + LETTERS_DIGITS[max1_index]

print ("概率: [%s %0.2f%%] [%s %0.2f%%] [%s %0.2f%%]" % (LETTERS_DIGITS[max1_index],max1*100, LETTERS_DIGITS[max2_index],max2*100, LETTERS_DIGITS[max3_index],max3*100))

print ("車牌編號是: 【%s】" % license_num)

保存好上面三個python腳本后,我們首先進行省份簡稱訓練。在運行代碼之前,需要先把數(shù)據(jù)集解壓到訓練腳本所在目錄。然后,在命令行中進入腳本所在目錄,輸入執(zhí)行如下命令:

python train-license-province.py train

訓練結果如下:

然后進行省份簡稱識別,在命令行輸入執(zhí)行如下命令:

python train-license-province.py predict

執(zhí)行城市代號訓練(相當于訓練26個字母):

python train-license-letters.py train

識別城市代號:

python train-license-letters.py predict

執(zhí)行車牌編號訓練(相當于訓練24個字母+10個數(shù)字,我國交通法規(guī)規(guī)定車牌編號中不包含字母I和O):

python train-license-digits.py train

識別車牌編號:

python train-license-digits.py predict

可以看到,在測試圖片上,識別準確率很高。識別結果是閩O-1672Q。

下圖是測試圖片的車牌原圖:

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

總結

以上是生活随笔為你收集整理的python车牌识别使用训练集_TensorFlow车牌识别完整版代码(含车牌数据集)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

亚洲国产午夜视频 | 国产福利不卡视频 | 二区三区视频 | 国产又黄又爽无遮挡 | 日韩av影片在线观看 | 精品美女国产在线 | www黄色大片 | 一区二区三区精品在线视频 | 一区二区不卡高清 | 午夜国产影院 | 国产精品久久久久久久久久久久午 | 91精品国产乱码在线观看 | 日本在线成人 | 白丝av免费观看 | 国产免费叼嘿网站免费 | 成人免费看黄 | 日韩中文字幕免费视频 | 国产91勾搭技师精品 | 免费在线a | 日韩av播放在线 | 国产午夜激情视频 | 91九色精品国产 | 日韩电影久久久 | 亚洲在线日韩 | av超碰在线 | 国产精品永久在线 | 中文字幕欧美日韩va免费视频 | 久久免费视频在线 | 夜夜躁日日躁狠狠久久88av | 99 色| 99精品在线播放 | 免费观看高清 | 欧美性生爱 | 久久久99精品免费观看乱色 | 91传媒视频在线观看 | 成人黄色国产 | 又长又大又黑又粗欧美 | 最新午夜 | 国内精品久久久久影院一蜜桃 | 日韩av影视在线 | 国产高清专区 | 久香蕉| 最近2019好看的中文字幕免费 | 国产伦精品一区二区三区高清 | 天堂中文在线视频 | 国产精品观看视频 | 日韩三级免费观看 | 国产一区二区三区在线 | 久久国产品| 五月激情丁香图片 | www视频免费在线观看 | 久久视频精品在线 | 高清av网 | 免费精品人在线二线三线 | 国产黄色片免费看 | 日本在线中文 | 在线观看成人网 | 亚洲国产免费网站 | 少妇bbw搡bbbb搡bbbb | 日韩欧美亚州 | av综合网址 | 黄色三级久久 | 久久综合婷婷综合 | 亚洲激情网站免费观看 | 在线之家免费在线观看电影 | 亚洲电影久久久 | 成人免费观看在线视频 | 国产一二区在线观看 | 久久精品三| 91夜夜夜 | 碰超在线97人人 | 午夜精品久久久久久久99 | www色片 | 久久综合九色综合欧美就去吻 | 美女久久久久久久久久 | 国产 日韩 在线 亚洲 字幕 中文 | 欧美巨乳网 | 麻豆av电影 | 亚洲少妇自拍 | 成人一级片视频 | 日韩毛片精品 | 欧美国产日韩久久 | 欧美在线观看小视频 | 在线视频中文字幕一区 | 久久久久久国产精品999 | 黄p网站在线观看 | 91精品1区2区| 精品国产资源 | 亚洲成a人片在线观看中文 中文字幕在线视频第一页 狠狠色丁香婷婷综合 | 99视频精品全部免费 在线 | 成人小视频在线免费观看 | 国产亚洲精品精品精品 | av免费观看高清 | 国产99久久 | 免费av影视 | 久久免费毛片 | 国产在线国产 | www.超碰97.com| av免费看在线 | 99999精品 | 国产伦精品一区二区三区… | 婷婷在线网 | 色综合久久久久综合体桃花网 | 天天干,天天射,天天操,天天摸 | 人人插人人玩 | 免费看精品久久片 | 亚洲欧美国产精品 | 91自拍视频在线观看 | 欧美色综合天天久久综合精品 | 久久久精品免费观看 | 在线黄色免费 | 狠狠色丁香九九婷婷综合五月 | 精品超碰 | 奇人奇案qvod | 少妇搡bbbb搡bbb搡忠贞 | 亚洲理论片 | 91免费日韩 | 国产一区二区久久精品 | 99人成在线观看视频 | 日韩精品免费一线在线观看 | 日韩最新av在线 | 国产精品久久久久久久妇 | 久久精品国产亚洲精品 | 99精品国产高清在线观看 | 精品色999| 美国av大片 | 国产精品毛片一区视频播不卡 | 天天天天天天操 | 特黄色大片 | 国产一区二区三精品久久久无广告 | 五月婷婷六月综合 | 日本精品一区二区三区在线观看 | 婷婷国产精品 | 美女视频是黄的免费观看 | 久久a国产 | 国产色在线观看 | 天天爱天天操 | 伊人资源视频在线 | 亚洲国产精品一区二区尤物区 | 高清不卡免费视频 | 日韩专区在线播放 | 日本护士撒尿xxxx18 | 亚洲欧美偷拍另类 | 免费高清在线观看成人 | 日韩欧美综合在线视频 | 亚洲在线国产 | 97超碰人人模人人人爽人人爱 | 婷婷久久五月天 | 亚洲精品在线视频播放 | 黄色大片免费播放 | 久草手机视频 | 97人人射| 国内精品久久久久久久久久久久 | 91精品视频一区二区三区 | 国产成人精品久 | 国产精品理论片在线播放 | 成人亚洲综合 | 日本护士三级少妇三级999 | 亚洲激情小视频 | 亚洲欧美精品一区二区 | 国产性天天综合网 | 91粉色视频 | 欧美极品少妇xxxxⅹ欧美极品少妇xxxx亚洲精品 | 97超碰福利久久精品 | www.成人久久 | 欧美性黄网官网 | 在线观看亚洲电影 | 日韩在线观看一区 | 九九热免费视频在线观看 | 免费网站观看www在线观看 | 米奇四色影视 | 亚洲一级片av | 免费av电影网站 | 免费看日韩片 | av中文字幕亚洲 | 伊人资源视频在线 | 精品国产一区二区三区四区在线观看 | 国产精品久久久久毛片大屁完整版 | 亚洲精品视频免费看 | 中文字幕在线乱 | 久久夜色精品国产欧美乱极品 | 久久久久久毛片精品免费不卡 | 国产淫a| 天天躁天天躁天天躁婷 | 精品国产一区二区三区av性色 | 深爱激情久久 | 国产日韩精品一区二区 | 久久久精品欧美 | 一本一道久久a久久精品蜜桃 | 久久字幕精品一区 | 免费在线看成人av | 天天操夜夜摸 | 国产色一区 | 国产精品 中文字幕 亚洲 欧美 | 中文字幕人成人 | 日韩欧美91 | 黄免费网站| 免费在线观看污 | 深爱激情亚洲 | 日韩欧美一区二区在线播放 | 免费黄色网止 | 久久久91精品国产一区二区三区 | 国产精品久久久久久久久久东京 | 欧美成人tv | 97视频精品 | 亚洲欧洲在线视频 | 久久精品成人热国产成 | 色播激情五月 | 国产高清一 | 久久久久久久综合色一本 | 五月天激情综合 | 最近中文字幕在线 | 免费视频二区 | 欧美精彩视频在线观看 | 日本三级香港三级人妇99 | 亚洲欧洲在线视频 | www.黄色在线 | 97天堂 | 狠狠干天天射 | 香蕉网在线观看 | av一本久道久久波多野结衣 | 激情五月视频 | 色99之美女主播在线视频 | 天天干,夜夜爽 | 久久99精品热在线观看 | 欧美久久久一区二区三区 | 国产成人av一区二区三区在线观看 | 99爱在线观看 | 色综合五月天 | 欧美激情第28页 | 国产日产精品久久久久快鸭 | 99精品在线免费观看 | www五月天 | 日韩在线电影一区二区 | 国产精品久久久久影院日本 | 国产成人333kkk | 精品国产乱码久久久久 | 最新国产精品拍自在线播放 | 国产玖玖精品视频 | 欧美日韩久久一区 | 五月婷婷精品 | 视频在线亚洲 | 久久网站最新地址 | 成人午夜av电影 | 国产精品久久一卡二卡 | 国产在线欧美在线 | 999成人国产 | av在线免费在线 | 国产欧美精品xxxx另类 | 国产精品久久久久久久久大全 | 亚洲粉嫩av | 婷婷丁香花五月天 | 国产精品亚 | 亚洲精品男人的天堂 | 欧美日韩中文在线视频 | 成人免费一级 | 国产视频亚洲 | 国产精品一区二区三区观看 | 欧美福利久久 | 黄网站污 | 丝袜美腿亚洲综合 | 激情中文在线 | 亚洲精品国偷自产在线91正片 | 欧美精品久久久久久 | 91福利视频久久久久 | 91丨九色丨高潮 | 国内精品久久久久久久97牛牛 | 欧美va天堂在线电影 | 中文字幕高清在线 | 欧美日韩国产页 | 97网| 久久国产亚洲视频 | 欧美91片| 五月天色综合 | 久久99精品波多结衣一区 | 国产色小视频 | 中文字幕在线观看免费 | 亚洲精品国产精品久久99 | 中文资源在线官网 | 国产正在播放 | 国产高清日韩欧美 | 欧美性另类 | 亚洲精品456在线播放 | 国产一级大片在线观看 | av中文字幕日韩 | 免费精品国产 | 国产在线91精品 | 亚洲久草视频 | 日韩中文在线视频 | 91精品国产综合久久福利 | 缴情综合网五月天 | 人人干干人人 | 国产一区在线播放 | 91av超碰| 久草视频在线播放 | 天天操夜| 久久天天操 | 久艹视频免费观看 | 天天草天天色 | 91精品国产欧美一区二区成人 | 国产麻豆果冻传媒在线观看 | av高清免费 | 久草在线视频首页 | 高清免费av在线 | 国产在线视频一区 | 99r在线观看| 一本一本久久a久久精品综合 | 在线观看你懂的网址 | 国产日韩欧美在线影视 | 国产精品成人自产拍在线观看 | 999国产在线 | 欧美日韩精品免费观看 | 不卡电影免费在线播放一区 | 欧美综合在线观看 | 成人午夜精品福利免费 | 亚洲一区二区三区91 | 国产精品无 | 欧美一级大片在线观看 | 久久久久综合精品福利啪啪 | av视屏在线 | 成人综合免费 | 中文视频在线看 | 亚洲综合精品视频 | 91完整版观看 | 久久久国产精品网站 | 久久久久精 | 精品久久一级片 | 91自拍视频在线 | 91精品蜜桃 | 日韩高清免费观看 | 亚洲精品在线网站 | 贫乳av女优大全 | 日韩在线观看一区二区三区 | 日韩精品一区二区三区不卡 | 久久8精品 | 日韩激情视频在线 | 日韩精品在线看 | 久久久视频在线 | 五月婷婷,六月丁香 | a特级毛片| 天天干中文字幕 | av三级在线免费观看 | 久久综合九色综合久久久精品综合 | 蜜桃av久久久亚洲精品 | 天天射天天干天天操 | 久久国产露脸精品国产 | 少妇bbbb搡bbbb桶 | 国产精品一区二区精品视频免费看 | 国产一区二区不卡视频 | 久艹视频在线观看 | 婷婷色综合 | 欧美日韩高清一区二区 国产亚洲免费看 | 亚洲欧美综合 | 国产黄色片免费看 | 久久99久久精品 | 婷婷久久综合九色综合 | 四虎成人网 | 一区二区中文字幕在线观看 | 午夜成人影视 | 亚洲视频在线观看网站 | 九九热1 | 日韩精品一二三 | 国产99re| 日韩亚洲在线 | 一区二区三区精品在线 | 狠狠色丁香久久婷婷综合五月 | 免费看片网址 | 欧美一级片免费播放 | 国产成人精品一区二区三区在线观看 | 911久久香蕉国产线看观看 | 欧美黄色高清 | 91精品视频免费看 | 国产涩图 | 久草爱视频 | 成人福利在线观看 | 91精品国自产在线观看 | 国产午夜精品免费一区二区三区视频 | 五月天激情视频在线观看 | 欧美一级片免费观看 | 日韩高清在线不卡 | 日本在线精品视频 | 国产精品久久久免费 | 99精品视频免费全部在线 | 激情在线网| 又黄又爽的视频在线观看网站 | 国产精品porn | 免费黄色激情视频 | 天天射狠狠干 | 日韩有码在线播放 | 深夜免费小视频 | 亚洲 欧美 另类人妖 | 国产九九精品 | 成人av久久| 久久激情视频 久久 | 69av在线视频| 欧美国产精品一区二区 | 超碰97人人射妻 | 亚洲三级黄色 | 97看片| 日韩中文在线视频 | 色婷婷天天干 | 天堂网中文在线 | 免费高清看电视网站 | 99 视频 高清| 欧美日韩视频 | 欧美精品久久久久久久久免 | 香蕉视频亚洲 | 免费a网站 | 91香蕉嫩草 | 亚洲精品国内 | 国内精品久久久 | 日韩福利在线观看 | 免费看一级一片 | 免费无遮挡动漫网站 | 国产成本人视频在线观看 | 日日干精品 | 亚洲精选国产 | av丁香 | 久久精品老司机 | 激情文学丁香 | 人人爽人人爽人人片 | 国产片免费在线观看视频 | 国产裸体无遮挡 | 国产精品成人aaaaa网站 | 欧洲一区二区三区精品 | 日韩色视频在线观看 | 国产一区二区三精品久久久无广告 | 麻豆精品在线 | 日韩视频一区二区三区 | 91久久精品一区二区三区 | 免费在线观看毛片网站 | 久草视频观看 | 超碰在线成人 | 99热最新地址 | 国产香蕉在线 | av在线电影网站 | 亚洲午夜小视频 | 91探花在线 | 在线观看理论 | 精品婷婷| 色www免费视频 | 亚洲在线网址 | 国产精品一区一区三区 | 一区二区三区视频网站 | 国产免费高清视频 | 久久久91精品国产一区二区精品 | 欧美另类tv| av在线播放快速免费阴 | 九九综合久久 | 国产色秀视频 | 亚洲精品tv| 欧美激情综合五月 | 日日爽天天爽 | 久久久久免费精品国产小说色大师 | 亚洲四虎影院 | 国产在线黄色 | 欧美在线视频日韩 | 丁香婷婷激情 | 一区二区视 | 2018亚洲男人天堂 | 91免费视频网站在线观看 | 青青河边草免费 | 久久免费久久 | 亚洲精品欧美精品 | 欧美日韩精品久久久 | 中文字幕在线视频精品 | 麻豆视频一区二区 | 色偷偷888欧美精品久久久 | 亚洲精品字幕 | 91成熟丰满女人少妇 | 久久国产视频网 | 娇妻呻吟一区二区三区 | 国产91大片 | 日韩精品久久久久久久电影竹菊 | 日日夜夜精品网站 | 免费一级片在线 | 精品在线小视频 | 夜色在线资源 | 五月天六月婷婷 | 成年人免费在线观看网站 | 久久精品三级 | av在线等 | 少妇高潮流白浆在线观看 | 国产在线97 | 日韩久久网站 | 午夜在线观看一区 | 丰满少妇高潮在线观看 | 狠狠ri| 最新中文字幕在线观看视频 | 最新av网站在线观看 | 色婷婷av一区二 | 国产黄免费 | 五月婷婷六月丁香在线观看 | 免费av在线网站 | 色a综合 | av中文字幕在线播放 | 日韩av不卡播放 | 日韩激情免费视频 | 国产女人18毛片水真多18精品 | 麻豆91小视频| 97视频资源 | 在线免费视频你懂的 | 99精品热视频只有精品10 | 日韩久久电影 | 在线天堂v | 国产高清综合 | 综合久久婷婷 | 国产精品日韩高清 | 日韩羞羞 | 久久精品久久精品久久精品 | 日韩在线免费电影 | 久久久久女教师免费一区 | 日韩精品久久久久久 | 黄色毛片视频免费 | 超薄丝袜一二三区 | 人人爽人人射 | 啪啪动态视频 | av黄色国产 | 色视频在线观看免费 | 日韩区欧美久久久无人区 | 免费特级黄色片 | 久草视频在线观 | 中文字幕日韩免费视频 | 久久国产品 | 国产在线精品一区二区三区 | 日韩av看片 | 色妞久久福利网 | 久久综合久久综合久久 | 香蕉视频18| 色综合久久中文综合久久牛 | 伊人丁香 | 99久久精品免费视频 | 2021国产在线视频 | 久草视频在线新免费 | 天天干天天射天天爽 | www.com操| 久久精品专区 | 国色综合 | 久精品在线 | 蜜臀av性久久久久蜜臀aⅴ涩爱 | 国产精品成人a免费观看 | 久久伦理视频 | 国产成本人视频在线观看 | 亚洲狠狠婷婷 | 亚洲精品字幕在线观看 | 日本激情视频中文字幕 | 久久久国产在线视频 | 在线影视 一区 二区 三区 | 久久av电影 | 成人在线观看网址 | 草樱av| 中文字幕在线免费观看 | 成人性生交大片免费观看网站 | 国产视频精品久久 | av三级av | 伊人日日干 | 中文字幕欧美三区 | 69久久夜色精品国产69 | 丁香资源影视免费观看 | 日日干天天射 | 看国产黄色大片 | www.五月婷| 亚洲精品久久久久久久不卡四虎 | 黄色一集片 | 日本精品视频一区二区 | 精品少妇一区二区三区在线 | av在线网站大全 | 伊人av综合 | 国内揄拍国产精品 | 中文字幕日韩av | 在线小视频 | 91超碰在线播放 | 国产精品系列在线播放 | 视频三区 | 国产91成人在在线播放 | 天天色棕合合合合合合 | 国产精品刺激对白麻豆99 | 黄毛片在线观看 | 狠狠躁夜夜av | 久久久久久久久久久成人 | 91精品资源 | 国产在线色视频 | 六月丁香激情综合 | 99免费在线播放99久久免费 | 伊甸园永久入口www 99热 精品在线 | 成人免费在线观看av | 免费在线观看av不卡 | 久久免费黄色大片 | 国产自在线观看 | 国产在线视频一区 | 亚洲精品国产精品国自产观看 | 亚洲精品在线免费 | 国产xx在线 | 国产精品美女久久久久久久久 | 国产伦精品一区二区三区在线 | 99精品视频在线观看免费 | 在线国产激情视频 | 999视频精品 | 韩国av电影在线观看 | av福利超碰网站 | 最新日韩精品 | 黄色动态图xx | 国产精品电影在线 | 国产成人一区二区三区免费看 | 特级大胆西西4444www | 手机在线日韩视频 | 人人爽人人爽人人爽学生一级 | 亚洲日本国产 | 涩涩网站在线观看 | 久久在线免费 | 久久短视频 | 欧美日韩在线观看一区 | 97电影院网| 国产99久久精品一区二区永久免费 | 99999精品 | 亚洲第一区在线播放 | 9免费视频 | 久久久久在线观看 | 成人羞羞免费 | 日韩精品一区二区三区水蜜桃 | 免费精品在线观看 | 99免在线观看免费视频高清 | 伊人天天操 | 久久久在线免费观看 | 九九九电影免费看 | 欧美精品少妇xxxxx喷水 | 欧美一区免费在线观看 | 久操视频在线观看 | 一区三区视频在线观看 | 日韩欧美高清一区二区三区 | 国产婷婷vvvv激情久 | 在线a视频免费观看 | 国产二区视频在线观看 | www狠狠操| japanesexxxhd奶水| 91av视频网站 | 亚洲午夜精品久久久久久久久久久久 | 在线久热 | 欧美日韩国产欧美 | 精品久久久久久亚洲综合网站 | 国产流白浆高潮在线观看 | 正在播放一区二区 | 最近中文字幕大全中文字幕免费 | 中文字幕日韩一区二区三区不卡 | 亚洲精品视频二区 | 久久99视频免费 | 国产精品91一区 | 亚洲婷婷在线 | 日日夜色| 精品福利av | 国产成人一二三 | 成人动态视频 | 999色视频 | 天天综合天天综合 | 精品在线观看免费 | 九九九九九九精品任你躁 | 亚洲精品h| 亚洲国产成人精品在线 | 国产免费二区 | 激情影院在线观看 | 超碰97人人在线 | 国产丝袜高跟 | 亚洲精品乱码久久久久久高潮 | 最近中文字幕国语免费av | 九九九热精品免费视频观看 | 欧美ⅹxxxxxx | 日精品| 国产 亚洲 欧美 在线 | 亚洲 欧洲 国产 精品 | 国产一区精品在线 | 蜜臀久久99精品久久久无需会员 | 开心婷婷色 | 久久五月激情 | 欧美日韩国产亚洲乱码字幕 | 日韩91精品 | 成人黄色av免费在线观看 | 国产又粗又猛又爽又黄的视频免费 | 久久精品视频国产 | 在线观看黄色免费视频 | 韩国av永久免费 | 国产精品一区二区av日韩在线 | 国产免费一区二区三区最新6 | 久久亚洲欧美日韩精品专区 | 亚洲成人999 | 麻豆一区二区 | 久草免费在线视频观看 | 国产手机在线观看 | 中文字幕在线观看免费高清电影 | 欧美日韩精品二区第二页 | 久久久久久久国产精品影院 | 中文在线字幕观看电影 | 麻豆91精品 | 99久久久久成人国产免费 | 中文字幕综合在线 | 视频直播国产精品 | www亚洲精品 | 欧美视频在线二区 | 国外成人在线视频网站 | 成人免费观看电影 | 亚洲国产成人精品在线 | 九九免费在线观看 | 一区二区不卡视频在线观看 | 天天操天天色天天 | 91精品在线观看视频 | 亚洲国产经典视频 | www久久久久| 欧美大片在线观看一区 | 五月综合色 | 韩日精品在线 | 日本中文字幕高清 | 亚洲国产精品第一区二区 | 国产精品嫩草影院99网站 | 日韩女同一区二区三区在线观看 | av不卡免费看 | 91成人免费视频 | 日韩av一区二区三区 | 中文字幕在线观看你懂的 | 嫩小bbbb摸bbb摸bbb | 久久久久久久99 | 51精品国自产在线 | 国产色资源 | 人人爽人人干 | 国产一区二区在线影院 | 久久66热这里只有精品 | 精品综合久久久 | 欧美日韩高清一区二区三区 | 国产精品系列在线 | 天天艹天天 | 日韩在线短视频 | av在线在线 | 久久精品国产99 | 91av网址| 欧美日韩高清不卡 | 美女视频黄频大全免费 | 国产一级特黄毛片在线毛片 | 中国精品少妇 | 91最新在线观看 | 最近最新中文字幕 | 伊人宗合| 国产高清不卡av | www.久久色| 爱色av.com | 日韩激情免费视频 | 操操操综合 | 精品一区 在线 | 欧美精品一区二区免费 | 亚洲一区不卡视频 | 欧洲精品亚洲精品 | 最近日本韩国中文字幕 | 久久中文字幕导航 | 国产精品嫩草在线 | 黄色福利视频网站 | 日日夜夜天天久久 | 日韩午夜大片 | 国产一区二区精品久久 | 91av视频导航| 天天插天天色 | 爱爱av网 | 免费黄色在线网址 | 97电影在线观看 | 99热这里只有精品国产首页 | 日本论理电影 | 狠狠久久综合 | 国产一区二区三区视频在线 | 国产精品国产三级国产专区53 | 操操操日日| 伊人亚洲综合网 | 成人av资源| 激情综合五月天 | 国产成人在线一区 | 丁香激情视频 | 91在线91拍拍在线91 | 国产91影院 | 国产一级在线观看 | 免费亚洲精品 | av一区二区在线观看中文字幕 | 色综合久久88色综合天天免费 | 欧美性天天 | 色综合网在线 | 在线av资源 | 国产精品9999久久久久仙踪林 | 成人av播放 | 色综合天 | 国产精品免费久久久久 | 久久五月激情 | 久草com| 欧美久久久久久久久久久久久 | 99久久爱 | 亚洲精品小区久久久久久 | 国产成人333kkk | 中文字幕在线观看第二页 | 亚州av网站大全 | 日本资源中文字幕在线 | av解说在线观看 | 亚洲欧美少妇 | 91精品视频在线看 | 亚洲一级影院 | 国产精品原创视频 | 九九视频在线播放 | 久久免费视频99 | 色视频 在线 | 91看片麻豆| 欧美动漫一区二区三区 | 五月天中文字幕 | 99亚洲国产精品 | 亚洲va天堂va欧美ⅴa在线 | 性色av香蕉一区二区 | 久久在线视频在线 | 久久99精品久久只有精品 | 婷婷五情天综123 | 日韩一区二区三区高清在线观看 | 国产成人三级在线播放 | 欧美动漫一区二区三区 | 国产精品国产三级国产aⅴ9色 | 日韩欧美视频在线观看免费 | 国产精品久久久久国产精品日日 | 久久亚洲人 | 午夜精品福利一区二区 | 国产精品福利无圣光在线一区 | 五月天久久久久久 | 国产精品v a免费视频 | 亚洲综合成人av | av网站免费线看精品 | 狠狠激情中文字幕 | 日韩一级电影在线 | 在线看片成人 | 91看片一区二区三区 | 国产一二三四在线观看视频 | 91看片淫黄大片在线播放 | 日韩午夜在线观看 | 最近中文字幕国语免费av | av黄色一级片| 色噜噜在线观看 | 国产免费午夜 | 人人狠狠综合久久亚洲 | 美女视频黄网站 | 91秒拍国产福利一区 | 欧美日韩中文在线 | 久久久久国产精品免费免费搜索 | 美女久久视频 | 国产精品免费视频久久久 | 午夜精品一区二区三区免费 | 四虎影视成人永久免费观看视频 | av丝袜制服 | 在线免费av播放 | 在线视频 成人 | 国产精品乱码久久久久久1区2区 | 天天色天天色天天色 | 91精品欧美| 人人射人人插 | 91福利视频网站 | 91视频免费网站 | 黄色小说视频网站 | 91麻豆国产福利在线观看 | 国产区在线看 | 美女视频黄免费的 | 狠狠色丁香婷婷综合最新地址 | 日韩中文字幕视频在线观看 | 天天色婷婷| 日韩久久激情 | 91热精品 | 在线视频你懂 | 九九在线高清精品视频 | 精品天堂av | 黄av免费在线观看 | 99热精品国产一区二区在线观看 | 中文字幕免费高清 | 四虎成人精品永久免费av | 精品99久久| www.天天草 | 精品国产一区二区三区久久久 | 亚洲国产日韩在线 | 91精品视频在线 | 欧美精品乱码99久久影院 | a v在线观看 | 国产高清中文字幕 | 国偷自产中文字幕亚洲手机在线 | 五月天国产 | 亚洲国产三级 | 亚洲黄色一级视频 | 香蕉视频在线视频 | 91av在线视频免费观看 | www天天干| 高清精品视频 | 国内揄拍国产精品 | 97超碰中文 | 美女视频黄的免费的 | 99久久婷婷国产精品综合 | 成人一级片免费看 | 精品国产一区二区三区四区在线观看 | 国产麻豆精品一区二区 | 欧美激情综合五月色丁香 | 国产一区二区不卡视频 | 国产视频精品久久 | 最新日韩视频在线观看 | 亚洲黄色激情小说 | 天天色天天射天天综合网 | 在线看黄网站 | 亚洲精品一区二区精华 | 成人av影视观看 | 亚洲第一区在线观看 | 粉嫩av一区二区三区四区五区 | 久久九九久久 | 天堂av最新网址 | 亚洲狠狠婷婷 | 日韩av一区二区三区 | 亚洲涩涩色 | 亚洲六月丁香色婷婷综合久久 | 综合色站导航 | 色综合久久久 | 精品国产精品久久一区免费式 | 日本性生活一级片 | 91免费高清视频 | 国产 欧美 日产久久 | 天天爽天天碰狠狠添 | 久久精品毛片 | 96视频免费在线观看 | 福利视频网址 | 中文字幕久久精品亚洲乱码 | 国产精品久久久久久模特 | 成人av免费网站 | 国产成在线观看免费视频 | 一级久久精品 | 欧美激情综合色综合啪啪五月 | 亚洲综合一区二区精品导航 | 中文字幕资源网 国产 | www.com.黄| 午夜丰满寂寞少妇精品 | 久久亚洲视频 | 97国产人人 | 夜夜操网站 | 国产成人黄色在线 | 国产福利精品视频 | 91久久人澡人人添人人爽欧美 | 最近av在线 | 欧美激情精品久久久久久变态 | 国产在线观看午夜 | 黄色www在线观看 | 亚洲精品免费观看视频 | 夜夜夜影院| 日韩啪啪小视频 | 国产精品自在线拍国产 | 一级免费黄色 | 日韩网站视频 | 青青河边草免费直播 | 亚洲国产大片 | 欧美另类一二三四区 | 天天干天天操天天爱 | 在线观看黄网 | 免费久久久久久 | a黄色一级| 日本中文字幕在线一区 | 国产一区二区在线视频观看 | 91亚洲精品国偷拍自产在线观看 | 成x99人av在线www | 欧美国产日韩一区二区 | 久久久www成人免费毛片 | 免费黄色激情视频 | 国产美女在线免费观看 | 国产视频每日更新 | 五月婷婷亚洲 | 日韩成人黄色 | 亚洲人成在线电影 | 免费在线观看日韩 | 国产免费三级在线观看 | 久久综合狠狠 | 综合成人在线 | av一区二区三区在线播放 | 东方av在线免费观看 | 国产大陆亚洲精品国产 | 五月综合| 国产情侣一区 | 婷婷丁香视频 | 国产成人在线一区 | 久久精品综合一区 | 久久中文字幕视频 | 韩日电影在线免费看 | 国产精品永久免费在线 | 五月天综合激情网 | 久久久免费国产 | 久久草视频| 97免费在线观看 | 女女av在线| 97人人超碰在线 | 欧美精彩视频在线观看 | 久久在现 | 久久av影视 | 国产亚洲久一区二区 | 丁香色综合 | 国产精品九九九 | av中文电影| 天天曰 | 开心激情网五月天 | 99草视频| 丁香九月婷婷综合 | 国产精品久久伊人 | 国产精彩视频一区二区 | 91在线视频观看 |