mpi

这段代码展示了如何使用OpenCV读取视频,处理为浮点型数据,并利用MPI索引来读取MAT文件中特定相机的关节数据。MAT文件由`get_file_names`函数遍历指定目录获取,然后按MPI索引提取特定相机的注解数据。最后,根据MPI索引和序列号,构建并打印出对应视频文件的路径。
摘要由CSDN通过智能技术生成
import scipy.io as scio
import os
import math
import cv2
import numpy as np

def read_video(video_path):
    cap = cv2.VideoCapture(video_path)
    wid = int(cap.get(3))
    hei = int(cap.get(4))
    framerate = int(cap.get(5))
    framenum = int(cap.get(7))
    print(framerate)
    print(framenum)

    video = np.zeros((framenum, hei, wid, 3), dtype='float16')
    cnt = 0
    while (cap.isOpened()):
        a, b = cap.read()
        print(type(b))
        if b is not None:
            b = b.astype('float16') / 255
            video[cnt] = b
        else:
            break
        cnt += 1

    print(video.shape)


def get_file_names(file_dir, extension):
    file_names = []
    for root, dirs, files in os.walk(file_dir):
        for _file in files:
            if os.path.splitext(_file)[-1] == extension:
                file_names.append(_file)
    return file_names



def mpi(indnum):
    dir_path='/home/passwordis1/Desktop/MOCAP-mpi/'
    mat_file_names =get_file_names(dir_path,'.mat')
    print(mat_file_names)
    mpi_index = [0,1,2,4,5,6,7,8]
    print (mpi_index)
    mpi_annot =[]
    for name in mat_file_names:

        file_path = dir_path + name

        data = scio.loadmat(file_path)

        for i in range(0,8):
            camera_num = mpi_index[i]
            anoot_for_camera_num = data['annot3'][camera_num]
            joint_for_camera_num = anoot_for_camera_num[0]

            mpi_annot.append(joint_for_camera_num)
    print(len(mpi_annot))
    print(mpi_annot[0].shape)
    print(mpi_annot[127].shape)

    number = indnum%8
    seqnum = int(math.floor(indnum/8))
    print(number,seqnum)
    prefixion = mat_file_names[seqnum][0:3]
    print(prefixion)

    video_name = prefixion +'Video_' + str(mpi_index[number-1])+'.avi'
    video_path = os.path.join(dir_path,video_name)
    print(video_path)

mpi(10)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值