import os
import sys
import tqdm
import cv2
import numpy as np
sys.path.append(r"./pytorch-ssd")
from vision.ssd.data_preprocessing import PredictionTransform
def preprocess(src_path, save_path):
if not os.path.exists(save_path):
os.mkdir(save_path)
image_size = 300
image_mean = np.array([127, 127, 127])
image_std = 128.0
transform = PredictionTransform(image_size, image_mean, image_std)
in_files = os.listdir(src_path)
for file in tqdm.tqdm(in_files):
input_image = cv2.imread(os.path.join(src_path, file))
input_image = cv2.cvtColor(input_image, cv2.COLOR_BGR2RGB)
input_tensor = transform(input_image)
img = np.array(input_tensor).astype(np.float32)
img.tofile(os.path.join(save_path, file.split('.', 1)[0] + ".bin"))
if __name__ == "__main__":
import argparse
parser = argparse.ArgumentParser('data preprocess.')
parser.add_argument('--src_path', type=str, required=True,
help='path to original dataset.')
parser.add_argument('--save_path', type=str, required=True,
help='a directory to save bin files.')
args = parser.parse_args()
preprocess(args.src_path, args.save_path)