# FreeMo: Motion Generation with Structured Joint-Collision Energy

This folder contains the code to reproduce the self-collision optimization component of our ICLR 2026 submission.  
Our optimization framework, FreeMo, performs inference-time refinement over pretrained motion generation models using a joint-level discriminator and a structured energy function.

## Dependencies

### Basic Dependencies
```bash
pip install -r requirements.txt
```

### External Repositories
This project is based on the following repositories. Please clone and download the corresponding model weights:

1. **MotionLCM**: https://github.com/Dai-Wenxun/MotionLCM
2. **MDM**: https://github.com/GuyTevet/motion-diffusion-model
3. **COAP**: https://github.com/markomih/COAP
4. **SALAD**: https://github.com/seokhyeonhong/salad

### Dataset Preparation
Please prepare the HumanML3D dataset following the instructions at https://github.com/EricGuo5513/HumanML3D.

## Usage

### Creating PosePenetrationDataset from MDM Motions

To create a PosePenetrationDataset from MDM-generated motion files:

```bash
# Convert MDM motion files to PosePenetrationDataset format
python create_pose_penetration_dataset.py \
    --input_dir /path/to/mdm/motions \
    --output_dir /path/to/output/dataset \
    --penetration_threshold 0.01
```

The output directory will contain:
- `ori_vecs/`: Pose vectors for each motion
- `penetration_score/`: Collision scores for each motion
- `train.txt`, `val.txt`, `test.txt`: Dataset splits

### Training Discriminators

First, you need to train global and joint-level discriminators:

```bash
# Train global discriminator
python train_pose_discriminator.py --cfg configs/pose_penetration_detector.yaml

# Train joint-level discriminator
python train_pose_discriminator.py --cfg configs/pose_penetration_detector_joint.yaml
```

### Model Testing

#### Base Model Testing
```bash
# Test base model
python test.py --cfg <base_model_config>
```

#### Optimized Model Testing
```bash
# Test optimized model
python test.py --cfg <base_model_config> --optimize --disc_cfg <discriminator_config>
```

For Collision Metrics
```bash
# Generate Samples
python demo.py --cfg <config_file> --example HardPoseText.txt

# or

python demo.py --cfg <config_file> --example HardPoseText.txt --optimize --disc_cfg <discriminator_config>

# Evaluation
python eval_self_collision.py <samples_dir>

```

### Configuration Files

The project provides several pre-configured configuration files:

config_file
- **MLD + HardPoseText**: `configs/mld_t2m_hardpose.yaml`
- **MLD + HumanML3D subset**: `configs/mld_t2m_humanml3d_subset.yaml`
- **MotionLCM + HardPoseText**: `configs/motionlcm_t2m_hardpose.yaml`
- **MotionLCM + HumanML3D subset**: `configs/motionlcm_t2m_humanml3d_subset.yaml`

discriminator_config
- **Global Discriminator**: `configs/pose_penetration_detector.yaml`
- **Joint-Level Discriminator**: `configs/pose_penetration_detector_joint.yaml`
- **Joint-Level Discriminator with Energy Term**: `configs/pose_penetration_detector_joint_energy.yaml`

