kaggle-environments 0.2.1__py3-none-any.whl → 1.20.0__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of kaggle-environments might be problematic. Click here for more details.
- kaggle_environments/__init__.py +49 -13
- kaggle_environments/agent.py +177 -124
- kaggle_environments/api.py +31 -0
- kaggle_environments/core.py +295 -170
- kaggle_environments/envs/cabt/cabt.js +164 -0
- kaggle_environments/envs/cabt/cabt.json +28 -0
- kaggle_environments/envs/cabt/cabt.py +186 -0
- kaggle_environments/envs/cabt/cg/__init__.py +0 -0
- kaggle_environments/envs/cabt/cg/cg.dll +0 -0
- kaggle_environments/envs/cabt/cg/game.py +75 -0
- kaggle_environments/envs/cabt/cg/libcg.so +0 -0
- kaggle_environments/envs/cabt/cg/sim.py +48 -0
- kaggle_environments/envs/cabt/test_cabt.py +120 -0
- kaggle_environments/envs/chess/chess.js +4289 -0
- kaggle_environments/envs/chess/chess.json +60 -0
- kaggle_environments/envs/chess/chess.py +4241 -0
- kaggle_environments/envs/chess/test_chess.py +60 -0
- kaggle_environments/envs/connectx/connectx.ipynb +3186 -0
- kaggle_environments/envs/connectx/connectx.js +1 -1
- kaggle_environments/envs/connectx/connectx.json +15 -1
- kaggle_environments/envs/connectx/connectx.py +6 -23
- kaggle_environments/envs/connectx/test_connectx.py +70 -24
- kaggle_environments/envs/football/football.ipynb +75 -0
- kaggle_environments/envs/football/football.json +91 -0
- kaggle_environments/envs/football/football.py +277 -0
- kaggle_environments/envs/football/helpers.py +95 -0
- kaggle_environments/envs/football/test_football.py +360 -0
- kaggle_environments/envs/halite/__init__.py +0 -0
- kaggle_environments/envs/halite/halite.ipynb +44741 -0
- kaggle_environments/envs/halite/halite.js +199 -83
- kaggle_environments/envs/halite/halite.json +31 -18
- kaggle_environments/envs/halite/halite.py +164 -303
- kaggle_environments/envs/halite/helpers.py +720 -0
- kaggle_environments/envs/halite/test_halite.py +190 -0
- kaggle_environments/envs/hungry_geese/__init__.py +0 -0
- kaggle_environments/envs/{battlegeese/battlegeese.js → hungry_geese/hungry_geese.js} +38 -22
- kaggle_environments/envs/{battlegeese/battlegeese.json → hungry_geese/hungry_geese.json} +21 -14
- kaggle_environments/envs/hungry_geese/hungry_geese.py +316 -0
- kaggle_environments/envs/hungry_geese/test_hungry_geese.py +0 -0
- kaggle_environments/envs/identity/identity.json +6 -5
- kaggle_environments/envs/identity/identity.py +15 -2
- kaggle_environments/envs/kore_fleets/__init__.py +0 -0
- kaggle_environments/envs/kore_fleets/helpers.py +1005 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.ipynb +114 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.js +658 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.json +164 -0
- kaggle_environments/envs/kore_fleets/kore_fleets.py +555 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/Bot.java +54 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/README.md +26 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/jars/hamcrest-core-1.3.jar +0 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/jars/junit-4.13.2.jar +0 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Board.java +518 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Cell.java +61 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Configuration.java +24 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Direction.java +166 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Fleet.java +72 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/KoreJson.java +97 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Observation.java +72 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Pair.java +13 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Player.java +68 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Point.java +65 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/Shipyard.java +70 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/kore/ShipyardAction.java +59 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/main.py +73 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/BoardTest.java +567 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/ConfigurationTest.java +25 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/KoreJsonTest.java +62 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/ObservationTest.java +46 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/PointTest.java +21 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/ShipyardTest.java +22 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/configuration.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/fullob.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/java/test/observation.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/python/__init__.py +0 -0
- kaggle_environments/envs/kore_fleets/starter_bots/python/main.py +27 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/Bot.ts +34 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/DoNothingBot.ts +12 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/MinerBot.ts +62 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/README.md +55 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/interpreter.ts +402 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Board.ts +514 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Cell.ts +63 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Configuration.ts +25 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Direction.ts +169 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Fleet.ts +76 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/KoreIO.ts +70 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Observation.ts +45 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Pair.ts +11 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Player.ts +68 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Point.ts +65 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/Shipyard.ts +72 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/kore/ShipyardAction.ts +58 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/main.py +73 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/miner.py +73 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/package.json +23 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/BoardTest.ts +551 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/ConfigurationTest.ts +16 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/ObservationTest.ts +33 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/PointTest.ts +17 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/ShipyardTest.ts +18 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/configuration.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/fullob.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/test/observation.json +1 -0
- kaggle_environments/envs/kore_fleets/starter_bots/ts/tsconfig.json +22 -0
- kaggle_environments/envs/kore_fleets/test_kore_fleets.py +331 -0
- kaggle_environments/envs/lux_ai_2021/README.md +3 -0
- kaggle_environments/envs/lux_ai_2021/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_2021/agents.py +11 -0
- kaggle_environments/envs/lux_ai_2021/dimensions/754.js +2 -0
- kaggle_environments/envs/lux_ai_2021/dimensions/754.js.LICENSE.txt +296 -0
- kaggle_environments/envs/lux_ai_2021/dimensions/main.js +1 -0
- kaggle_environments/envs/lux_ai_2021/index.html +43 -0
- kaggle_environments/envs/lux_ai_2021/lux_ai_2021.json +100 -0
- kaggle_environments/envs/lux_ai_2021/lux_ai_2021.py +231 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/game_constants.js +6 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/game_constants.json +59 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/game_objects.js +145 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/io.js +14 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/kit.js +209 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/map.js +107 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/lux/parser.js +79 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/main.js +88 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/main.py +75 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/js_simple/simple.tar.gz +0 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/annotate.py +20 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/constants.py +25 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game.py +86 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_constants.json +59 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_constants.py +7 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_map.py +106 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/lux/game_objects.py +154 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/random_agent.py +38 -0
- kaggle_environments/envs/lux_ai_2021/test_agents/python/simple_agent.py +82 -0
- kaggle_environments/envs/lux_ai_2021/test_lux.py +19 -0
- kaggle_environments/envs/lux_ai_2021/testing.md +23 -0
- kaggle_environments/envs/lux_ai_2021/todo.md.og +18 -0
- kaggle_environments/envs/lux_ai_s3/README.md +21 -0
- kaggle_environments/envs/lux_ai_s3/agents.py +5 -0
- kaggle_environments/envs/lux_ai_s3/index.html +42 -0
- kaggle_environments/envs/lux_ai_s3/lux_ai_s3.json +47 -0
- kaggle_environments/envs/lux_ai_s3/lux_ai_s3.py +178 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/__init__.py +1 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/env.py +819 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/globals.py +9 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/params.py +101 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/profiler.py +141 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/pygame_render.py +222 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/spaces.py +27 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/state.py +464 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/utils.py +12 -0
- kaggle_environments/envs/lux_ai_s3/luxai_s3/wrappers.py +156 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/agent.py +78 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/lux/__init__.py +0 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/lux/kit.py +31 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/lux/utils.py +17 -0
- kaggle_environments/envs/lux_ai_s3/test_agents/python/main.py +66 -0
- kaggle_environments/envs/lux_ai_s3/test_lux.py +9 -0
- kaggle_environments/envs/mab/__init__.py +0 -0
- kaggle_environments/envs/mab/agents.py +12 -0
- kaggle_environments/envs/mab/mab.js +100 -0
- kaggle_environments/envs/mab/mab.json +74 -0
- kaggle_environments/envs/mab/mab.py +146 -0
- kaggle_environments/envs/open_spiel/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/chess/chess.js +441 -0
- kaggle_environments/envs/open_spiel/games/chess/image_config.jsonl +20 -0
- kaggle_environments/envs/open_spiel/games/chess/openings.jsonl +20 -0
- kaggle_environments/envs/open_spiel/games/connect_four/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/connect_four/connect_four.js +284 -0
- kaggle_environments/envs/open_spiel/games/connect_four/connect_four_proxy.py +86 -0
- kaggle_environments/envs/open_spiel/games/go/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/go/go.js +481 -0
- kaggle_environments/envs/open_spiel/games/go/go_proxy.py +99 -0
- kaggle_environments/envs/open_spiel/games/tic_tac_toe/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/tic_tac_toe/tic_tac_toe.js +345 -0
- kaggle_environments/envs/open_spiel/games/tic_tac_toe/tic_tac_toe_proxy.py +98 -0
- kaggle_environments/envs/open_spiel/games/universal_poker/__init__.py +0 -0
- kaggle_environments/envs/open_spiel/games/universal_poker/universal_poker.js +431 -0
- kaggle_environments/envs/open_spiel/games/universal_poker/universal_poker_proxy.py +159 -0
- kaggle_environments/envs/open_spiel/html_playthrough_generator.py +31 -0
- kaggle_environments/envs/open_spiel/observation.py +128 -0
- kaggle_environments/envs/open_spiel/open_spiel.py +565 -0
- kaggle_environments/envs/open_spiel/proxy.py +138 -0
- kaggle_environments/envs/open_spiel/test_open_spiel.py +191 -0
- kaggle_environments/envs/rps/__init__.py +0 -0
- kaggle_environments/envs/rps/agents.py +84 -0
- kaggle_environments/envs/rps/helpers.py +25 -0
- kaggle_environments/envs/rps/rps.js +117 -0
- kaggle_environments/envs/rps/rps.json +63 -0
- kaggle_environments/envs/rps/rps.py +90 -0
- kaggle_environments/envs/rps/test_rps.py +110 -0
- kaggle_environments/envs/rps/utils.py +7 -0
- kaggle_environments/envs/tictactoe/test_tictactoe.py +43 -77
- kaggle_environments/envs/tictactoe/tictactoe.ipynb +1397 -0
- kaggle_environments/envs/tictactoe/tictactoe.json +10 -2
- kaggle_environments/envs/tictactoe/tictactoe.py +1 -1
- kaggle_environments/errors.py +2 -4
- kaggle_environments/helpers.py +377 -0
- kaggle_environments/main.py +340 -0
- kaggle_environments/schemas.json +23 -18
- kaggle_environments/static/player.html +206 -74
- kaggle_environments/utils.py +46 -73
- kaggle_environments-1.20.0.dist-info/METADATA +25 -0
- kaggle_environments-1.20.0.dist-info/RECORD +211 -0
- {kaggle_environments-0.2.1.dist-info → kaggle_environments-1.20.0.dist-info}/WHEEL +1 -2
- kaggle_environments-1.20.0.dist-info/entry_points.txt +3 -0
- kaggle_environments/envs/battlegeese/battlegeese.py +0 -223
- kaggle_environments/temp.py +0 -14
- kaggle_environments-0.2.1.dist-info/METADATA +0 -393
- kaggle_environments-0.2.1.dist-info/RECORD +0 -32
- kaggle_environments-0.2.1.dist-info/entry_points.txt +0 -3
- kaggle_environments-0.2.1.dist-info/top_level.txt +0 -1
- {kaggle_environments-0.2.1.dist-info → kaggle_environments-1.20.0.dist-info/licenses}/LICENSE +0 -0
|
@@ -0,0 +1,340 @@
|
|
|
1
|
+
# Copyright 2020 Kaggle Inc
|
|
2
|
+
#
|
|
3
|
+
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
4
|
+
# you may not use this file except in compliance with the License.
|
|
5
|
+
# You may obtain a copy of the License at
|
|
6
|
+
#
|
|
7
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
|
8
|
+
#
|
|
9
|
+
# Unless required by applicable law or agreed to in writing, software
|
|
10
|
+
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
11
|
+
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
12
|
+
# See the License for the specific language governing permissions and
|
|
13
|
+
# limitations under the License.
|
|
14
|
+
|
|
15
|
+
import argparse
|
|
16
|
+
import json
|
|
17
|
+
import traceback
|
|
18
|
+
from logging.config import dictConfig
|
|
19
|
+
from typing import Optional
|
|
20
|
+
|
|
21
|
+
from . import errors, utils
|
|
22
|
+
from .agent import Agent
|
|
23
|
+
from .core import environments, evaluate, make
|
|
24
|
+
|
|
25
|
+
parser = argparse.ArgumentParser(description="Kaggle Simulations")
|
|
26
|
+
parser.add_argument(
|
|
27
|
+
"action",
|
|
28
|
+
choices=["list", "evaluate", "run", "step", "load", "act", "dispose", "http-server"],
|
|
29
|
+
help="List environments. Evaluate many episodes. Run a single episode. Step the environment. Load the environment. Start http server.",
|
|
30
|
+
)
|
|
31
|
+
parser.add_argument("--environment", type=str, help="Environment to run against.")
|
|
32
|
+
parser.add_argument("--debug", type=bool, help="Print debug statements.")
|
|
33
|
+
parser.add_argument("--agents", type=str, nargs="*", help="Agent(s) to run with the environment.")
|
|
34
|
+
parser.add_argument(
|
|
35
|
+
"--configuration",
|
|
36
|
+
type=json.loads,
|
|
37
|
+
help="Environment configuration to setup the environment.",
|
|
38
|
+
)
|
|
39
|
+
parser.add_argument(
|
|
40
|
+
"--info",
|
|
41
|
+
type=json.loads,
|
|
42
|
+
help="Information about agents playing.",
|
|
43
|
+
)
|
|
44
|
+
parser.add_argument(
|
|
45
|
+
"--steps",
|
|
46
|
+
type=json.loads,
|
|
47
|
+
help="Environment starting states (default=[resetState]).",
|
|
48
|
+
)
|
|
49
|
+
parser.add_argument(
|
|
50
|
+
"--logs",
|
|
51
|
+
type=json.loads,
|
|
52
|
+
help="Environment starting logs (default=[]).",
|
|
53
|
+
)
|
|
54
|
+
parser.add_argument(
|
|
55
|
+
"--state",
|
|
56
|
+
type=json.loads,
|
|
57
|
+
help="Single agent state used for evaluation (default={}).",
|
|
58
|
+
)
|
|
59
|
+
parser.add_argument("--episodes", type=int, help="Number of episodes to evaluate (default=1)")
|
|
60
|
+
parser.add_argument(
|
|
61
|
+
"--render",
|
|
62
|
+
type=json.loads,
|
|
63
|
+
help="Response from run, step, or load. Calls environment render (default={mode='json'}).",
|
|
64
|
+
)
|
|
65
|
+
parser.add_argument(
|
|
66
|
+
"--display",
|
|
67
|
+
type=str,
|
|
68
|
+
help="Shortcut to the --render {mode=''} argument (default json).",
|
|
69
|
+
)
|
|
70
|
+
parser.add_argument("--port", type=int, help="http-server Port (default=8000).")
|
|
71
|
+
parser.add_argument("--host", type=str, help="http-server Host (default=127.0.0.1).")
|
|
72
|
+
parser.add_argument("--in", type=str, help="Episode replay file to load. Only works when the action is load.")
|
|
73
|
+
parser.add_argument(
|
|
74
|
+
"--out", type=str, help="Output file to write the results of the episode. Does nothing in http-server mode."
|
|
75
|
+
)
|
|
76
|
+
parser.add_argument(
|
|
77
|
+
"--log",
|
|
78
|
+
type=str,
|
|
79
|
+
help="Agent log file to write the std out, resource, and step timing for each agent. Also used to load logs from a file with the load action.",
|
|
80
|
+
)
|
|
81
|
+
|
|
82
|
+
|
|
83
|
+
def render(args, env):
|
|
84
|
+
mode = args.display if args.display is not None else utils.get(args.render, str, "json", path=["mode"])
|
|
85
|
+
|
|
86
|
+
if mode == "human" or mode == "ansi" or mode == "txt":
|
|
87
|
+
args.render["mode"] = "ansi"
|
|
88
|
+
elif mode == "ipython" or mode == "html":
|
|
89
|
+
args.render["mode"] = "html"
|
|
90
|
+
elif mode == "webm" or mode == "video":
|
|
91
|
+
args.render["mode"] = "webm"
|
|
92
|
+
else:
|
|
93
|
+
args.render["mode"] = "json"
|
|
94
|
+
result = env.render(**args.render)
|
|
95
|
+
return result
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
def action_list(args):
|
|
99
|
+
return json.dumps([*environments])
|
|
100
|
+
|
|
101
|
+
|
|
102
|
+
def action_evaluate(args):
|
|
103
|
+
return json.dumps(evaluate(args.environment, args.agents, args.configuration, args.steps, args.episodes))
|
|
104
|
+
|
|
105
|
+
|
|
106
|
+
cached_agent = None
|
|
107
|
+
|
|
108
|
+
|
|
109
|
+
def action_act(args):
|
|
110
|
+
global cached_agent
|
|
111
|
+
if len(args.agents) != 1:
|
|
112
|
+
return {"error": "One agent must be provided."}
|
|
113
|
+
raw = args.agents[0]
|
|
114
|
+
|
|
115
|
+
env = make(args.environment, args.configuration, args.info, state=args.state, debug=args.debug)
|
|
116
|
+
|
|
117
|
+
is_first_run = cached_agent is None or cached_agent.raw != raw
|
|
118
|
+
if is_first_run:
|
|
119
|
+
cached_agent = Agent(raw, env)
|
|
120
|
+
observation = utils.get(args.state, dict, {}, ["observation"])
|
|
121
|
+
action, log = cached_agent.act(observation)
|
|
122
|
+
if isinstance(action, errors.DeadlineExceeded):
|
|
123
|
+
action = "DeadlineExceeded"
|
|
124
|
+
elif isinstance(action, BaseException):
|
|
125
|
+
action = "BaseException::" + str(action)
|
|
126
|
+
|
|
127
|
+
if args.log_path is not None:
|
|
128
|
+
with open(args.log_path, mode="a") as log_file:
|
|
129
|
+
if not is_first_run:
|
|
130
|
+
log_file.write(",\n ")
|
|
131
|
+
json.dump([log], log_file)
|
|
132
|
+
|
|
133
|
+
return {"action": action}
|
|
134
|
+
|
|
135
|
+
|
|
136
|
+
def action_step(args):
|
|
137
|
+
env = {"logs": args.logs}
|
|
138
|
+
try:
|
|
139
|
+
env = make(args.environment, args.configuration, args.info, args.steps, args.logs, args.debug)
|
|
140
|
+
runner = env.__agent_runner(args.agents)
|
|
141
|
+
env.step(runner.act())
|
|
142
|
+
finally:
|
|
143
|
+
if args.log_path is not None:
|
|
144
|
+
with open(args.log_path, mode="a") as log_file:
|
|
145
|
+
json.dump(env.logs[-1], log_file)
|
|
146
|
+
log_file.write(",")
|
|
147
|
+
return render(args, env)
|
|
148
|
+
|
|
149
|
+
|
|
150
|
+
def action_run(args):
|
|
151
|
+
# Create a fake env so we can make the real env in our try body
|
|
152
|
+
env = utils.structify({"logs": args.logs})
|
|
153
|
+
try:
|
|
154
|
+
env = make(args.environment, args.configuration, args.info, args.steps, args.logs, args.debug)
|
|
155
|
+
env.run(args.agents)
|
|
156
|
+
finally:
|
|
157
|
+
if args.log_path is not None:
|
|
158
|
+
with open(args.log_path, mode="w") as log_file:
|
|
159
|
+
json.dump(env.logs, log_file, indent=2)
|
|
160
|
+
return render(args, env)
|
|
161
|
+
|
|
162
|
+
|
|
163
|
+
def action_load(args):
|
|
164
|
+
if args.log_path is not None:
|
|
165
|
+
with open(args.log_path, mode="r") as log_file:
|
|
166
|
+
args.logs = json.load(log_file)
|
|
167
|
+
|
|
168
|
+
if args.in_path is not None:
|
|
169
|
+
with open(args.in_path, mode="r") as replay_file:
|
|
170
|
+
json_args = json.load(replay_file)
|
|
171
|
+
env = make(
|
|
172
|
+
json_args["name"], json_args["configuration"], json_args["info"], json_args["steps"], args.logs, args.debug
|
|
173
|
+
)
|
|
174
|
+
else:
|
|
175
|
+
env = make(args.environment, args.configuration, args.info, args.steps, args.logs, args.debug)
|
|
176
|
+
return render(args, env)
|
|
177
|
+
|
|
178
|
+
|
|
179
|
+
disposed = True
|
|
180
|
+
|
|
181
|
+
|
|
182
|
+
# This method is only called at the end of an episode to write the final array brace in the logs file and dispose the cached agent to force reinitialization
|
|
183
|
+
def action_dispose(args):
|
|
184
|
+
global cached_agent, disposed
|
|
185
|
+
if disposed:
|
|
186
|
+
return "Already disposed"
|
|
187
|
+
|
|
188
|
+
cached_agent = None
|
|
189
|
+
if args.log_path is not None:
|
|
190
|
+
with open(args.log_path, mode="a") as log_file:
|
|
191
|
+
log_file.write("]")
|
|
192
|
+
disposed = True
|
|
193
|
+
return "Successfully disposed"
|
|
194
|
+
|
|
195
|
+
|
|
196
|
+
def parse_args(args):
|
|
197
|
+
return utils.structify(
|
|
198
|
+
{
|
|
199
|
+
"action": utils.get(args, str, "list", ["action"]),
|
|
200
|
+
"agents": utils.get(args, list, [], ["agents"]),
|
|
201
|
+
"configuration": utils.get(args, dict, {}, ["configuration"]),
|
|
202
|
+
"environment": args.get("environment", args.get("name", None)),
|
|
203
|
+
"episodes": utils.get(args, int, 1, ["episodes"]),
|
|
204
|
+
"state": utils.get(args, dict, {}, ["state"]),
|
|
205
|
+
"steps": utils.get(args, list, [], ["steps"]),
|
|
206
|
+
"logs": utils.get(args, list, [], ["logs"]),
|
|
207
|
+
"render": utils.get(args, dict, {"mode": "json"}, ["render"]),
|
|
208
|
+
"display": utils.get(args, str, None, ["display"]),
|
|
209
|
+
"debug": utils.get(args, bool, False, ["debug"]),
|
|
210
|
+
"host": utils.get(args, str, "127.0.0.1", ["host"]),
|
|
211
|
+
"port": utils.get(args, int, 8000, ["port"]),
|
|
212
|
+
"in_path": utils.get(args, str, None, ["in"]),
|
|
213
|
+
"out_path": utils.get(args, str, None, ["out"]),
|
|
214
|
+
"log_path": utils.get(args, str, None, ["log"]),
|
|
215
|
+
"info": utils.get(args, dict, {}, ["info"]),
|
|
216
|
+
}
|
|
217
|
+
)
|
|
218
|
+
|
|
219
|
+
|
|
220
|
+
def action_handler(args):
|
|
221
|
+
try:
|
|
222
|
+
if args.action == "list":
|
|
223
|
+
return action_list(args)
|
|
224
|
+
if args.action == "http-server":
|
|
225
|
+
return {"error": "Already running a http server."}
|
|
226
|
+
if args.action == "act":
|
|
227
|
+
return action_act(args)
|
|
228
|
+
if args.action == "dispose":
|
|
229
|
+
return action_dispose(args)
|
|
230
|
+
if args.action == "load":
|
|
231
|
+
return action_load(args)
|
|
232
|
+
|
|
233
|
+
if args.environment is None:
|
|
234
|
+
return {"error": "Environment required."}
|
|
235
|
+
|
|
236
|
+
if args.action == "evaluate":
|
|
237
|
+
return action_evaluate(args)
|
|
238
|
+
if args.action == "step":
|
|
239
|
+
return action_step(args)
|
|
240
|
+
if args.action == "run":
|
|
241
|
+
return action_run(args)
|
|
242
|
+
|
|
243
|
+
return {"error": "Unknown Action"}
|
|
244
|
+
except Exception as e:
|
|
245
|
+
return {"error": str(e), "trace": traceback.format_exc()}
|
|
246
|
+
|
|
247
|
+
|
|
248
|
+
log_path: Optional[str] = None
|
|
249
|
+
|
|
250
|
+
|
|
251
|
+
def action_http(args):
|
|
252
|
+
from flask import Flask, request
|
|
253
|
+
|
|
254
|
+
if args.log_path is not None:
|
|
255
|
+
global log_path
|
|
256
|
+
log_path = args.log_path
|
|
257
|
+
|
|
258
|
+
# Setup logging to console for Flask
|
|
259
|
+
dictConfig(
|
|
260
|
+
{
|
|
261
|
+
"version": 1,
|
|
262
|
+
"formatters": {
|
|
263
|
+
"default": {
|
|
264
|
+
"format": "%(levelname)s: %(message)s",
|
|
265
|
+
}
|
|
266
|
+
},
|
|
267
|
+
"handlers": {
|
|
268
|
+
"wsgi": {"class": "logging.StreamHandler", "stream": "ext://sys.stdout", "formatter": "default"}
|
|
269
|
+
},
|
|
270
|
+
"root": {"level": "INFO", "handlers": ["wsgi"]},
|
|
271
|
+
}
|
|
272
|
+
)
|
|
273
|
+
|
|
274
|
+
app = Flask(__name__, static_url_path="", static_folder="")
|
|
275
|
+
app.route("/", methods=["GET", "POST"])(lambda: http_request(request))
|
|
276
|
+
app.run(args.host, args.port, debug=args.debug, use_reloader=args.debug)
|
|
277
|
+
|
|
278
|
+
|
|
279
|
+
def http_request(request):
|
|
280
|
+
# Set CORS headers for the preflight request
|
|
281
|
+
if request.method == "OPTIONS":
|
|
282
|
+
# Allows GET requests from any origin with the Content-Type
|
|
283
|
+
# header and caches preflight response for an 3600s
|
|
284
|
+
headers = {
|
|
285
|
+
"Access-Control-Allow-Origin": "*",
|
|
286
|
+
"Access-Control-Allow-Methods": "GET",
|
|
287
|
+
"Access-Control-Allow-Headers": "Content-Type",
|
|
288
|
+
"Access-Control-Max-Age": "3600",
|
|
289
|
+
}
|
|
290
|
+
|
|
291
|
+
return "", 204, headers
|
|
292
|
+
|
|
293
|
+
headers = {"Access-Control-Allow-Origin": "*"}
|
|
294
|
+
params = request.args.to_dict()
|
|
295
|
+
for key in list(params.keys()):
|
|
296
|
+
if key.endswith("[]"):
|
|
297
|
+
params[key.replace("[]", "")] = request.args.getlist(key)
|
|
298
|
+
del params[key]
|
|
299
|
+
elif key.endswith("{}"):
|
|
300
|
+
params[key.replace("{}", "")] = json.loads(params[key])
|
|
301
|
+
del params[key]
|
|
302
|
+
|
|
303
|
+
body = request.get_json(silent=True, force=True) or {}
|
|
304
|
+
args = {**params, **body}
|
|
305
|
+
if "render" in args and isinstance(args["render"], str):
|
|
306
|
+
# Manually deserialize render argument
|
|
307
|
+
# We should eventually refactor this to use the same deserializer as the cmd line arg parser
|
|
308
|
+
args["render"] = json.loads(args["render"])
|
|
309
|
+
args = parse_args(args)
|
|
310
|
+
if args.log_path is None:
|
|
311
|
+
args.log_path = log_path
|
|
312
|
+
|
|
313
|
+
global disposed
|
|
314
|
+
# Write the opening array brace for the logs file if there is a logs file.
|
|
315
|
+
if disposed and args["action"] != "dispose" and args.log_path is not None:
|
|
316
|
+
with open(args.log_path, mode="w") as log_file:
|
|
317
|
+
log_file.write("[")
|
|
318
|
+
disposed = False
|
|
319
|
+
|
|
320
|
+
resp = action_handler(args)
|
|
321
|
+
return resp, 200, headers
|
|
322
|
+
|
|
323
|
+
|
|
324
|
+
def main():
|
|
325
|
+
args = parse_args(vars(parser.parse_args()))
|
|
326
|
+
if args.action == "http-server":
|
|
327
|
+
action_http(args)
|
|
328
|
+
else:
|
|
329
|
+
result = action_handler(args)
|
|
330
|
+
if args.out_path is None:
|
|
331
|
+
print(result)
|
|
332
|
+
else:
|
|
333
|
+
with open(args.out_path, encoding="utf-8", mode="w") as out_file:
|
|
334
|
+
out_file.write(str(result))
|
|
335
|
+
|
|
336
|
+
return 0
|
|
337
|
+
|
|
338
|
+
|
|
339
|
+
if __name__ == "__main__":
|
|
340
|
+
main()
|
kaggle_environments/schemas.json
CHANGED
|
@@ -62,29 +62,17 @@
|
|
|
62
62
|
"minimum": 1,
|
|
63
63
|
"default": 1000
|
|
64
64
|
},
|
|
65
|
-
"agentExec": {
|
|
66
|
-
"description": "How the agent is executed alongside the running envionment.",
|
|
67
|
-
"type": "string",
|
|
68
|
-
"default": "PROCESS",
|
|
69
|
-
"enum": ["LOCAL", "PROCESS"]
|
|
70
|
-
},
|
|
71
|
-
"agentTimeout": {
|
|
72
|
-
"description": "Maximum runtime (seconds) to initialize an agent.",
|
|
73
|
-
"type": "integer",
|
|
74
|
-
"minimum": 1,
|
|
75
|
-
"default": 10
|
|
76
|
-
},
|
|
77
65
|
"actTimeout": {
|
|
78
66
|
"description": "Maximum runtime (seconds) to obtain an action from an agent.",
|
|
79
|
-
"type": "
|
|
80
|
-
"minimum":
|
|
81
|
-
"default":
|
|
67
|
+
"type": "number",
|
|
68
|
+
"minimum": 0,
|
|
69
|
+
"default": 6
|
|
82
70
|
},
|
|
83
71
|
"runTimeout": {
|
|
84
72
|
"description": "Maximum runtime (seconds) of an episode (not necessarily DONE).",
|
|
85
|
-
"type": "
|
|
86
|
-
"minimum":
|
|
87
|
-
"default":
|
|
73
|
+
"type": "number",
|
|
74
|
+
"minimum": 0,
|
|
75
|
+
"default": 1200
|
|
88
76
|
}
|
|
89
77
|
}
|
|
90
78
|
},
|
|
@@ -110,6 +98,23 @@
|
|
|
110
98
|
"observation": {
|
|
111
99
|
"description": "Observation to create an action based upon.",
|
|
112
100
|
"type": "object",
|
|
101
|
+
"additionalProperties": true,
|
|
102
|
+
"properties": {
|
|
103
|
+
"remainingOverageTime": {
|
|
104
|
+
"description": "Total remaining banked time (seconds) that can be used in excess of per-step actTimeouts -- agent is disqualified with TIMEOUT status when this drops below 0.",
|
|
105
|
+
"shared": false,
|
|
106
|
+
"type": "number",
|
|
107
|
+
"minimum": 0,
|
|
108
|
+
"default": 12
|
|
109
|
+
},
|
|
110
|
+
"step": {
|
|
111
|
+
"description": "Current step within the episode.",
|
|
112
|
+
"type": "integer",
|
|
113
|
+
"shared": true,
|
|
114
|
+
"minimum": 0,
|
|
115
|
+
"default": 0
|
|
116
|
+
}
|
|
117
|
+
},
|
|
113
118
|
"default": {}
|
|
114
119
|
},
|
|
115
120
|
"status": {
|