| | |
| | |
| | |
| | |
| | |
| | |
| |
|
| | import sys |
| |
|
| | sys.path.append(".") |
| |
|
| | import os |
| | import pdb |
| | import time |
| | import traceback |
| |
|
| | import ipdb |
| | import numpy as np |
| | from tqdm import tqdm |
| |
|
| | from engine.NormalEstimator.Sapiens.interface import interface |
| |
|
| |
|
| | def basename(path): |
| | pre_name = os.path.basename(path).split(".")[0] |
| |
|
| | return pre_name |
| |
|
| |
|
| | def multi_process(worker, items, **kwargs): |
| | """ |
| | worker worker function to process items |
| | """ |
| |
|
| | nodes = kwargs["nodes"] |
| | dirs = kwargs["dirs"] |
| |
|
| | bucket = int( |
| | np.ceil(len(items) / nodes) |
| | ) |
| |
|
| | print("Total Nodes:", nodes) |
| | print("Save Path:", dirs) |
| | rank = int(os.environ.get("RANK", 0)) |
| |
|
| | print("Current Rank:", rank) |
| |
|
| | kwargs["RANK"] = rank |
| |
|
| | if rank == nodes - 1: |
| | output_dir = worker(items[bucket * rank :], **kwargs) |
| | else: |
| | output_dir = worker(items[bucket * rank : bucket * (rank + 1)], **kwargs) |
| |
|
| | if rank == 0 and nodes > 1: |
| | time_sleep = kwargs.get("timesleep", 7200) |
| | time.sleep(time_sleep) |
| |
|
| |
|
| | def run_normal(items, **params): |
| | output_dir = params["dirs"] |
| | debug = params["debug"] |
| | os.makedirs(output_dir, exist_ok=True) |
| |
|
| | if debug: |
| | items = items[:1] |
| |
|
| | process_valid = [] |
| |
|
| | for item in tqdm(items, desc="Processing..."): |
| | if not os.path.isdir(item): |
| | continue |
| |
|
| | print(f"processing img dir {item}") |
| | basename_folder = basename(item) |
| | img_folder = item |
| | mask_folder = item.replace("mvs_render", "mvs_sam") |
| | normal_folder = item.replace("mvs_render", "mvs_normal") |
| |
|
| | if os.path.exists(normal_folder): |
| | continue |
| |
|
| | interface(img_folder, mask_folder, normal_folder) |
| |
|
| | return output_dir |
| |
|
| |
|
| | def get_parse(): |
| | import argparse |
| |
|
| | parser = argparse.ArgumentParser(description="") |
| | parser.add_argument("-i", "--input", required=True, help="input path") |
| | parser.add_argument("-o", "--output", required=True, help="output path") |
| | parser.add_argument("--nodes", default=1, type=int, help="how many workload?") |
| | parser.add_argument("--debug", action="store_true", help="debug tag") |
| | parser.add_argument("--txt", default=None, type=str) |
| | args = parser.parse_args() |
| | return args |
| |
|
| |
|
| | if __name__ == "__main__": |
| | opt = get_parse() |
| |
|
| | |
| | if opt.txt == None: |
| | available_items = os.listdir(opt.input) |
| | available_items = [os.path.join(opt.input, item) for item in available_items] |
| | else: |
| | available_items = [] |
| | with open(opt.txt) as reader: |
| | for line in reader: |
| | available_items.append(line.strip()) |
| |
|
| | available_items = [ |
| | os.path.join(opt.input, item.split(".")[0]) for item in available_items |
| | ] |
| |
|
| | multi_process( |
| | worker=run_normal, |
| | items=available_items, |
| | dirs=opt.output, |
| | nodes=opt.nodes, |
| | debug=opt.debug, |
| | ) |
| |
|