Source code for grid2op.Opponent.baseActionBudget

# Copyright (c) 2019-2020, RTE (https://www.rte-france.com)
# See AUTHORS.txt
# This Source Code Form is subject to the terms of the Mozilla Public License, version 2.0.
# If a copy of the Mozilla Public License, version 2.0 was not distributed with this file,
# you can obtain one at http://mozilla.org/MPL/2.0/.
# SPDX-License-Identifier: MPL-2.0
# This file is part of Grid2Op, Grid2Op a testbed platform to model sequential decision making in power systems.

import numpy as np
from grid2op.Exceptions import OpponentError


[docs]class BaseActionBudget: """ INTERNAL .. warning:: /!\\\\ Internal, do not use unless you know what you are doing /!\\\\ This is the base class representing the action budget. It makes sure the opponent uses the correct type of "action", and compute the bugdet associated to it. """ def __init__(self, action_space): self.action_space = action_space def __call__(self, attack): """ INTERNAL .. warning:: /!\\\\ Internal, do not use unless you know what you are doing /!\\\\ This function takes an attack as input and compute the cost associated to it. **NB** The cost of a "None" attack is necessarily 0 ! Parameters ---------- attack: :class:`ŋrid2op.BaseAction.BaseAction` The attack performed by the opponent Returns ------- cost: the cost of the action performed by the opponent. """ if attack is None: return 0 if not isinstance(attack, self.action_space.actionClass): raise OpponentError( 'Attempt to use an attack of type "{}" which is not a instance of "{}", ' "the type of action the opponent was supposed to use." "".format(type(attack), self.action_space.actionClass) ) aff_lines, aff_subs = attack.get_topological_impact() cost = aff_lines.sum() + aff_subs.sum() return cost