From 4cd64a6fbdc8300218c20a7c69d3347b2c41bcf5 Mon Sep 17 00:00:00 2001 From: Dominik Roth Date: Wed, 22 Jun 2022 13:08:44 +0200 Subject: [PATCH] Implemented CLI to select env for testing --- columbus/humanPlayer.py | 30 +++++++++++++++++++++++++++--- 1 file changed, 27 insertions(+), 3 deletions(-) diff --git a/columbus/humanPlayer.py b/columbus/humanPlayer.py index cef9772..4948b8a 100644 --- a/columbus/humanPlayer.py +++ b/columbus/humanPlayer.py @@ -1,5 +1,5 @@ from time import sleep, time -from env import * +import env import numpy as np import pygame @@ -7,13 +7,37 @@ from observables import Observable, CnnObservable def main(): - #env = ColumbusTest3_1(fps=30) - env = ColumbusStateWithBarriers(fps=30) + Env = chooseEnv() + env = Env(fps=30) env.start_pos = [0.6, 0.3] playEnv(env) env.close() +def getAvaibleEnvs(): + # kinda hacky... idk + strs = dir(env) + for s in strs: + if s.startswith('Columbus') and s != 'ColumbusEnv': + yield getattr(env, s) + + +def chooseEnv(): + envs = list(getAvaibleEnvs()) + for i, Env in enumerate(envs): + print('['+str(i)+'] '+Env.__name__) + while True: + inp = input('[#> ') + try: + i = int(inp) + except: + print('[!] You have to enter the number...') + if i < 0 or i >= len(envs): + print( + '[!] That is a number, but not one that makes sense in this context...') + return envs[i] + + def playEnv(env): env.reset() done = False