zoukankan      html  css  js  c++  java
  • tensorflow高效地推导pb模型,完整代码

    from matplotlib import pyplot as plt
    import numpy as np
    import os
    
    import six.moves.urllib as urllib
    import sys
    import tarfile
    import tensorflow as tf
    import zipfile
    import glob
    from collections import defaultdict
    from io import StringIO
    
    from PIL import Image
    import DrawBox
    import cv2
    from object_detection.utils import label_map_util
    from object_detection.utils import visualization_utils as vis_util
    
    SaveFilename='D:/FasterR-CNNImageTest/11/'
    if not os.path.exists(SaveFilename):
        os.mkdir(SaveFilename)
    with tf.device('/cpu:0'):
        cap = cv2.VideoCapture(0)
        PATH_TO_CKPT = 'pb/frozen_inference_graph.pb'
        PATH_TO_LABELS = os.path.join('dataset', 'pascal_label_map.pbtxt')
        NUM_CLASSES = 2
        # Load a (frozen) Tensorflow model into memory.
        detection_graph = tf.Graph()
        with detection_graph.as_default():
            od_graph_def = tf.GraphDef()
            with tf.gfile.GFile(PATH_TO_CKPT, 'rb') as fid:
                serialized_graph = fid.read()
                od_graph_def.ParseFromString(serialized_graph)
                tf.import_graph_def(od_graph_def, name='')
        label_map = label_map_util.load_labelmap(PATH_TO_LABELS)
        categories = label_map_util.convert_label_map_to_categories(label_map, max_num_classes=NUM_CLASSES,
                                                                    use_display_name=True)
        category_index = label_map_util.create_category_index(categories)
    
    
        def load_image_into_numpy_array(image):
            (im_width, im_height) = image.size
            return np.array(image.getdata()).reshape(
                (im_height, im_width, 3)).astype(np.uint8)
    
    
        # # Detection
        cnt = 0
        PATH_TO_TEST_IMAGES_DIR = 'E:/PythonOpenCVCode/BalanceGeneratePicture/TestSetSaveImage/Test/JPEGImages'
    
        with detection_graph.as_default():
            with tf.Session(graph=detection_graph) as sess:
                # while True:  # for image_path in TEST_IMAGE_PATHS:    #changed 20170825
                # Definite input and output Tensors for detection_graph
                image_tensor = detection_graph.get_tensor_by_name('image_tensor:0')
                # Each box represents a part of the image where a particular object was detected.
                detection_boxes = detection_graph.get_tensor_by_name('detection_boxes:0')
                # Each score represent how level of confidence for each of the objects.
                # Score is shown on the result image, together with the class label.
                detection_scores = detection_graph.get_tensor_by_name('detection_scores:0')
                detection_classes = detection_graph.get_tensor_by_name('detection_classes:0')
                num_detections = detection_graph.get_tensor_by_name('num_detections:0')
                for pidImage in glob.glob(PATH_TO_TEST_IMAGES_DIR + "/*.jpg"):
                    TEST_IMAGE_PATHS = [os.path.join(PATH_TO_TEST_IMAGES_DIR, pidImage)]
                    # Size, in inches, of the output images.
                    IMAGE_SIZE = (12, 8)
                    for image_path in TEST_IMAGE_PATHS:
                        image = Image.open(image_path)
                        # the array based representation of the image will be used later in order to prepare the
                        # result image with boxes and labels on it.
                        image_np = load_image_into_numpy_array(image)
                        # Expand dimensions since the model expects images to have shape: [1, None, None, 3]
                        image_np_expanded = np.expand_dims(image_np, axis=0)
                        # Actual detection.
                        (boxes, scores, classes, num) = sess.run(
                            [detection_boxes, detection_scores, detection_classes, num_detections],
                            feed_dict={image_tensor: image_np_expanded})
                        # Visualization of the results of a detection.
                        # print(boxes)
                        DrawBox.visualize_boxes_and_labels_on_image_array(
                            image_np,
                            np.squeeze(boxes),
                            np.squeeze(classes).astype(np.int32),
                            np.squeeze(scores),
                            category_index,
                            max_boxes_to_draw=400,
                            use_normalized_coordinates=True,
                            groundtruth_box_visualization_color='red',
                            line_thickness=8)
                        #plt.figure(figsize=IMAGE_SIZE)
                        cv2.imwrite(SaveFilename + os.path.basename(image_path), image_np)
                        # plt.imshow(image_np)
                        cnt = cnt + 1
                        print(image_path)
  • 相关阅读:
    Winform 打包,卸载程序制作获取ProductCode
    委托/事件的重写
    反序列化无法找到程序集
    Control.Invoke注意事项
    操作config文件
    MemoEdit自动滚动到结尾
    读取局域网内的共享文件
    命令行卸载程序
    获取执行程序的路径
    SCSF 系列:使用 Visualizer 监控 SCSF 运行状态
  • 原文地址:https://www.cnblogs.com/tangmiao/p/9176503.html
Copyright © 2011-2022 走看看