import random

from utils import construct_bits_string

from math_func.State import State


def reset_envs(envs, players, input=None):
    for env in envs:
        env.my_reset()

    if input is None:
        s = random.randint(0, 2 ** players - 1)
    else:
        s = input
    states = list(construct_bits_string(s, players))
    initial_states = [0] * players
    for i in range(players):
        if int(states[i]) == 0:
            initial_states[i] = float(State.Zero.value)
        if int(states[i]) == 1:
            initial_states[i] = float(State.One.value)

    for i, env in enumerate(envs):
        env.initial_states = initial_states[:]
        env.state_machine.set_initial(initial_states[i])
        env.states = initial_states[:]

def step_envs(envs, actions, players):
    this_func = "Math: step_envs"
    for i, env in enumerate(envs):
        # update state machine
        env.transit(actions[i])
        env.states = actions[:] # Doesn't matter since we don't use it
        env._done = True