from worlds.game import GameParams
from worlds.traffic_world import TrafficWorldParams

class TesterTrafficWorld:
    def __init__(self, experiment, tabular_case, gamma, data=None):
        if data is None:
            # Reading the file
            self.experiment = experiment
            self.tabular_case = tabular_case
            f = open(experiment)
            lines = [l.rstrip() for l in f]
            f.close()
            # setting the test attributes
            self.map = eval(lines[1])
            self.tasks = eval(lines[2])
            optimal_aux = eval(lines[3])
            self.consider_night = eval(lines[4])

            # I compute the optimal reward
            self.optimal = {}
            for i in range(len(self.tasks)):
                self.optimal[self.tasks[i]] = gamma ** (float(optimal_aux[i]) - 1)
        else:
            self.experiment = data["experiment"]
            self.map = data["map"]
            self.tasks = data["tasks"]
            self.consider_night = data["consider_night"]
            self.optimal = data["optimal"]

    def get_dictionary(self):
        d = {}
        d["experiment"] = self.experiment
        d["map"] = self.map
        d["tasks"] = self.tasks
        d["consider_night"] = self.consider_night
        d["optimal"] = self.optimal
        return d

    def get_reward_machine_files(self):
        return self.tasks

    def get_task_specifications(self):
        return self.tasks

    def get_task_params(self, task_specification):
        params = TrafficWorldParams(self.map, self.tabular_case, self.consider_night)
        return GameParams("trafficworld", params)

    def get_task_rm_file(self, task_specification):
        return task_specification
