當前位置: 首頁>>代碼示例>>Python>>正文


Python png.Reader方法代碼示例

本文整理匯總了Python中png.Reader方法的典型用法代碼示例。如果您正苦於以下問題:Python png.Reader方法的具體用法?Python png.Reader怎麽用?Python png.Reader使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在png的用法示例。


在下文中一共展示了png.Reader方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: flow_read_png

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def flow_read_png(fpath):
    """
    Read KITTI optical flow, returns u,v,valid mask

    """
    if not has_png:
        print('Error. Please install the PyPNG library')
        return

    R = png.Reader(fpath)
    width,height,data,_ = R.asDirect()
    # This only worked with python2.
    #I = np.array(map(lambda x:x,data)).reshape((height,width,3))
    I = np.array([x for x in data]).reshape((height,width,3))
    u_ = I[:,:,0]
    v_ = I[:,:,1]
    valid = I[:,:,2]

    u = (u_.astype('float64')-2**15)/64.0
    v = (v_.astype('float64')-2**15)/64.0

    return u,v,valid 
開發者ID:anuragranj,項目名稱:cc,代碼行數:24,代碼來源:flow_io.py

示例2: load_png

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def load_png(file_path):
    """
    Read from KITTI .png file
    Args:
        file_path string: file path(absolute)
    Returns:
        data (numpy.array): data of image in (Height, Width, 3) layout
    """
    flow_object = png.Reader(filename=file_path)
    flow_direct = flow_object.asDirect()
    flow_data = list(flow_direct[2])
    (w, h) = flow_direct[3]['size']

    flow = np.zeros((h, w, 3), dtype=np.float64)
    for i in range(len(flow_data)):
        flow[i, :, 0] = flow_data[i][0::3]
        flow[i, :, 1] = flow_data[i][1::3]
        flow[i, :, 2] = flow_data[i][2::3]

    invalid_idx = (flow[:, :, 2] == 0)
    flow[:, :, 0:2] = (flow[:, :, 0:2] - 2 ** 15) / 64.0
    flow[invalid_idx, 0] = 0
    flow[invalid_idx, 1] = 0

    return flow.astype(np.float32) 
開發者ID:DeepMotionAIResearch,項目名稱:DenseMatchingBenchmark,代碼行數:27,代碼來源:load_flow.py

示例3: read_disp_png

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def read_disp_png(file_name):
    """
    Read optical flow from KITTI .png file
    :param file_name: name of the flow file
    :return: optical flow data in matrix
    """
    image_object = png.Reader(filename=file_name)
    image_direct = image_object.asDirect()
    image_data = list(image_direct[2])
    (w, h) = image_direct[3]['size']
    channel = len(image_data[0]) / w
    flow = np.zeros((h, w, channel), dtype=np.uint16)
    for i in range(len(image_data)):
        for j in range(channel):
            flow[i, :, j] = image_data[i][j::channel]
    return flow[:, :, 0] / 256 
開發者ID:anuragranj,項目名稱:cc,代碼行數:18,代碼來源:flowlib.py

示例4: read_png_file

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def read_png_file(flow_file):
    """
    Read from KITTI .png file
    :param flow_file: name of the flow file
    :return: optical flow data in matrix
    """
    flow_object = png.Reader(filename=flow_file)
    flow_direct = flow_object.asDirect()
    flow_data = list(flow_direct[2])
    (w, h) = flow_direct[3]['size']
    print("Reading %d x %d flow file in .png format" % (h, w))
    flow = np.zeros((h, w, 3), dtype=np.float64)
    for i in range(len(flow_data)):
        flow[i, :, 0] = flow_data[i][0::3]
        flow[i, :, 1] = flow_data[i][1::3]
        flow[i, :, 2] = flow_data[i][2::3]

    invalid_idx = (flow[:, :, 2] == 0)
    flow[:, :, 0:2] = (flow[:, :, 0:2] - 2 ** 15) / 64.0
    flow[invalid_idx, 0] = 0
    flow[invalid_idx, 1] = 0
    return flow 
開發者ID:anuragranj,項目名稱:cc,代碼行數:24,代碼來源:flowlib.py

示例5: read_flow_png

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def read_flow_png(flow_file):
    """
    Read optical flow from KITTI .png file
    :param flow_file: name of the flow file
    :return: optical flow data in matrix
    """
    flow_object = png.Reader(filename=flow_file)
    flow_direct = flow_object.asDirect()
    flow_data = list(flow_direct[2])
    (w, h) = flow_direct[3]['size']
    flow = np.zeros((h, w, 3), dtype=np.float64)
    for i in range(len(flow_data)):
        flow[i, :, 0] = flow_data[i][0::3]
        flow[i, :, 1] = flow_data[i][1::3]
        flow[i, :, 2] = flow_data[i][2::3]

    invalid_idx = (flow[:, :, 2] == 0)
    flow[:, :, 0:2] = (flow[:, :, 0:2] - 2 ** 15) / 64.0
    flow[invalid_idx, 0] = 0
    flow[invalid_idx, 1] = 0
    return flow 
開發者ID:ChenyangLEI,項目名稱:Fully-Automatic-Video-Colorization-with-Self-Regularization-and-Diversity,代碼行數:23,代碼來源:myflowlib.py

示例6: accept

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def accept(self, path, ext, operator):
        if operator == "resize":
            return 'NG'
        elif operator == "save":
            return 'OK'
        else:
            if ext == '.png':
                f = path if hasattr(path, "read") else open(path, "rb")

                r = png.Reader(file=f)
                width, height, pixels, metadata = r.asDirect()
                f.seek(0)
                bit_depth = metadata.get("bitdepth")

                if bit_depth not in [8, 16]:
                    return "NG"
                else:
                    return "Recommended"
            else:
                return "NG" 
開發者ID:sony,項目名稱:nnabla,代碼行數:22,代碼來源:pypng_backend.py

示例7: load_images

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def load_images(path, ID):
    
    """
    Load a color and a depth image by path and image ID 

    """
    global camera_intrinsics
    
    img_file = path + 'JPEGImages/%s.jpg' % (ID*LABEL_INTERVAL)
    cad = cv2.imread(img_file)

    depth_file = path + 'depth/%s.png' % (ID*LABEL_INTERVAL)
    reader = png.Reader(depth_file)
    pngdata = reader.read()
    # depth = np.vstack(map(np.uint16, pngdata[2]))
    depth = np.array(tuple(map(np.uint16, pngdata[2])))
    pointcloud = convert_depth_frame_to_pointcloud(depth, camera_intrinsics)


    return (cad, pointcloud) 
開發者ID:F2Wang,項目名稱:ObjectDatasetTools,代碼行數:22,代碼來源:compute_gt_poses.py

示例8: read_png_file

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def read_png_file(flow_file):
    """
    Read from KITTI .png file
    :param flow_file: name of the flow file
    :return: optical flow data in matrix
    """
    flow_object = png.Reader(filename=flow_file)
    flow_direct = flow_object.asDirect()
    flow_data = list(flow_direct[2])
    (w, h) = flow_direct[3]['size']
    print "Reading %d x %d flow file in .png format" % (h, w)
    flow = np.zeros((h, w, 3), dtype=np.float64)
    for i in range(len(flow_data)):
        flow[i, :, 0] = flow_data[i][0::3]
        flow[i, :, 1] = flow_data[i][1::3]
        flow[i, :, 2] = flow_data[i][2::3]

    invalid_idx = (flow[:, :, 2] == 0)
    flow[:, :, 0:2] = (flow[:, :, 0:2] - 2 ** 15) / 64.0
    flow[invalid_idx, 0] = 0
    flow[invalid_idx, 1] = 0
    return flow 
開發者ID:yzcjtr,項目名稱:GeoNet,代碼行數:24,代碼來源:flowlib.py

示例9: read_png_flow

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def read_png_flow(flow_file):
    flow_object = png.Reader(filename=flow_file)
    flow_direct = flow_object.asDirect()
    flow_data = list(flow_direct[2])
    (w, h) = flow_direct[3]['size']
    flow = np.zeros((h, w, 3), dtype=np.float64)
    for i in range(len(flow_data)):
        flow[i, :, 0] = flow_data[i][0::3]
        flow[i, :, 1] = flow_data[i][1::3]
        flow[i, :, 2] = flow_data[i][2::3]

    invalid_idx = (flow[:, :, 2] == 0)
    flow[:, :, 0:2] = (flow[:, :, 0:2] - 2 ** 15) / 64.0
    flow[invalid_idx, 0] = 0
    flow[invalid_idx, 1] = 0
    return flow[:, :, 0:2], (1 - invalid_idx * 1)[:, :, None] 
開發者ID:visinf,項目名稱:irr,代碼行數:18,代碼來源:kitti_combined.py

示例10: load_depth

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def load_depth(path):
    # PyPNG library is used since it allows to save 16-bit PNG
    r = png.Reader(filename=path)
    im = np.vstack(map(np.uint16, r.asDirect()[2])).astype(np.float32)
    # itertools.imap is removed in py3
    return im 
開發者ID:meiqua,項目名稱:patch_linemod,代碼行數:8,代碼來源:inout.py

示例11: load_depth

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def load_depth(path):
    # PyPNG library is used since it allows to save 16-bit PNG
    r = png.Reader(filename=path)
    im = np.vstack(itertools.imap(np.uint16, r.asDirect()[2])).astype(np.float32)
    return im 
開發者ID:thodan,項目名稱:sixd_toolkit,代碼行數:7,代碼來源:inout.py

示例12: load

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def load(image, filename):
        """load a PNG file"""
        reader = png.Reader(filename=filename)
        image.width, image.height, pixels, _ = reader.asRGBA8()
        image.pixels = Image.create_array(image.width, image.height)
        index = 0
        for row in pixels:
            for r, g, b, α in zip(row[::4], row[1::4], row[2::4], row[3::4]):
                image.pixels[index] = Image.color_for_argb(α, r, g, b)
                index += 1 
開發者ID:lovexiaov,項目名稱:python-in-practice,代碼行數:12,代碼來源:Png.py

示例13: load_im

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def load_im(path):
    im = scipy.misc.imread(path)

    # Using PyPNG
    # r = png.Reader(filename=path)
    # im = np.vstack(itertools.imap(np.uint8, r.asDirect()[2]))

    return im 
開發者ID:meiqua,項目名稱:patch_linemod,代碼行數:10,代碼來源:inout.py

示例14: read_png_file

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def read_png_file(filepath):
    data = png.Reader(filename=filepath).asRGBA8()
    width = data[0]
    height = data[1]
    rows = list(data[2])
    return width, height, rows 
開發者ID:appleseedhq,項目名稱:blenderseed,代碼行數:8,代碼來源:runtestsuite.py

示例15: open_flow_png_file

# 需要導入模塊: import png [as 別名]
# 或者: from png import Reader [as 別名]
def open_flow_png_file(file_path_list):
    # Funtion from Kilian Merkelbach.
    # Decode the information stored in the filename
    flow_png_info = {}
    assert len(file_path_list) == 2
    for file_path in file_path_list:
        file_token_list = os.path.splitext(file_path)[0].split("_")
        minimal_value = int(file_token_list[-1].replace("minimal", ""))
        flow_axis = file_token_list[-2]
        flow_png_info[flow_axis] = {'path': file_path,
                                    'minimal_value': minimal_value}

    # Open both files and add back the minimal value
    for axis, flow_info in flow_png_info.items():
        import png
        png_reader = png.Reader(filename=flow_info['path'])
        flow_2d = np.vstack(map(np.uint16, png_reader.asDirect()[2]))

        # Add the minimal value back
        flow_2d = flow_2d.astype(np.int16) + flow_info['minimal_value']

        flow_png_info[axis]['flow'] = flow_2d

    # Combine the flows
    flow_x = flow_png_info['x']['flow']
    flow_y = flow_png_info['y']['flow']
    flow = np.stack([flow_x, flow_y], 2)

    return flow 
開發者ID:tobiasfshr,項目名稱:MOTSFusion,代碼行數:31,代碼來源:import_utils.py


注:本文中的png.Reader方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。