It is recommended to have a look at the 0_basic_functionalities, 1_Observation_Agents and 2_Action_GridManipulation notebooks before getting into this one.
Objectives
In this notebook we will expose :
Action
objects or integers).NB In this tutorial, we train an Agent inspired from this blog post: deep-reinforcement-learning-tutorial-with-open-ai-gym. Many other different reinforcement learning tutorials exist. The code presented in this notebook only aims at demonstrating how to use the Grid2Op functionalities to train a Deep Reinforcement learning Agent and inspect its behaviour, but not at building a very smart agent. Nothing about the performance, training strategy, type of Agent, meta parameters, etc, should be retained as a common practice.
import os
import sys
import grid2op
res = None
try:
from jyquickhelper import add_notebook_menu
res = add_notebook_menu()
except ModuleNotFoundError:
print("Impossible to automatically add a menu / table of content to this notebook.\nYou can download \"jyquickhelper\" package with: \n\"pip install jyquickhelper\"")
res
Impossible to automatically add a menu / table of content to this notebook. You can download "jyquickhelper" package with: "pip install jyquickhelper"
The Grid2op package has been built with an "object-oriented" perspective: almost everything is encapsulated in a dedicated class
. This allows for more customization of the plateform.
The downside of this approach is that machine learning methods, especially in deep learning, often prefer to deal with vectors rather than with "complex" objects. Indeed, as we covered in the previous tutorials on the platform, we saw that building our own actions can be tedious and can sometime require important knowledge of the powergrid.
On the contrary, in most of the standard Reinforcement Learning environments, actions have a higher representation. For example in pacman, there are 4 different types of actions: turn left, turn right, go up and do down. This allows for easy sampling (if you need to achieve an uniform sampling, you simply need to randomly pick a number between 0 and 3 included) and an easy representation: each action can be represented as a different component of a vector of dimension 4 [because there are 4 actions].
On the other hand, this representation is not "human friendly". It is quite convenient in the case of pacman because the action space is rather small, making it possible to remember which action corresponds to which component, but in the case of the grid2op package, there are hundreds or even thousands of actions, making it impossible to remember which component corresponds to which action. We suppose that we do not really care about this here, as tutorials on Reinforcement Learning with discrete action space often assume that actions are labeled with integers (such as in pacman for example).
However, to allow RL agent to train more easily, we allow to make some "Converters" whose roles are to allow an agent to deal with a custom representation of the action space. The class AgentWithConverter is perfect for such usage.
# import the usefull class
import numpy as np
from grid2op import make
from grid2op.Agent import RandomAgent
max_iter = 100 # to make computation much faster we will only consider 50 time steps instead of 287
train_iter = 1000
env_name = "rte_case14_redisp"
env = make(env_name, test=True)
env.seed(0) # this is to ensure the same action are taken by the "RandomAgent".
my_agent = RandomAgent(env.action_space)
/home/benjamin/Documents/grid2op_dev/getting_started/grid2op/MakeEnv/Make.py:240: UserWarning: You are using a development environment. This environment is not intended for training agents. warnings.warn(_MAKE_DEV_ENV_WARN)
And that's it. This agent will be able to perform any action, but instead of going through the description of the actions from a powersystem point of view (ie setting what is connected to what, what is disconnected etc.) it will simply choose an integer with the method my_act
. This integer will then be converted back to a proper action.
Here is an example of the action representation as seen by the Agent (here, integers):
for el in range(3):
print(my_agent.my_act(None, None))
172 47 117
Below you can see that the act
function behaves as expected, handling proper Action
objects:
for el in range(3):
print(my_agent.act(None, None))
This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - NOT switch anything in the topology - Set the bus of the following element: - assign bus 2 to line (extremity) 1 [on substation 4] - assign bus 2 to line (extremity) 9 [on substation 4] - assign bus 1 to line (extremity) 11 [on substation 4] - assign bus 2 to line (origin) 17 [on substation 4] - assign bus 2 to load 4 [on substation 4] This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - Change the bus of the following element: - switch bus of line (origin) 11 [on substation 3] - NOT force any particular bus configuration This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - NOT switch anything in the topology - Set the bus of the following element: - assign bus 2 to line (origin) 2 [on substation 8] - assign bus 1 to line (origin) 3 [on substation 8] - assign bus 1 to line (extremity) 16 [on substation 8] - assign bus 1 to line (extremity) 19 [on substation 8] - assign bus 1 to load 6 [on substation 8]
NB lots of these actions are equivalent to the "do nothing" action at some point. For example, trying to reconnect a powerline that is already connected will not do anything. The same for topology. If everything is already connected to bus 1, then the action to connect things to bus 1 on the same substation will not affect the powergrid.
In this tutorial, we will show how to build a Q-learning Agent. Most of the code originated from this blog post (which was deleted) https://towardsdatascience.com/deep-reinforcement-learning-tutorial-with-open-ai-gym-c0de4471f368.
The goal of this notebook is to demonstrate how to train an agent using grid2op framework. The key message is: since grid2op fully implements the gym API, it is rather easy to do. We will use the l2rpn baselines repository and implement a Double Dueling Deep Q learning Algorithm. For more information, you can look for the code in the dedicated repository here.
Requirements This notebook requires having keras
installed on your machine as well as the l2rpn_baselines
repository.
As always in these notebooks, we will use the rte_case14_realistic
test Environment. More data is available if you don't pass the test=True
parameters.
The type of Agent we are using requires a bit of setup, independantly of Grid2Op. We will reuse the code shown in https://towardsdatascience.com/deep-reinforcement-learning-tutorial-with-open-ai-gym-c0de4471f368 and in Reinforcement-Learning-Tutorial from Abhinav Sagar. The code is registered under the MIT license found here: MIT License.
This first section aims at defining these classes.
You will need to install the l2rpn_baselines library. Since this library is uploaded on Pypi this can be done easily.
print("To install l2rpn_baselines, either uncomment the cell below, or type, in a command prompt:\n{}".format(
("\t{} -m pip install l2rpn_baselines".format(sys.executable))))
To install l2rpn_baselines, either uncomment the cell below, or type, in a command prompt: /usr/bin/python3 -m pip install l2rpn_baselines
# !$sys.executable -m pip install l2rpn_baselines
But first let's import the necessary dependencies :
#tf2.0 friendly
import numpy as np
import random
import warnings
import l2rpn_baselines
# Enable GPU memory growth for Windows
import tensorflow as tf
config = tf.compat.v1.ConfigProto()
config.gpu_options.allow_growth=True
sess = tf.compat.v1.Session(config=config)
#tf2.0 friendly
import numpy as np
import random
import warnings
import tensorflow.keras as tfk
from tensorflow.keras.models import load_model, Sequential, Model
from tensorflow.keras.optimizers import Adam
from tensorflow.keras.layers import Activation, Dropout, Flatten, Dense, subtract, add
from tensorflow.keras.layers import Input, Lambda, Concatenate
DECAY_RATE = 0.9
BUFFER_SIZE = 40000
MINIBATCH_SIZE = 64
TOT_FRAME = 3000000
EPSILON_DECAY = 10000
MIN_OBSERVATION = 42 #5000
FINAL_EPSILON = 1/300 # have on average 1 random action per scenario of approx 287 time steps
INITIAL_EPSILON = 0.1
TAU = 0.01
ALPHA = 1
# Number of frames to "throw" into network
NUM_FRAMES = 1 ## this has been changed compared to the original implementation.
For many of the Deep Reinforcement Learning problems (for example for model used to play Atari games), the inputs are images and the outputs are integers that encode the different possible actions (typically "move up" or "move down" in Atari). In our system (the powergrid) it is rather different. We did our best to make the convertion between complex and simple structures easy. Indeed, the use of converters such as (IdToAct) allows easily to:
Action
objects defined in the previous notebooksIn essence, a converter allows to manipulate the "action space" of the Agent and is such that:
To use this converter, the Agent must inherit from the class grid2op.Agent.AgentWithConverter
and implement the following interface (shown here as an example):
from grid2op.Agent import AgentWithConverter
class MyAgent(AgentWithConverter):
def __init__(self, action_space, action_space_converter=None):
super(MyAgent, self).__init__(action_space=action_space, action_space_converter=action_space_converter)
# for example you can define here all the actions you will consider
self.my_actions = [action_space(),
action_space({"redispatching": [0,+1]}),
action_space({"set_line_status": [(0,-1)]}),
action_space({"change_bus": {"lines_or_id": [12]}}),
...
]
# or load them from a file for example...
# self.my_action = np.load("my_action_pre_selected.npy")
# you can also in this agent load a neural network...
self.my_nn_model = model.load("my_saved_neural_network_weights.h5")
def convert_obs(self, observation):
"""
This method is used to convert the observation, represented as a class Observation in input
into a "transformed_observation" that will be manipulated by the agent
An example here will transform the observation into a numpy array.
It is recommended to modify it to suit your needs.
"""
return observation.to_vect()
def convert_act(self, encoded_act):
"""
This method will take an "encoded_act" (for example a integer) into a valid grid2op action.
"""
if encoded_act < 0 or encoded_act > len(self.my_action):
raise RuntimeError("Invalid action with id {}".format(encoded_act))
return self.my_actions[encoded_act]
def my_act(self, transformed_observation, reward, done=False):
"""
This is the main function where you can take your decision.
Instead of:
- calling "act(observation, reward, done)" you implement
"my_act(transformed_observation, reward, done)"
- this manipulates only "transformed_observation" fully flexible as you defined "convert_obs"
- and returns "encoded_action" that are then digest automatically by
"convert_act(encoded_act)" and to return valid actions.
Here we suppose, as many dqn agent, that `my_nn_model` return a vector of size
nb_actions filled with number between 0 and 1 and we take the action given the highest score
"""
pred_score = self.my_nn_model.predict(transformed_observation, reward, done)
res = np.argmax(pred_score)
return res
And that's it. There is nothing else to do, your agent is ready to learn how to control a powergrid using only these 3 functions.
NB A few things are worth noting:
Action
object in the act method, that you must leave unchanged.Here, we consider the observation as a whole and do not try any modifications of the features. This means that the vector (the observation) that the agent will receive is going to be really big, not scaled and filled with a lot of information that may not be really useful. It could be tried to select only a subset of the available features and apply a pre-processing function to them.
Here we show the most interesting part (in this tutorial) of the code that is implemented as a baseline. For a full description of the code, you can go take a look here.
This is the DoubleDuelingDQN_NN.py
file:
import tensorflow.keras as tfk
class DoubleDuelingDQN_NN(object):
"""Constructs the desired deep q learning network"""
def __init__(self,
action_size,
observation_size,
HIDDEN_FOR_SIMPLICITY
):
self.action_size = action_size
self.observation_size = observation_size
HIDDEN_FOR_SIMPLICITY
def construct_q_network(self):
"""
we showed this here to tell you it was exactly like any keras implementation
"""
input_layer = tfk.Input(shape = (self.observation_size * self.num_frames,), name="input_obs")
lay1 = tfkl.Dense(self.observation_size * 2, name="fc_1")(input_layer)
lay1 = tfka.relu(lay1, alpha=0.01) #leaky_relu
...
HIDDEN_FOR_SIMPLICITY
...
self.model = tfk.Model(...)
def random_move(self):
"""
Moves are encoded by a random number between 0 and the total number of actions.
Easy to do a random move isn't it ? :-)
"""
opt_policy = np.random.randint(0, self.action_size)
return opt_policy
def predict_move(self, data):
"""
in this example we decided to show
"""
model_input = data.reshape(1, self.observation_size * self.num_frames)
q_actions = self.model.predict(model_input, batch_size = 1)
opt_policy = np.argmax(q_actions)
return opt_policy, q_actions[0]
This is the DoubleDuelingDQN.py
file:
from grid2op.Agent import AgentWithConverter # all converter agent should inherit this
from grid2op.Converter import IdToAct # this is the automatic converter to convert action given as ID (integer)
# to valid grid2op action (in particular it is able to compute all actions).
from l2rpn_baselines.DoubleDuelingDQN.DoubleDuelingDQN_NN import DoubleDuelingDQN_NN
class DoubleDuelingDQN(AgentWithConverter):
def __init__(self,
observation_space,
action_space,
HIDDEN_FOR_SIMPLICITY
):
...
HIDDEN_FOR_SIMPLICITY
...
# Load network graph
self.Qmain = DoubleDuelingDQN_NN(self.action_size,
self.observation_size,
HIDDEN_FOR_SIMPLICITY)
## Agent Interface
def convert_obs(self, observation):
# Made a custom version to normalize per attribute
# return observation.to_vect() - like object scaled accordingly
li_vect= []
for el in observation.attr_list_vect:
v = observation._get_array_from_attr_name(el).astype(np.float)
v_fix = np.nan_to_num(v)
v_norm = np.linalg.norm(v_fix)
if v_norm > 1e8:
v_res = (v_fix / v_norm) * 10.0
else:
v_res = v_fix
li_vect.append(v_res)
return np.concatenate(li_vect)
def convert_act(self, action):
"""
calling the convert_act method of the base class.
This is not mandatory as this is the standard behaviour in OOP (object oriented programming)
"""
return super().convert_act(action)
def my_act(self, state, reward, done=False):
"""
The complete implementation of the my_act function
"""
# Register current state to stacking buffer
self._save_current_frame(state)
# We need at least num frames to predict
if len(self.frames) < self.num_frames:
return 0 # Do nothing
# Infer with the last num_frames states
a, _ = self.Qmain.predict_move(np.array(self.frames)) # self.Qmain is of type 'DoubleDuelingDQN_NN' previously defined
return a
Now we can define the agent and train it.
To that extent, we will use the "train" method provided in the l2rpn_baselines
repository.
NB The code below can take a few minutes to run. It's training a Deep Reinforcement Learning Agent after all. It this takes too long on your machine, you can always decrease the "nb_frame", and set it to 1000 for example. In this case, the Agent will probably not be really good.
NB It would take much longer to train a good agent.
# create an environment
env = make(env_name, test=True)
# don't forget to set "test=False" (or remove it, as False is the default value) for "real" training
# import the train function and train your agent
from l2rpn_baselines.DoubleDuelingDQN import train
agent_name = "test_agent"
save_path = "saved_agent_DDDQN_{}".format(train_iter)
train(env,
name=agent_name,
iterations=train_iter,
save_path=save_path,
load_path=None, # put something else if you want to reload an agent instead of creating a new one
logs_path="tf_logs_DDDQN")
/home/benjamin/Documents/grid2op_dev/getting_started/grid2op/MakeEnv/Make.py:240: UserWarning: You are using a development environment. This environment is not intended for training agents. warnings.warn(_MAKE_DEV_ENV_WARN)
Step [0] -- Random [0.99] 60 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 78 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [8] steps Total reward [6602.5159912109375] Survived [3] steps Total reward [3208.1754150390625] 98 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1067.5107421875] 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 90 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 83 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [3211.416015625] 95 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2147.70654296875] 83 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6485.3905029296875] 88 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1065.4486083984375] Survived [1] steps Total reward [1067.9678955078125] 47 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6580.5118408203125] 106 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5299.8193359375] 22 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 46 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 68 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [12] steps Total reward [9965.986572265625] 42 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4294.826416015625] 62 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1065.928955078125] 54 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [8675.7705078125] 93 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 71 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [2144.875244140625] 75 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2120.5009765625] Survived [2] steps Total reward [2120.3284912109375] 37 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 65 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5366.8748779296875] Survived [1] steps Total reward [1077.76806640625] 85 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5384.7044677734375] 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 68 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [6546.499755859375] 86 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [8733.393432617188] Survived [1] steps Total reward [1077.983154296875] 70 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3177.6397705078125] 80 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 90 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 75 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [3252.0419921875] Survived [0] steps Total reward [-10.0] 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [8819.481201171875] 87 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6466.73095703125] Survived [2] steps Total reward [2163.1221923828125] Survived [1] steps Total reward [1068.0589599609375] 73 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3251.0098876953125] Survived [1] steps Total reward [1061.6922607421875] Survived [3] steps Total reward [3248.9903564453125] Survived [2] steps Total reward [2134.5330810546875] Survived [4] steps Total reward [4348.4349365234375] Survived [0] steps Total reward [-10.0] 83 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 40 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [4] steps Total reward [3255.4202880859375] Survived [2] steps Total reward [2106.391845703125] Survived [4] steps Total reward [4267.240234375] 35 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 29 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 75 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [6398.467041015625] 57 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3199.354248046875] 30 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 99 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 100 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 106 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [13] steps Total reward [9859.140258789062] Survived [1] steps Total reward [1078.1507568359375] Survived [3] steps Total reward [3207.1600341796875] Survived [2] steps Total reward [2160.94921875] Survived [1] steps Total reward [1058.2332763671875] Survived [1] steps Total reward [1078.0872802734375] Survived [2] steps Total reward [2134.330078125] 48 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [2158.1317138671875] 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 1000.0 Survived [2] steps Total reward [1058.0113525390625] 70 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [3] steps Total reward [3253.2054443359375] Survived [4] steps Total reward [4293.2239990234375] Survived [2] steps Total reward [2161.01611328125] 100 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2132.712890625] 78 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 106 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [7671.140625] 46 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 68 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [1058.4443359375] Survived [2] steps Total reward [2161.1915283203125] Survived [0] steps Total reward [-10.0] 56 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [7693.3980712890625] Survived [5] steps Total reward [5345.6077880859375] Survived [5] steps Total reward [5451.6357421875] 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [1] steps Total reward [-20.0] Survived [2] steps Total reward [2163.00146484375] Survived [8] steps Total reward [8633.730224609375] 76 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [10] steps Total reward [9911.260009765625] Survived [2] steps Total reward [2132.7193603515625] 93 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3256.2803955078125] Survived [3] steps Total reward [3207.7230224609375] Survived [3] steps Total reward [3253.779296875] 78 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1045.1610107421875] Survived [6] steps Total reward [6570.5205078125] Survived [1] steps Total reward [1067.4835205078125] Survived [4] steps Total reward [4349.2501220703125] Survived [8] steps Total reward [8632.627197265625] Survived [3] steps Total reward [3249.080322265625] loss = 1.3646276 Survived [1] steps Total reward [1068.558837890625] Survived [5] steps Total reward [5445.12060546875] 40 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2124.388916015625] 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2154.9761962890625] 81 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4292.4368896484375] Survived [2] steps Total reward [2162.8861083984375] 26 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2120.9876708984375] Survived [0] steps Total reward [-10.0] 62 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 76 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3179.5240478515625] Survived [2] steps Total reward [2163.1298828125] 21 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4283.6009521484375] 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2143.8634033203125] Survived [4] steps Total reward [4291.1593017578125] Survived [3] steps Total reward [3251.909912109375] Survived [5] steps Total reward [5377.3319091796875] Survived [5] steps Total reward [5407.6572265625] 30 {'disc_lines': array([False, False, False, False, False, True, False, False, False, False, False, False, False, False, True, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [10] steps Total reward [9793.000610351562] 68 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3253.8450927734375] 42 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 50 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3194.419921875] 33 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [1] steps Total reward [-20.0] Survived [1] steps Total reward [1068.6573486328125] Survived [4] steps Total reward [4351.2264404296875] 34 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4293.6063232421875] 58 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 23 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 59 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 79 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 78 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [11] steps Total reward [5528.4085693359375] 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 25 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3195.2822265625] loss = 1.2992628 63 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 81 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 62 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [6553.6273193359375] 97 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 83 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [1048.490234375] 65 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 62 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 97 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [4266.32568359375] 83 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1058.5562744140625] 48 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 42 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5466.044189453125] 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 21 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [2131.6654052734375] Survived [7] steps Total reward [7528.6292724609375] 63 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6463.6431884765625] 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 74 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [4] steps Total reward [3241.0115966796875] 46 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 22 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 63 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 82 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [2101.8616943359375] Survived [3] steps Total reward [3253.170654296875] Survived [1] steps Total reward [1067.2991943359375] Survived [5] steps Total reward [5451.0823974609375] Survived [4] steps Total reward [4296.32373046875] Survived [1] steps Total reward [1078.0606689453125] 54 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 100 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 80 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 31 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [10] steps Total reward [7619.4976806640625] 90 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2154.3724365234375] Survived [3] steps Total reward [3208.465087890625] Survived [1] steps Total reward [1077.788818359375] Survived [2] steps Total reward [2132.377685546875] Survived [3] steps Total reward [3252.261962890625] Survived [1] steps Total reward [1068.3411865234375] Survived [5] steps Total reward [5446.91064453125] Survived [3] steps Total reward [3206.114013671875] 82 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3251.5341796875] loss = 1.2040688 Survived [6] steps Total reward [6475.7763671875] 71 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [1] steps Total reward [-20.0] Survived [2] steps Total reward [2134.4744873046875] Survived [8] steps Total reward [8770.592407226562] 94 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1044.5133056640625] Survived [1] steps Total reward [1077.9725341796875] Survived [3] steps Total reward [3208.2943115234375] Survived [2] steps Total reward [2153.6746826171875] Survived [5] steps Total reward [5376.5982666015625] Survived [1] steps Total reward [1077.9071044921875] 21 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 93 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 84 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 34 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [11] steps Total reward [7550.3662109375] 68 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4345.841552734375] 70 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3219.3173828125] 95 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5470.525390625] Survived [4] steps Total reward [4290.3287353515625] 84 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 78 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [7] steps Total reward [5404.1439208984375] Survived [3] steps Total reward [3209.04296875] 86 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5450.4600830078125] 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 72 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 73 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [7] steps Total reward [5402.09033203125] Survived [1] steps Total reward [1075.765625] 52 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6428.070068359375] Survived [0] steps Total reward [-10.0] 90 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 87 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3211.632568359375] Survived [2] steps Total reward [2162.0762939453125] 80 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 1.1473268 Survived [5] steps Total reward [4305.07275390625] 53 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 35 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 78 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [5454.4654541015625] Survived [1] steps Total reward [1068.1715087890625] 39 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 48 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [10] steps Total reward [8701.160522460938] 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 47 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [2123.2001953125] Survived [0] steps Total reward [-10.0] 23 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [4] steps Total reward [4286.12109375] 70 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5399.928466796875] Survived [0] steps Total reward [-10.0] Survived [3] steps Total reward [3254.173828125] 38 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 44 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 95 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [6480.5660400390625] 47 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [5] steps Total reward [5436.26416015625] 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 38 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3204.61865234375] 91 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1068.1866455078125] Survived [1] steps Total reward [1068.6011962890625] Survived [1] steps Total reward [1077.814697265625] Survived [1] steps Total reward [1068.6815185546875] 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [11] steps Total reward [11072.135498046875] 58 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [1034.3101806640625] 34 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 41 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 95 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 94 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 48 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [12] steps Total reward [7720.90087890625] 36 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4303.022705078125] Survived [4] steps Total reward [4350.0833740234375] 98 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1057.9678955078125] 63 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 47 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 1.1907688 93 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 99 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [10] steps Total reward [6571.940673828125] Survived [2] steps Total reward [2133.7501220703125] Survived [5] steps Total reward [5310.0694580078125] 65 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4296.3909912109375] Survived [0] steps Total reward [-10.0] Survived [4] steps Total reward [4295.474853515625] 79 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5386.3160400390625] Survived [4] steps Total reward [4292.962890625] 70 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2152.4434814453125] Survived [3] steps Total reward [3208.046142578125] Survived [1] steps Total reward [1078.1507568359375] 92 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3189.4132080078125] 50 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 57 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3222.2509765625] Survived [1] steps Total reward [1068.6025390625] 88 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 85 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [6612.673828125] 49 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4295.4315185546875] 35 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2151.3760986328125] 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3205.551513671875] 46 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2155.571533203125] 97 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4290.207763671875] 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 25 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Step [1000] -- Random [0.9430048473807477] Successfully saved model at: saved_agent_DDDQN_1000/test_agent.h5 Survived [7] steps Total reward [5472.593505859375] Survived [0] steps Total reward [-10.0] Survived [3] steps Total reward [3250.31298828125] Survived [5] steps Total reward [5351.5853271484375] Survived [3] steps Total reward [3250.1292724609375] Survived [0] steps Total reward [-10.0] Survived [0] steps Total reward [-10.0] Survived [4] steps Total reward [4295.61083984375] 65 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 1.2030356 42 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [2145.095458984375] 25 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [2134.4920654296875] Survived [5] steps Total reward [5448.824462890625] 28 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 44 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [10] steps Total reward [8757.726806640625] 88 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1065.622314453125] 80 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 29 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [10] steps Total reward [8694.855224609375] 87 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 44 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [6569.5980224609375] 94 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 79 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 92 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 50 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [3189.946533203125] Survived [3] steps Total reward [3251.5859375] 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3151.9537353515625] Survived [4] steps Total reward [4344.1800537109375] 82 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 99 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [6446.7137451171875] Survived [0] steps Total reward [-10.0] Survived [1] steps Total reward [1067.912841796875] Survived [3] steps Total reward [3253.360595703125] Survived [2] steps Total reward [2109.673095703125] 35 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5473.426025390625] Survived [3] steps Total reward [3207.91015625] 52 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5427.3486328125] 39 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3198.552001953125] 82 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2139.4805908203125] 79 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6469.699462890625] 71 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1067.814697265625] loss = 1.1736221 Survived [3] steps Total reward [3193.33935546875] Survived [11] steps Total reward [12147.331909179688] Survived [0] steps Total reward [-10.0] 26 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [6] steps Total reward [6564.5169677734375] Survived [4] steps Total reward [4291.4327392578125] 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4341.1915283203125] Survived [2] steps Total reward [2134.5657958984375] 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3252.7711181640625] 58 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 100 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 88 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [3205.9422607421875] 21 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1067.8363037109375] 68 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 73 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [6498.865966796875] 77 {'disc_lines': array([False, False, False, False, False, True, False, False, False, False, False, False, False, False, True, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 48 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [11] steps Total reward [9974.704345703125] Survived [2] steps Total reward [2133.652587890625] Survived [8] steps Total reward [8746.900146484375] Survived [1] steps Total reward [1068.167724609375] 62 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3188.613525390625] 95 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 80 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 79 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 10 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 80 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [3193.8106689453125] 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Successfully saved model at: saved_agent_DDDQN_1000/test_agent.h5
Logs are saved in the "tf_logs_DDDQN" log repository. To watch what happens during training, you can type the command (from a bash command line for example):
tensorboard --logdir='tf_logs_DDDQN'
You can even do it while it's training.
And now, it is time to test the agent that we trained.
To do that, we have multiple choices.
We can either re-code the "DeepQAgent" class to load the stored weights (that have been saved during training) when it is initialized (this is not covered in this notebook), or we can also directly specify the instance of the Agent to use in the Grid2Op Runner.
Doing this is fairly simple. First, you need to specify that you won't use the "agentClass" argument by setting it to None
, and secondly you simply have to provide the agent instance to be used as the agentInstance argument.
NB If you don't do that, the Runner will be created (the constructor will raise an exception). If you choose to feed the "agentClass" argument with a class, your agent will be re-instanciated from scratch with this class. If you do re-instanciate your agent and if it is not planned in the class to load pre-trained weights, then the agent will not be pre-trained and will be unlikely to perform well on the task.
Now that we have "successfully" trained our Agent, we will evaluate it. As opposed to the training, the evaluation is done classically using a standard Runner.
Note that the Runner will use a "scoring function" that might be different from the "reward function" used during training. In our case, We use the L2RPNReward
function for both training and evaluating.
In the code below, we commented on what can be different and what must be identical for training and evaluating a model.
from grid2op.Runner import Runner
# chose a scoring function (might be different from the reward you use to train your agent)
from grid2op.Reward import L2RPNReward
scoring_function = L2RPNReward
# load your agent
from l2rpn_baselines.DoubleDuelingDQN import DoubleDuelingDQN
my_agent = DoubleDuelingDQN(env.observation_space, env.action_space)
my_agent.load(os.path.join(save_path, "{}.h5".format(agent_name)))
# here we do that to limit the time take, and will only assess the performance on "max_iter" iteration
dict_params = env.get_params_for_runner()
dict_params["gridStateclass_kwargs"]["max_iter"] = max_iter
# make a runner from an intialized environment
runner = Runner(**dict_params, agentClass=None, agentInstance=my_agent)
Succesfully loaded network from: saved_agent_DDDQN_1000/test_agent.h5
Now we will run the Agent and save the results. In order to do that, we specify the path_save
argument. This path allows you to save lots of insights about your Agent's behaviour. Details of all of the information contained in this output are listed in the documentation here.
import shutil
path_save="trained_agent_log"
# delete the previous stored results
if os.path.exists(path_save):
shutil.rmtree(path_save)
# run the episode
res = runner.run(nb_episode=2, path_save=path_save)
print("The results for the trained agent are:")
for _, chron_name, cum_reward, nb_time_step, max_ts in res:
msg_tmp = "\tFor chronics located at {}\n".format(chron_name)
msg_tmp += "\t\t - total score: {:.6f}\n".format(cum_reward)
msg_tmp += "\t\t - number of time steps completed: {:.0f} / {:.0f}".format(nb_time_step, max_ts)
print(msg_tmp)
The results for the trained agent are: For chronics located at 0 - total score: 6470.220215 - number of time steps completed: 10 / 100 For chronics located at 1 - total score: 6559.027832 - number of time steps completed: 10 / 100
Please refer to the official documentation for more information about the contents of the directory where the data is saved. Note that saving the information is triggered by the "path_save" argument of the "runner.run" function.
The information contained in this output will be saved in a structured way and includes : For each episode :
"episode_meta.json": json file that represents some meta information about:
grid2op.Backend
class usedgrid2op.Environment
class used."episode_times.json": json file that gives some information about the total time spent in multiple parts of the runner, mainly the
grid2op.Agent
(and especially its method grid2op.Agent.act
) and the
grid2op.Environment
"_parameters.json": json representation of the grid2op.Parameters
used for this episode
"rewards.npy": numpy 1d-array giving the rewards at each time step. We adopted the convention that the stored
reward at index i
is the one observed by the agent at time i
and NOT the reward sent by the
grid2op.Environment
after the action has been taken.
"exec_times.npy": numpy 1d-array giving the execution time for each time step in the episode
"actions.npy": numpy 2d-array giving the actions that have been taken by the grid2op.Agent
. At row i
of "actions.npy" is a
vectorized representation of the action performed by the agent at timestep i
ie. after having observed
the observation present at row i
of "observation.npy" and the reward showed in row i
of "rewards.npy".
"disc_lines.npy": numpy 2d-array that tells which lines have been disconnected during the simulation of the cascading failure at each
time step. The same convention has been adopted for "rewards.npy". This means that the powerlines are
disconnected when the grid2op.Agent
takes the grid2op.Action
at time step i
.
"observations.npy": numpy 2d-array representing the grid2op.Observation
at the disposal of the
grid2op.Agent
when he took his action.
We can first look at the repository were the data is stored:
import os
os.listdir(path_save)
['dict_env_modification_space.json', '1', 'dict_action_space.json', 'dict_observation_space.json', '0']
As we can see there are 2 folders, each corresponding to a chronics. There are also additional json files.
Now let's see what is inside one of these folders:
os.listdir(os.path.join(path_save, "0"))
['episode_meta.json', 'disc_lines_cascading_failure.npz', 'actions.npz', 'rewards.npz', 'observations.npz', 'agent_exec_times.npz', 'episode_times.json', '_parameters.json', 'other_rewards.json', 'env_modifications.npz']
For example, we can load the actions chosen by the Agent, and have a look at them.
To do that, we will load the action array and use the action_space
function to convert it back to Action
objects.
from grid2op.Episode import EpisodeData
this_episode = EpisodeData.from_disk(path_save, name="0")
all_actions = this_episode.get_actions()
li_actions = []
for i in range(all_actions.shape[0]):
try:
tmp = runner.env.action_space.from_vect(all_actions[i,:])
li_actions.append(tmp)
except:
break
This allows us to have a deeper look at the actions, and their effects.
Now we will inspect the actions that has been taken by the agent :
line_disc = 0
line_reco = 0
for act in li_actions:
dict_ = act.as_dict()
if "set_line_status" in dict_:
line_reco += dict_["set_line_status"]["nb_connected"]
line_disc += dict_["set_line_status"]["nb_disconnected"]
print(f'Total reconnected lines : {line_reco}')
print(f'Total disconnected lines : {line_disc}')
Total reconnected lines : 3 Total disconnected lines : 0
As we can see, during this episode, our agent never tries to disconnect or reconnect a line.
We can also analyse the observations of the recorded episode :
all_observations = this_episode.get_observations()
li_observations = []
nb_real_disc = 0
for i in range(all_observations.shape[0]):
try:
tmp = runner.env.observation_space.from_vect(all_observations[i,:])
li_observations.append(tmp)
nb_real_disc += (np.sum(tmp.line_status == False))
except:
break
print(f'Total number of disconnected powerlines cumulated over all the timesteps : {nb_real_disc}')
Total number of disconnected powerlines cumulated over all the timesteps : 10
We can also look at the kind of actions that the agent chose:
actions_count = {}
for act in li_actions:
act_as_vect = tuple(act.to_vect())
if not act_as_vect in actions_count:
actions_count[act_as_vect] = 0
actions_count[act_as_vect] += 1
print("The agent did {} different valid actions:\n".format(len(actions_count)))
The agent did 7 different valid actions:
The actions chosen by the agent were :
all_act = np.array(list(actions_count.keys()))
for act in all_act:
print(runner.env.action_space.from_vect(act))
This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - NOT switch anything in the topology - NOT force any particular bus configuration This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - Change the bus of the following element: - switch bus of line (origin) 13 [on substation 5] - switch bus of line (origin) 14 [on substation 5] - switch bus of line (extremity) 17 [on substation 5] - switch bus of generator 2 [on substation 5] - NOT force any particular bus configuration This action will: - NOT change anything to the injections - NOT perform any redispatching action - force reconnection of 1 powerlines ([18]) - NOT switch any line status - NOT switch anything in the topology - Set the bus of the following element: - assign bus 2 to line (origin) 18 [on substation 6] - assign bus 1 to line (extremity) 18 [on substation 7] This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - NOT switch anything in the topology - Set the bus of the following element: - assign bus 2 to line (extremity) 0 [on substation 1] - assign bus 2 to line (origin) 7 [on substation 1] - assign bus 1 to line (origin) 8 [on substation 1] - assign bus 2 to line (origin) 9 [on substation 1] - assign bus 1 to generator 0 [on substation 1] - assign bus 2 to load 0 [on substation 1] This action will: - NOT change anything to the injections - NOT perform any redispatching action - force reconnection of 1 powerlines ([17]) - NOT switch any line status - NOT switch anything in the topology - Set the bus of the following element: - assign bus 2 to line (origin) 17 [on substation 4] - assign bus 2 to line (extremity) 17 [on substation 5] This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - Change the bus of the following element: - switch bus of line (origin) 18 [on substation 6] - switch bus of line (origin) 19 [on substation 6] - NOT force any particular bus configuration This action will: - NOT change anything to the injections - NOT perform any redispatching action - NOT force any line status - NOT switch any line status - NOT switch anything in the topology - Set the bus of the following element: - assign bus 2 to line (extremity) 8 [on substation 3] - assign bus 2 to line (extremity) 10 [on substation 3] - assign bus 1 to line (origin) 11 [on substation 3] - assign bus 1 to line (origin) 15 [on substation 3] - assign bus 2 to line (origin) 16 [on substation 3] - assign bus 1 to load 3 [on substation 3]
As we saw, the agent we developped was not really interesting. To improve it, we could think about:
In this notebook, we will focus on changing the observation representation, by only feeding to the agent a part of the available information.
To do so, the only thing that we need to do is to modify the way the observation is converted in the convert_obs
method, and that is it. Nothing else needs to be changed. Here for example, we could think of only using the flow ratio (i.e., the current flow divided by the thermal limit, named rho) instead of feeding the whole observation to the agent
class DoubleDuelingDQN_Improved(DoubleDuelingDQN):
def convert_obs(self, observation):
"""
And by just changing that, i can change what is fed to the neural network :-)
NB: i need however to tell in the initialization of the neural network the changes I made...
"""
return observation.rho
def __init__(self,
observation_space,
action_space,
name=__name__,
num_frames=4,
is_training=False,
batch_size=32,
lr=1e-5):
"""
We have changed the size of the observation, so we need to re create another neural network with
the proper input size.
That is why we need to change this.
"""
# Call parent constructor
DoubleDuelingDQN.__init__(self,
observation_space=observation_space,
action_space=action_space,
name=name,
num_frames=num_frames,
is_training=is_training,
batch_size=batch_size,
lr=lr)
# import some constant and the class for this baseline
from l2rpn_baselines.DoubleDuelingDQN.DoubleDuelingDQN_NN import DoubleDuelingDQN_NN
from l2rpn_baselines.DoubleDuelingDQN.DoubleDuelingDQN import LR_DECAY_STEPS, LR_DECAY_RATE
# Compute dimensions from intial spaces
self.observation_size = self.obs_space.n_line
# Load network graph
self.Qmain = DoubleDuelingDQN_NN(self.action_size,
self.observation_size,
num_frames = self.num_frames,
learning_rate = self.lr,
learning_rate_decay_steps = LR_DECAY_STEPS,
learning_rate_decay_rate = LR_DECAY_RATE)
# Setup training vars if needed
if self.is_training:
self._init_training()
And we can reuse the generic method provided by l2rpn_baselines to train it.
from l2rpn_baselines.utils import train_generic
agent_name = "test_agent2"
save_path = "saved_agent_DDDQN2_{}".format(train_iter)
my_new_agent = DoubleDuelingDQN_Improved(env.observation_space,
env.action_space,
is_training=True,
name=agent_name)
my_new_agent_trained = train_generic(agent=my_new_agent,
env=env,
iterations=train_iter,
save_path="saved_agent_DDDQN_{}".format(train_iter))
Step [0] -- Random [0.99] 56 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [7521.9539794921875] 50 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6587.2149658203125] Survived [0] steps Total reward [-10.0] Survived [3] steps Total reward [3252.8548583984375] 65 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1058.4443359375] 64 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 49 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [7728.1346435546875] 87 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [2129.9864501953125] Survived [2] steps Total reward [2162.3546142578125] 96 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 36 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 47 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [5395.7259521484375] 51 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 56 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [1055.3546142578125] Survived [2] steps Total reward [2133.289794921875] Survived [3] steps Total reward [3253.58837890625] 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 49 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [1035.875732421875] 42 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6560.983642578125] 92 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 60 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 34 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [4315.851806640625] Survived [2] steps Total reward [2134.6702880859375] Survived [1] steps Total reward [1068.6011962890625] Survived [4] steps Total reward [4348.5252685546875] 50 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3214.8037109375] Survived [2] steps Total reward [2155.882080078125] 28 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 34 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [7626.9559326171875] Survived [1] steps Total reward [1077.0111083984375] Survived [5] steps Total reward [5375.51318359375] Survived [3] steps Total reward [3253.426025390625] 34 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 774.2992 Survived [9] steps Total reward [8578.70458984375] 54 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 38 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 34 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [6575.8154296875] Survived [3] steps Total reward [3208.324951171875] 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4325.2081298828125] 97 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [17] steps Total reward [16658.271606445312] Survived [1] steps Total reward [1077.8489990234375] 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2132.5130615234375] Survived [1] steps Total reward [1078.0638427734375] Survived [4] steps Total reward [4275.7174072265625] Survived [0] steps Total reward [-10.0] Survived [0] steps Total reward [-10.0] Survived [4] steps Total reward [4346.470703125] 78 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2120.699462890625] Survived [4] steps Total reward [4329.4078369140625] 97 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4313.68798828125] Survived [0] steps Total reward [-10.0] 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3220.4822998046875] Survived [2] steps Total reward [2161.7779541015625] Survived [3] steps Total reward [3167.637939453125] 81 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 53 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4345.976318359375] Survived [2] steps Total reward [2134.0416259765625] 47 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6552.2781982421875] Survived [3] steps Total reward [3208.3668212890625] Survived [2] steps Total reward [2159.5635986328125] 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4292.58056640625] 78 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 99 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [1055.2578125] loss = 5.2718916 Survived [3] steps Total reward [3203.4613037109375] Survived [2] steps Total reward [2163.5150146484375] Survived [0] steps Total reward [-10.0] 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 82 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 25 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [1049.7996826171875] Survived [3] steps Total reward [3207.42041015625] Survived [6] steps Total reward [6541.8135986328125] Survived [3] steps Total reward [3209.370361328125] Survived [1] steps Total reward [1077.6328125] Survived [1] steps Total reward [1068.658447265625] 95 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 29 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4348.2022705078125] Survived [5] steps Total reward [5378.7962646484375] 48 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4228.8333740234375] Survived [0] steps Total reward [-10.0] 26 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4337.539794921875] Survived [4] steps Total reward [4289.73779296875] Survived [3] steps Total reward [3251.739013671875] Survived [2] steps Total reward [2133.9208984375] 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4339.4173583984375] Survived [7] steps Total reward [7530.447998046875] Survived [2] steps Total reward [2162.7066650390625] 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 70 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 100 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [4297.2738037109375] 59 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 55 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [6442.7886962890625] 24 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4250.4561767578125] Survived [1] steps Total reward [1077.9427490234375] 86 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 26 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [7580.5150146484375] 30 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [4] steps Total reward [4346.5711669921875] Survived [2] steps Total reward [2134.066650390625] loss = 5.676509 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5473.0289306640625] 80 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3219.62451171875] Survived [0] steps Total reward [-10.0] 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 72 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 63 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [5327.8651123046875] 60 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 75 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5467.77783203125] Survived [2] steps Total reward [2134.3577880859375] 75 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 81 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5470.578369140625] Survived [8] steps Total reward [8676.089233398438] 33 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1065.4189453125] 64 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [1] steps Total reward [-20.0] 46 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 79 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3235.5303955078125] 49 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3155.5050048828125] Survived [2] steps Total reward [2162.1298828125] Survived [0] steps Total reward [-10.0] 84 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 95 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [1067.3441162109375] 65 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 36 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3209.15380859375] Survived [0] steps Total reward [-10.0] Survived [3] steps Total reward [3209.573974609375] 98 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4354.050048828125] Survived [5] steps Total reward [5345.17724609375] 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 44 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [6] steps Total reward [5444.0306396484375] Survived [3] steps Total reward [3204.26416015625] Survived [4] steps Total reward [4344.8369140625] 63 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4281.88525390625] Survived [0] steps Total reward [-10.0] 91 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4300.7921142578125] 41 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 6.0920753 Survived [11] steps Total reward [11062.380981445312] 51 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 78 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [2130.831787109375] Survived [6] steps Total reward [6566.5330810546875] 95 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1058.3140869140625] Survived [2] steps Total reward [2162.8404541015625] 24 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3184.5850830078125] Survived [2] steps Total reward [2162.5576171875] Survived [0] steps Total reward [-10.0] 25 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1064.6839599609375] 36 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 85 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3189.3504638671875] Survived [6] steps Total reward [6569.697265625] Survived [6] steps Total reward [6476.77197265625] Survived [2] steps Total reward [2161.9366455078125] Survived [1] steps Total reward [1068.84814453125] Survived [2] steps Total reward [2163.09423828125] Survived [5] steps Total reward [5381.5885009765625] Survived [1] steps Total reward [1077.587158203125] Survived [1] steps Total reward [1068.618896484375] Survived [2] steps Total reward [2163.412353515625] 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4294.0098876953125] 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4336.233642578125] Survived [1] steps Total reward [1067.7320556640625] Survived [2] steps Total reward [2161.2618408203125] Survived [0] steps Total reward [-10.0] 92 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 96 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [1060.29638671875] 43 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5381.4656982421875] Survived [2] steps Total reward [2162.154296875] Survived [4] steps Total reward [4295.9267578125] 24 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [6561.3193359375] Survived [2] steps Total reward [2133.7822265625] loss = 6.090977 Survived [0] steps Total reward [-10.0] Survived [1] steps Total reward [1068.6573486328125] Survived [1] steps Total reward [1077.0111083984375] Survived [2] steps Total reward [2134.9063720703125] 54 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, True, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2142.583984375] 44 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5375.6466064453125] Survived [1] steps Total reward [1077.91943359375] 37 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [8649.608276367188] Survived [0] steps Total reward [-10.0] Survived [3] steps Total reward [3188.001953125] Survived [2] steps Total reward [2160.46435546875] Survived [3] steps Total reward [3208.756591796875] 30 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 49 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [15] steps Total reward [14590.5361328125] 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 21 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [-30.0] Survived [3] steps Total reward [3243.138916015625] Survived [0] steps Total reward [-10.0] Survived [2] steps Total reward [2162.46875] Survived [0] steps Total reward [-10.0] 36 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 47 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 66 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [5422.6693115234375] 52 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 24 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [6469.8675537109375] 66 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4353.27099609375] Survived [2] steps Total reward [2110.7213134765625] Survived [0] steps Total reward [-10.0] Survived [3] steps Total reward [3208.1649169921875] 83 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [2163.3531494140625] 24 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5391.3681640625] 99 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4349.7081298828125] Survived [3] steps Total reward [3208.6741943359375] Survived [2] steps Total reward [2161.6563720703125] 68 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 29 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 5.4945035 65 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [3212.6279296875] 69 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [8532.496704101562] 86 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [1] steps Total reward [-20.0] Survived [2] steps Total reward [2148.9364013671875] Survived [0] steps Total reward [-10.0] Survived [2] steps Total reward [2163.6729736328125] Survived [2] steps Total reward [2121.97119140625] 88 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 54 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [6446.3560791015625] 82 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2118.8974609375] Survived [3] steps Total reward [3245.4925537109375] 51 {'disc_lines': array([False, False, False, False, False, False, False, False, False, True, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 49 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [4285.3919677734375] Survived [2] steps Total reward [2160.1024169921875] 86 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2130.415771484375] 90 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 36 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 30 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [-40.0] Survived [1] steps Total reward [1068.6549072265625] Survived [2] steps Total reward [2163.4512939453125] Survived [2] steps Total reward [2134.6297607421875] 61 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 49 {'disc_lines': array([False, False, False, False, False, True, False, False, False, False, False, False, False, False, True, False, False, True, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 63 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [8] steps Total reward [5350.39599609375] 98 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2132.389892578125] Survived [0] steps Total reward [-10.0] 94 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3211.6798095703125] Survived [0] steps Total reward [-10.0] 93 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1058.649658203125] 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2154.82373046875] Survived [1] steps Total reward [1068.91162109375] 58 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2150.6158447265625] Survived [4] steps Total reward [4293.26220703125] Survived [3] steps Total reward [3249.8455810546875] Survived [1] steps Total reward [1068.3140869140625] 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2152.950439453125] Survived [0] steps Total reward [-10.0] Survived [1] steps Total reward [1077.9964599609375] Survived [2] steps Total reward [2122.6461181640625] Survived [0] steps Total reward [-10.0] 89 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 5.267556 Survived [4] steps Total reward [3186.5091552734375] 31 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 41 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [2127.794677734375] Survived [2] steps Total reward [2134.5648193359375] 64 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2154.9381103515625] 74 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 24 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [2135.8975830078125] Survived [0] steps Total reward [-10.0] Survived [1] steps Total reward [1068.4127197265625] 97 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 91 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 53 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 86 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [20] steps Total reward [17837.960083007812] 86 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2119.833984375] 59 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 47 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 77 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [2086.48388671875] Survived [1] steps Total reward [1068.0113525390625] 30 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 73 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [13] steps Total reward [12076.154296875] 35 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4278.3341064453125] 68 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3243.50390625] Survived [2] steps Total reward [2134.5728759765625] 83 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [4] steps Total reward [3242.2886962890625] Survived [1] steps Total reward [1068.5655517578125] Survived [3] steps Total reward [3253.8099365234375] 98 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 44 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5409.1068115234375] 23 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Step [1000] -- Random [0.9295309194857401] Successfully saved model at: saved_agent_DDDQN_1000/test_agent2.h5 Survived [4] steps Total reward [3251.837890625] 37 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4296.3802490234375] 96 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 45 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [1067.0111083984375] Survived [3] steps Total reward [3207.0372314453125] Survived [1] steps Total reward [1077.0946044921875] Survived [2] steps Total reward [2127.5086669921875] 86 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} loss = 5.2421956 Survived [4] steps Total reward [3250.738037109375] 51 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [6] steps Total reward [5390.1983642578125] 65 {'disc_lines': array([False, False, False, False, False, True, False, False, False, False, False, False, False, False, True, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4288.6419677734375] 28 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [2123.818359375] 49 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4296.6048583984375] 32 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [9] steps Total reward [8712.962646484375] Survived [8] steps Total reward [8792.678833007812] 21 {'disc_lines': None, 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal'), Grid2OpException DivergingPowerFlow DivergingPowerFlow('Powerflow has diverged during computation.')], 'rewards': {}} Survived [2] steps Total reward [2123.257080078125] 73 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [4351.071044921875] Survived [0] steps Total reward [-10.0] 79 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [1] steps Total reward [-20.0] 71 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [2] steps Total reward [1045.4710693359375] Survived [0] steps Total reward [-10.0] Survived [3] steps Total reward [3209.0240478515625] 73 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 24 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [7] steps Total reward [5473.9801025390625] Survived [10] steps Total reward [10931.128540039062] Survived [5] steps Total reward [5356.6353759765625] Survived [4] steps Total reward [4294.8941650390625] 39 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 67 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [3] steps Total reward [1060.2774658203125] 93 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} 67 {'disc_lines': array([False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False, False]), 'is_illegal': True, 'is_ambiguous': False, 'is_dispatching_illegal': False, 'is_illegal_reco': False, 'exception': [Grid2OpException IllegalAction IllegalAction('BaseAction illegal')], 'rewards': {}} Survived [5] steps Total reward [3197.71142578125] Successfully saved model at: saved_agent_DDDQN_1000/test_agent2.h5
And we re-use the code that we wrote earlier to assess its performance.
runner2 = Runner(**dict_params, agentClass=None, agentInstance=my_new_agent_trained)
# run the episode
res = runner2.run(nb_episode=2, path_save=path_save)
print("The results for the trained agent are:")
for _, chron_name, cum_reward, nb_time_step, max_ts in res:
msg_tmp = "\tFor chronics located at {}\n".format(chron_name)
msg_tmp += "\t\t - total score: {:.6f}\n".format(cum_reward)
msg_tmp += "\t\t - number of time steps completed: {:.0f} / {:.0f}".format(nb_time_step, max_ts)
print(msg_tmp)
The results for the trained agent are: For chronics located at 0 - total score: 5379.121094 - number of time steps completed: 6 / 100 For chronics located at 1 - total score: 3253.798584 - number of time steps completed: 4 / 100