This repository contains code to simulate Constrained Markov Decision Processes (CMDPs) with both stochastic and adversarial constraints, and to compare the performance of algorithm WC-OPS with OptCMDP, OptPrimalDual-CMDP and Greedy.

 ## Structure
- `Cmdp.py` – class to handle a CMDP from a JSON specification.  
- `generate_cmdp_json.py` – script to generate random CMDPs with transitions, layers, and optionally a deterministic path.  
- `main.py` – entry point to run simulations with chosen settings and plot graphs.
- ...

## Requirements
- Python 3.8+  
- Libraries:
  ```bash
  pip install numpy pandas matplotlib
  pip install scipy
  pip install cvxpy
  pip install MOSEK

## Run
  ```bash
  python main.py --loss_type adv --constraint_type stoc --T 500000 --m 3 --n_repeats 10 --X 5 --A 4 --L 3

