-
Notifications
You must be signed in to change notification settings - Fork 12
/
Copy pathexample_hello_kspdg.py
43 lines (35 loc) · 1.56 KB
/
example_hello_kspdg.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
# Copyright (c) 2024, MASSACHUSETTS INSTITUTE OF TECHNOLOGY
# Subject to FAR 52.227-11 – Patent Rights – Ownership by the Contractor (May 2014).
# SPDX-License-Identifier: MIT
"""
This script is a "Hello World" for writing agents that can interact with
a KSPDG environment.
Instructions to Run:
- Start KSP game application.
- Select Start Game > Play Missions > Community Created > pe1_i3 > Continue
- In kRPC dialog box click Add server. Select Show advanced settings and select Auto-accept new clients. Then select Start Server
- In a terminal, run this script
"""
from kspdg.pe1.e1_envs import PE1_E1_I3_Env
# instantiate and reset the environment to populate game
env = PE1_E1_I3_Env()
env.reset()
# Environment automatically orients pursuer toward target
# therefore a niave pusuit policy to to simply burn at full
# thrust in pursuer's body-forward direction.
# Do this until the episode
# (Do you think it can intercept even a non-maneuvering evader??)
is_done = False
act = {
"burn_vec": [1.0, 0, 0, 1.0], # burn vector in x, y, z, and duration [s]
"vec_type": 0, # burn vector as throttle values (if =1, burn vector represents thrust in [N])
"ref_frame": 0 # burn_vec expressed in agent vessel's right-handed body frame.
# i.e. forward throttle, right throttle, down throttle,
# Can also use rhcbci (1) and rhntw (2) ref frames
}
while not is_done:
obs, rew, is_done, info = env.step(act)
# printout info to see evaluation metrics of episode
print(info)
# close the environments to cleanup any processes
env.close()