#include <any>
#include <iostream>
#include <string>
#include <unordered_map>
{
const std::string
SERVER_URL =
"http://0.0.0.0:8001/api";
{
<< std::endl;
GymWalk<4> env(server);
std::cout << "Is environment registered: " << server.is_env_registered(env.env_name())
<< std::endl;
std::cout << "Environment URL: " << env.get_url() << std::endl;
std::unordered_map<std::string, std::any> make_ops;
std::unordered_map<std::string, std::any> reset_ops;
reset_ops.insert({
"seed",
static_cast<uint_t>(42)});
env.make("v1", make_ops, reset_ops);
std::cout << "Environment version: " << env.version() << std::endl;
std::cout << "Environment idx is: " << env.idx() << std::endl;
std::cout << "Is environment created? " << env.is_created() << std::endl;
std::cout << "Is environment alive? " << env.is_alive() << std::endl;
std::cout << "Number of valid actions? " << env.n_actions() << std::endl;
std::cout << "Number of states? " << env.n_states() << std::endl;
auto time_step = env.reset();
std::cout << "Reward on reset: " << time_step.reward() << std::endl;
std::cout << "Observation on reset: " << time_step.observation() << std::endl;
std::cout << "Is terminal state: " << time_step.done() << std::endl;
std::cout << time_step << std::endl;
auto new_time_step = env.step(1);
std::cout << new_time_step << std::endl;
auto state = 0;
auto action = 1;
auto dynamics = env.p(state, action);
std::cout << "Dynamics for state=" << state << " and action=" << action << std::endl;
for (auto item : dynamics)
{
std::cout << std::get<0>(item) << std::endl;
std::cout << std::get<1>(item) << std::endl;
std::cout << std::get<2>(item) << std::endl;
std::cout << std::get<3>(item) << std::endl;
}
std::cout <<
"Action sampled: " <<
action << std::endl;
new_time_step =
env.step(action);
std::cout << new_time_step << std::endl;
}
}
{
std::cout << "Testing GymWalk..." << std::endl;
std::cout << "====================" << std::endl;
return 0;
}
static const std::string name
Definition gym_walk.h:46
Utility class to facilitate HTTP requests between the environments REST API and C++ drivers.
Definition rest_rl_env_client.h:29
bool is_env_registered(const std::string &env_name) const noexcept
Definition rest_rl_env_client.cpp:39
int main()
Definition intro_example_1.cpp:31
Definition bitrl_consts.h:14
std::size_t uint_t
uint_t
Definition bitrl_types.h:43
Definition rl_example_1.cpp:13
const std::string SERVER_URL
Definition example_1.cpp:17
void test_gymwalk(RESTRLEnvClient &server)
Definition example_2.cpp:19
dict action
Definition play.py:41