IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> 无人驾驶信号灯 -> 正文阅读

[人工智能]无人驾驶信号灯

环境准备

本地GPU环境准备

首先介绍在本地使用GPU进行训练的环境准备,首先确保你的电脑中包含算力比较充足的GPU(俗称显卡,推荐GTX1060及以上级别),使用Ubuntu或者其他Linux发行版本的系统,安装好CUDA和CUDNN,安装tensorflow-gpu和其他环境:
pip install tensorflow-gpu
sudo apt-get install protobuf-compiler python-pil python-lxml python-tk
pip install --user Cython
pip install --user contextlib2
pip install --user jupyter
pip install --user matplotlib

git clone https://github.com/cocodataset/cocoapi.git
cd cocoapi/PythonAPI
make
cp -r pycocotools <path_to_tensorflow>/models/research/

git clone https://github.com/tensorflow/models.git

protoc object_detection/protos/*.proto --python_out=.

export PYTHONPATH=$PYTHONPATH:pwd:pwd/slim

#!/usr/bin/env python

import os
import csv
import io
import itertools
import hashlib
import random

import PIL.Image

import tensorflow as tf

from object_detection.utils import label_map_util
from object_detection.utils import dataset_util

import contextlib2
from object_detection.dataset_tools import tf_record_creation_util

ANNOTATION = ‘frameAnnotationsBOX.csv’
FRAMES = ‘frames’

MAP = {
‘go’: ‘green’,
‘goLeft’: ‘green’,
‘stop’: ‘red’,
‘stopLeft’: ‘red’,
‘warning’: ‘yellow’,
‘warningLeft’: ‘yellow’
}

flags = tf.app.flags
flags.DEFINE_string(‘data_dir’, ‘’, ‘Root directory to LISA dataset.’)
flags.DEFINE_string(‘output_path’, ‘’, ‘Path to output TFRecord’)
flags.DEFINE_string(‘label_map_path’, ‘data/lisa_label_map.pbtxt’,
‘Path to label map proto’)
FLAGS = flags.FLAGS

width = None
height = None

def process_frame(label_map_dict, frame):
global width
global height

filename, xmin, ymin, xmax, ymax, classes = frame

if not os.path.exists(filename):
    tf.logging.error("File %s not found", filename)
    return

with tf.gfile.GFile(filename, 'rb') as img:
    encoded_png = img.read()

png = PIL.Image.open(io.BytesIO(encoded_png))
if png.format != 'PNG':
    tf.logging.error("File %s has unexpeted image format '%s'", filename, png.format)
    return

if width is None and height is None:
    width = png.width
    height = png.height
    tf.logging.info('Expected image size: %dx%d', width, height)

if width != png.width or height != png.height:
    tf.logging.error('File %s has unexpected size', filename)
    return
print filename
print classes
key = hashlib.sha256(encoded_png).hexdigest()
labels = [ label_map_dict[c] for c in classes ]
xmin = [ float(x)/width for x in xmin ]
xmax = [ float(x)/width for x in xmax ]
ymin = [ float(y)/height for y in ymin ]
ymax = [ float(y)/height for y in ymax ]

classes = [ c.encode('utf8') for c in classes ]

example = tf.train.Example(features=tf.train.Features(feature={
    'image/height': dataset_util.int64_feature(height),
    'image/width': dataset_util.int64_feature(width),
    'image/filename': dataset_util.bytes_feature(filename.encode('utf8')),
    'image/source_id': dataset_util.bytes_feature(filename.encode('utf8')),
    'image/key/sha256': dataset_util.bytes_feature(key.encode('utf8')),
    'image/encoded': dataset_util.bytes_feature(encoded_png),
    'image/format': dataset_util.bytes_feature('png'.encode('utf8')),
    'image/object/bbox/xmin': dataset_util.float_list_feature(xmin),
    'image/object/bbox/xmax': dataset_util.float_list_feature(xmax),
    'image/object/bbox/ymin': dataset_util.float_list_feature(ymin),
    'image/object/bbox/ymax': dataset_util.float_list_feature(ymax),
    'image/object/class/text': dataset_util.bytes_list_feature(classes),
    'image/object/class/label': dataset_util.int64_list_feature(labels)
}))
return example

def create_frame(root, frame, records):
filename = os.path.join(root, FRAMES, os.path.basename(frame))
if not os.path.exists(filename):
tf.logging.error(“File %s not found”, filename)
return

xmin = []
ymin = []
xmax = []
ymax = []
classes = []

for r in records:
    if r['Annotation tag'] not in MAP:
        continue
    classes.append(MAP[r['Annotation tag']])
    xmin.append(r['Upper left corner X'])
    xmax.append(r['Lower right corner X'])
    ymin.append(r['Upper left corner Y'])
    ymax.append(r['Lower right corner Y'])

yield (filename, xmin, ymin, xmax, ymax, classes)

def process_annotation(root):
tf.logging.info(‘Processing %s’, os.path.join(root, ANNOTATION))
with tf.gfile.GFile(os.path.join(root, ANNOTATION)) as a:
annotation = a.read().decode(‘utf-8’)

with io.StringIO(annotation) as a:
    data = csv.DictReader(a, delimiter=';')
    for key, group in itertools.groupby(data, lambda r: r['Filename']):
        for e in create_frame(root, key, group):
            yield e

def main(_):
label_map_dict = label_map_util.get_label_map_dict(FLAGS.label_map_path)

frames = []
for r, d, f in tf.gfile.Walk(FLAGS.data_dir, in_order=True):
    if ANNOTATION in f:
        del d[:]
        for e in process_annotation(r):
            frames.append(e)
# random.shuffle(frames)

num_shards=30

with contextlib2.ExitStack() as tf_record_close_stack:
    output_tfrecords = tf_record_creation_util.open_sharded_output_tfrecords(
        tf_record_close_stack, FLAGS.output_path, num_shards)

    for index, f in enumerate(frames):
        tf_example = process_frame(label_map_dict, f)

        output_shard_index = index % num_shards
        output_tfrecords[output_shard_index].write(tf_example.SerializeToString())

if name == ‘main’:
tf.logging.set_verbosity(tf.logging.INFO)
tf.app.run()

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2021-12-28 22:55:34  更:2021-12-28 22:55:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:17:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码