#!/usr/bin/env bash
set -euo pipefail

SPLIT=${1:-All}
CFG_PATH=${2:-Env_Config/Flat_Object/rigid_scales.json}
POS=${3:-5}

SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
PY_SCRIPT="${SCRIPT_DIR}/Env_StandAlone/Rigid_Vision_Collection.py"
LOG_DIR="${SCRIPT_DIR}/FlatLab/_logs"
mkdir -p "${LOG_DIR}"

ISAACSIM_PY="./isaacsim_4.5.0/python.sh"

declare -A TRAIN_MAP=(
  [Board]="1 2 3"
  [Book]="1 2 3 4"
  [Box]="1 2 3 4"
  [Clock]="1 2"
  [Disk]="1 2 3"
  [Keyboard]="1 2 3"
  [Photo_Album]="1 2"
  [Plate]="1 2 3"
)

declare -A TEST_SEEN_MAP=(
  [Board]="4 5 6"
  [Book]="5 6 7 8"
  [Box]="5 6 7 8"
  [Clock]="3 4"
  [Disk]="4 5 6"
  [Keyboard]="4 5 6"
  [Photo_Album]="3 4"
  [Plate]="4 5 6"
)

declare -A TEST_UNSEEN_MAP=(
  [Chessboard]="1 2 3 4"
  [Cutting_Board]="1 2 3 4 5 6"
  [Laptop]="1 2"
  [Magazine]="1 2 3 4 5 6"
  [Pad]="1 2 3 4 5 6"
  [Painting]="1 2 3 4"
  [Disk_Case]="1 2 3 4"
)

get_scales() {
  local cfg_file="$1" obj_type="$2" obj_index="$3" split="$4"
  "$ISAACSIM_PY" - "$cfg_file" "$obj_type" "$obj_index" "$split" <<PY | \
  grep -E '^[[:space:]]*[-+]?[0-9]*\.?[0-9]+[[:space:]]*,[[:space:]]*[-+]?[0-9]*\.?[0-9]+[[:space:]]*,[[:space:]]*[-+]?[0-9]*\.?[0-9]+[[:space:]]*$' | \
  sed -E 's/[[:space:]]//g'
import json,sys
cfg_path,obj,obj_idx,split=sys.argv[1],sys.argv[2],sys.argv[3],sys.argv[4]
def norm(e):
  if isinstance(e,(int,float)): return [float(e)]*3
  if isinstance(e,(list,tuple)):
    e=list(map(float,e));
    return [e[0],e[1],(e[2] if len(e)>=3 else 0.8)]
  return [0.8,0.8,0.8]
def get_item_node(cfg,obj,obj_idx):
  k=f"{obj}{obj_idx}" if obj_idx else None
  return (cfg.get(k) if k and k in cfg else cfg.get(obj))
try:
  with open(cfg_path,'r',encoding='utf-8') as f: cfg=json.load(f)
except Exception:
  cfg={}
scales=[]
extras=[]
node=get_item_node(cfg,obj,obj_idx)
if isinstance(node,dict):
  if isinstance(node.get(split),list) and node[split]: extras=[norm(x) for x in node[split]]
  elif isinstance(node.get('scales'),list) and node['scales']: extras=[norm(x) for x in node['scales']]

default_scale=[0.8,0.8,0.8]
if split=="Train":
  scales=[default_scale]+extras
else:

  scales=[default_scale]
for s in (scales if scales else [default_scale]):
  print(f"{s[0]},{s[1]},{s[2]}")
PY
}

run_for_map() {
  declare -n MAP_REF=$1
  for OBJ in "${!MAP_REF[@]}"; do
    for IDX in ${MAP_REF[$OBJ]}; do
      log "[RUN] ${SPLIT} -> ${OBJ}${IDX}"
      if [[ "${SPLIT}" == "Train" ]]; then
        idx_num=0
        while IFS= read -r SCALE || [[ -n "$SCALE" ]]; do
          split_dir=$(echo "${SPLIT}" | tr 'A-Z' 'a-z' | sed 's/test_seen/test_seen/; s/test_unseen/test_unseen/; s/train/train/')
          case "${OBJ}" in
            Book|Disk|Plate|Magazine|Pad|Disk_Case)
              strategy_dir="Strategy_A";;
            Box|Board|Keyboard|Photo_Album|Clock|Cutting_Board|Chessboard|Painting|Laptop)
              strategy_dir="Strategy_B";;
            *)
              strategy_dir="Strategy_B";;
          esac
          BASE_DIR="${SCRIPT_DIR}/Data/FlatLab/Data_op_RGB/${split_dir}/${strategy_dir}"
          complete=true
          RGB_DIR="${SCRIPT_DIR}/Data/FlatLab/Data_op_RGB/${split_dir}/${strategy_dir}"
          DEPTH_DIR="${SCRIPT_DIR}/Data/FlatLab/Data_op_Depth/${split_dir}/${strategy_dir}"
          ENV_DIR="${SCRIPT_DIR}/Data/FlatLab/Data_op_PointCloud_Env/${split_dir}/${strategy_dir}"
          OBJ_DIR="${SCRIPT_DIR}/Data/FlatLab/Data_op_PointCloud_Obj/${split_dir}/${strategy_dir}"
          mkdir -p "${RGB_DIR}" "${DEPTH_DIR}" "${ENV_DIR}" "${OBJ_DIR}"
          for i in $(seq 1 ${POS}); do
            stem="${OBJ}_view5_${OBJ}${IDX}_Scale${idx_num}_Position${i}"
            [[ -f "${RGB_DIR}/${stem}_Wood_RGB.png" ]] || complete=false
            [[ -f "${DEPTH_DIR}/${stem}_Wood_Depth.png" ]] || complete=false
            [[ -f "${ENV_DIR}/${stem}_Wood_Env.ply" ]] || complete=false
            [[ -f "${OBJ_DIR}/${stem}_Wood_Obj.ply" ]] || complete=false
          done

          if ${complete}; then
            log "  - scale_idx=${idx_num} "
            idx_num=$((idx_num+1))
            continue
          fi

          log "  - scale_idx=${idx_num} "
          for i in $(seq 1 ${POS}); do
            stem="${OBJ}_view5_${OBJ}${IDX}_Scale${idx_num}_Position${i}"
            rm -f "${RGB_DIR}/${stem}_Wood_RGB.png" \
                  "${DEPTH_DIR}/${stem}_Wood_Depth.png" \
                  "${ENV_DIR}/${stem}_Wood_Env.ply" \
                  "${OBJ_DIR}/${stem}_Wood_Obj.ply" || true
          done

          log "  -  scale_idx=${idx_num} …"
          "$ISAACSIM_PY" "${PY_SCRIPT}" \
            "${OBJ}" "${IDX}" \
            --split "${SPLIT}" \
            --config "${CFG_PATH}" \
            --positions "${POS}" \
            --scale "${SCALE}" \
            --scale-idx "${idx_num}" 2>&1 | tee -a "${LOG_DIR}/run_${SPLIT}.log"

          idx_num=$((idx_num+1))
        done < <(get_scales "${CFG_PATH}" "${OBJ}" "${IDX}" "${SPLIT}")
      else
        SCALE="0.8,0.8,0.8"
        idx_num=0
        split_dir=$(echo "${SPLIT}" | tr 'A-Z' 'a-z' | sed 's/test_seen/test_seen/; s/test_unseen/test_unseen/')
        case "${OBJ}" in
          Book|Disk|Plate|Magazine|Pad|Disk_Case)
            strategy_dir="Strategy_A";;
          Box|Board|Keyboard|Photo_Album|Clock|Cutting_Board|Chessboard|Painting|Laptop)
            strategy_dir="Strategy_B";;
          *)
            strategy_dir="Strategy_B";;
        esac
        BASE_DIR="${SCRIPT_DIR}/Data/FlatLab/Data_op_RGB/${split_dir}/${strategy_dir}"
        complete=true
        for i in $(seq 1 ${POS}); do
          base="${OBJ}_view5_${OBJ}${IDX}_Scale${idx_num}_Position${i}_Wood_RGB"
          [[ -f "${BASE_DIR}/${base}.png" ]] || complete=false
        done

        if ${complete}; then
          log "  - scale_idx=0 "
          continue
        fi

        log "  - scale_idx=0 "
        for i in $(seq 1 ${POS}); do
          base="${OBJ}_view5_${OBJ}${IDX}_Scale${idx_num}_Position${i}_Wood_RGB"
          rm -f "${BASE_DIR}/${base}.png" || true
        done

        log "  -  scale_idx=0 …"
        "$ISAACSIM_PY" "${PY_SCRIPT}" \
          "${OBJ}" "${IDX}" \
          --split "${SPLIT}" \
          --config "${CFG_PATH}" \
          --positions "${POS}" \
          --scale "${SCALE}" \
          --scale-idx "0" 2>&1 | tee -a "${LOG_DIR}/run_${SPLIT}.log"
      fi
    done
  done
}

case "${SPLIT}" in
  All)
    log " Train → Test_Seen → Test_Unseen"
    run_for_map TRAIN_MAP
    run_for_map TEST_SEEN_MAP
    run_for_map TEST_UNSEEN_MAP
    ;;
  Train)
    run_for_map TRAIN_MAP
    ;;
  Test_Seen)
    run_for_map TEST_SEEN_MAP
    ;;
  Test_Unseen)
    run_for_map TEST_UNSEEN_MAP
    ;;
  *)
    echo ": ${SPLIT}" >&2; exit 2
    ;;
esac

log ": ${SPLIT}"
