# FlatLab (Submission Package)

This repository contains:
1) **Isaac Sim** standalone scripts to generate RGB / depth / point cloud observations for **flat rigid** and **deformable** objects (the “FlatLab” dataset layout), and  
2) **PyTorch** training code for (a) **point-cloud strategy classification** and (b) **pose regression**.

The simulation scripts are meant to be launched with **NVIDIA Isaac Sim’s `python.sh`**.

---

## Project Layout
```

FlatLab-Submission/
 ├─ Assets/                       # USD assets (objects, room, table, robots)
 ├─ Env_Config/                   # Scene/object/camera utilities & configs
 ├─ Env_StandAlone/               # Isaac Sim standalone environments & collectors
 ├─ Model/
 │  ├─ point_cloud_classifier/    # Strategy classifier (PointNet + contrastive)
 │  └─ pose_reg/                  # Pose regression (PointNet2Reg)
 ├─ Deformable_Vision_Collection.sh
 └─ Rigid_Vision_Collection.sh

```
Generated dataset files are written under:
```

Data/FlatLab/
 ├─ Data_op_RGB/
 ├─ Data_op_Depth/
 ├─ Data_op_PointCloud_Env/
 └─ Data_op_PointCloud_Obj/

```
Each sample typically produces:
- `*_Wood_RGB.png`
- `*_Wood_Depth.png`
- `*_Wood_Env.ply`
- `*_Wood_Obj.ply`

---

## Requirements

### A) Simulation / Data Collection (Isaac Sim)
- **NVIDIA Isaac Sim 4.5.0** (the scripts assume a folder named `isaacsim_4.5.0` at repo root)
- A compatible NVIDIA GPU + driver (per Isaac Sim requirements)

Expected layout:
```

your_workspace/
 ├─ FlatLab-Submission/           # this repo root
 └─ isaacsim_4.5.0/               # Isaac Sim installation directory
 └─ python.sh

```
### B) Model Training (PyTorch)
Training can be run in a separate Python environment (recommended), e.g. Conda/venv:
- Python 3.8+ (3.10 is fine)
- `torch`, `numpy`, `tqdm`, `scipy`, `matplotlib`, `open3d`, `plyfile`, `termcolor`, `imageio`, `av`

Example install:
```bash
pip install torch numpy tqdm scipy matplotlib open3d plyfile termcolor imageio av
```

------

## Quick Start

### 1) Enter the repository

```bash
cd FlatLab-Submission
```

### 2) Verify Isaac Sim launcher exists

```bash
ls -al ./isaacsim_4.5.0/python.sh
```

If your Isaac Sim is elsewhere, either:

- create a symlink named `isaacsim_4.5.0` in repo root, or
- edit `ISAACSIM_PY=...` inside the `.sh` scripts.

------

## Data Collection

### A) Rigid Object Vision Collection

Run (split can be `Train`, `Test_Seen`, `Test_Unseen`, or `All`):

```bash
bash Rigid_Vision_Collection.sh All
```

Optional arguments:

```bash
bash Rigid_Vision_Collection.sh <SPLIT> <CFG_PATH> <NUM_POSITIONS>
# Example:
bash Rigid_Vision_Collection.sh Train Env_Config/Flat_Object/rigid_scales.json 5
```

**Output:**

```
Data/FlatLab/Data_op_RGB/<split>/{Strategy_A|Strategy_B}/...
Data/FlatLab/Data_op_Depth/<split>/{Strategy_A|Strategy_B}/...
Data/FlatLab/Data_op_PointCloud_Env/<split>/{Strategy_A|Strategy_B}/...
Data/FlatLab/Data_op_PointCloud_Obj/<split>/{Strategy_A|Strategy_B}/...
```

> Note: The file naming convention includes object type, instance index, scale index, and position index:
>  `<OBJ>_view5_<OBJ><IDX>_Scale<k>_Position<i>_Wood_*.{png|ply}`

------

### B) Deformable Object Vision Collection

Run:

```bash
bash Deformable_Vision_Collection.sh train Deformable
```

Arguments:

- `split`: `train`, `test_seen`, `test_unseen`
- `mode`: `Deformable`, `Rigid`, or `Both`

Examples:

```bash
bash Deformable_Vision_Collection.sh train Both
bash Deformable_Vision_Collection.sh test_unseen Deformable
```

**Output (Strategy_C):**

```
Data/FlatLab/Data_op_RGB/<split>/Strategy_C/...
Data/FlatLab/Data_op_Depth/<split>/Strategy_C/...
Data/FlatLab/Data_op_PointCloud_Env/<split>/Strategy_C/...
Data/FlatLab/Data_op_PointCloud_Obj/<split>/Strategy_C/...
```

------

### C) Action / Demo Data Collection (Stage2 Example)

There is an example launcher:

```bash
bash Env_StandAlone/Action_Data_Collection.sh 50 10 False 3
```

Meaning:

- `50`  → positions (either an integer count or a space-separated list)
- `10`  → timeout minutes per attempt
- `False` → record video (`True/False`)
- `3`   → max retry attempts

Outputs go under:

```
FlatLab/Data/<TASK_NAME>/
├─ Video/
├─ train_data/
└─ pointcloud/
```

------

## Training

### A) Point Cloud Strategy Classifier

Go to:

```bash
cd Model/point_cloud_classifier
```

Train:

```bash
python train.py \
  --data_root ../../Data/FlatLab/Data_op_PointCloud_Obj \
  --classes Strategy_A Strategy_B Strategy_C \
  --epochs 150 \
  --batch_size 32 \
  --device cuda:0 \
  --save_dir ./checkpoints
```

This trains a PointNet-style classifier with a combined:

- cross-entropy classification loss
- NT-Xent contrastive loss (weighted by `--contrast_weight`)

Checkpoints and logs are written to `--save_dir`.

------

### B) Pose Regression

Go to:

```bash
cd Model/pose_reg
```

Train:

```bash
python train.py
```

Most pose-reg settings are configured via `utils.get_args()` (see `Model/pose_reg/utils.py`), including:

- dataset root
- GPU selection
- batch size / epochs
- number of points

------

## Tips & Troubleshooting

- **GUI vs headless:** Many scripts start Isaac Sim with `headless: False`. If you want headless mode, edit the corresponding Python file(s):

  ```python
  simulation_app = SimulationApp({"headless": True})
  ```

- **First run is slow:** Isaac Sim may compile shaders / cache assets.

- **Missing outputs:** Confirm your dataset paths:

  - Vision collectors write to `Data/FlatLab/...`

- **Script path adjustments:** If `isaacsim_4.5.0/python.sh` is not found, update the shell scripts accordingly.

------

