import json
import numpy as np


class Cmdp:
    def __init__(self, json_path):
        with open(json_path) as f:
            data = json.load(f)

        self.L = data["L"]
        self.X = data["X"]
        self.A = data["A"]
        self.layers = data["layers"]
        self.state_to_layer = {int(k): v for k, v in data["state_to_layer"].items()}
        self.transitions = data["transitions"]
        self.x0 = data["x0"]
        self.det_actions = set(tuple(item) for item in data.get("det_actions", []))

        self.adversarial_reward_vectors = None
        self.adversarial_constraint_vectors = None

    def get_next_state(self, x, a):
        key = f"{x}_{a}"
        if key not in self.transitions:
            raise ValueError(f"Transition not defined for ({x}, {a})")
        probs_dict = self.transitions[key]
        next_states = list(probs_dict.keys())
        probs = list(probs_dict.values())
        return int(np.random.choice(next_states, p=probs))

    def get_reward(self, x, a, t):
        raise NotImplementedError("Use external reward function or override for adversarial")

    def get_constraint(self, x, a, i, t):
        raise NotImplementedError("Use external constraint function or override for adversarial")

