game: goofspiel(imp_info=True,num_cards=4,points_order=descending)

GameType.chance_mode = ChanceMode.EXPLICIT_STOCHASTIC
GameType.dynamics = Dynamics.SIMULTANEOUS
GameType.information = Information.IMPERFECT_INFORMATION
GameType.long_name = "Goofspiel"
GameType.max_num_players = 10
GameType.min_num_players = 2
GameType.parameter_specification = ["imp_info", "num_cards", "players", "points_order", "returns_type"]
GameType.provides_information_state_string = True
GameType.provides_information_state_tensor = True
GameType.provides_observation_string = True
GameType.provides_observation_tensor = True
GameType.provides_factored_observation_string = True
GameType.reward_model = RewardModel.TERMINAL
GameType.short_name = "goofspiel"
GameType.utility = Utility.ZERO_SUM

NumDistinctActions() = 4
PolicyTensorShape() = [4]
MaxChanceOutcomes() = 0
GetParameters() = {imp_info=True,num_cards=4,players=2,points_order=descending,returns_type=win_loss}
NumPlayers() = 2
MinUtility() = -1.0
MaxUtility() = 1.0
UtilitySum() = 0.0
InformationStateTensorShape() = point_totals: [2, 11], player_hand: [4], win_sequence: [4, 2], point_card_sequence: [4, 4], player_action_sequence: [4, 4]
InformationStateTensorLayout() = TensorLayout.CHW
InformationStateTensorSize() = 66
ObservationTensorShape() = current_point_card: [4], point_totals: [2, 11], player_hand: [4], win_sequence: [4, 2]
ObservationTensorLayout() = TensorLayout.CHW
ObservationTensorSize() = 38
MaxGameLength() = 4
ToString() = "goofspiel(imp_info=True,num_cards=4,points_order=descending)"

# State 0
# P0 hand: 1 2 3 4
# P1 hand: 1 2 3 4
# P0 actions:
# P1 actions:
# Point card sequence: 4
# Points: 0 0
IsTerminal() = False
History() = []
HistoryString() = ""
IsChanceNode() = False
IsSimultaneousNode() = True
CurrentPlayer() = -2
InformationStateString(0) = "P0 hand: 1 2 3 4 \nP0 action sequence: \nPoint card sequence: 4 \nWin sequence: \nPoints: 0 0 \nTerminal?: 0\n"
InformationStateString(1) = "P1 hand: 1 2 3 4 \nP1 action sequence: \nPoint card sequence: 4 \nWin sequence: \nPoints: 0 0 \nTerminal?: 0\n"
InformationStateTensor(0).point_totals: ◉◯◯◯◯◯◯◯◯◯◯
                                        ◉◯◯◯◯◯◯◯◯◯◯
InformationStateTensor(0).player_hand: ◉◉◉◉
InformationStateTensor(0).win_sequence: ◯◯
                                        ◯◯
                                        ◯◯
                                        ◯◯
InformationStateTensor(0).point_card_sequence: ◯◯◯◉
                                               ◯◯◯◯
                                               ◯◯◯◯
                                               ◯◯◯◯
InformationStateTensor(0).player_action_sequence: ◯◯◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
InformationStateTensor(1).point_totals: ◉◯◯◯◯◯◯◯◯◯◯
                                        ◉◯◯◯◯◯◯◯◯◯◯
InformationStateTensor(1).player_hand: ◉◉◉◉
InformationStateTensor(1).win_sequence: ◯◯
                                        ◯◯
                                        ◯◯
                                        ◯◯
InformationStateTensor(1).point_card_sequence: ◯◯◯◉
                                               ◯◯◯◯
                                               ◯◯◯◯
                                               ◯◯◯◯
InformationStateTensor(1).player_action_sequence: ◯◯◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
ObservationString(0) = "Current point card: 4\nPoints: 0 0 \nP0 hand: 1 2 3 4 \nWin sequence: \n"
ObservationString(1) = "Current point card: 4\nPoints: 0 0 \nP1 hand: 1 2 3 4 \nWin sequence: \n"
PublicObservationString() = "Current point card: 4\nWin sequence: \nPoints: 0 0 \n"
PrivateObservationString(0) = "Current point card: 4\nPoints: 0 0 \nP0 hand: 1 2 3 4 \nWin sequence: \n"
PrivateObservationString(1) = "Current point card: 4\nPoints: 0 0 \nP1 hand: 1 2 3 4 \nWin sequence: \n"
ObservationTensor(0).current_point_card: ◯◯◯◉
ObservationTensor(0).point_totals: ◉◯◯◯◯◯◯◯◯◯◯
                                   ◉◯◯◯◯◯◯◯◯◯◯
ObservationTensor(0).player_hand: ◉◉◉◉
ObservationTensor(0).win_sequence: ◯◯
                                   ◯◯
                                   ◯◯
                                   ◯◯
ObservationTensor(1).current_point_card: ◯◯◯◉
ObservationTensor(1).point_totals: ◉◯◯◯◯◯◯◯◯◯◯
                                   ◉◯◯◯◯◯◯◯◯◯◯
ObservationTensor(1).player_hand: ◉◉◉◉
ObservationTensor(1).win_sequence: ◯◯
                                   ◯◯
                                   ◯◯
                                   ◯◯
Rewards() = [0.0, 0.0]
Returns() = [0.0, 0.0]
LegalActions(0) = [0, 1, 2, 3]
LegalActions(1) = [0, 1, 2, 3]
StringLegalActions(0) = ["[P0]Bid: 1", "[P0]Bid: 2", "[P0]Bid: 3", "[P0]Bid: 4"]
StringLegalActions(1) = ["[P1]Bid: 1", "[P1]Bid: 2", "[P1]Bid: 3", "[P1]Bid: 4"]

# Apply joint action ["[P0]Bid: 3", "[P1]Bid: 4"]
actions: [2, 3]

# State 1
# P0 hand: 1 2 4
# P1 hand: 1 2 3
# P0 actions: 2
# P1 actions: 3
# Point card sequence: 4 3
# Points: 0 4
IsTerminal() = False
History() = [2, 3]
HistoryString() = "2, 3"
IsChanceNode() = False
IsSimultaneousNode() = True
CurrentPlayer() = -2
InformationStateString(0) = "P0 hand: 1 2 4 \nP0 action sequence: 2 \nPoint card sequence: 4 3 \nWin sequence: 1 \nPoints: 0 4 \nTerminal?: 0\n"
InformationStateString(1) = "P1 hand: 1 2 3 \nP1 action sequence: 3 \nPoint card sequence: 4 3 \nWin sequence: 1 \nPoints: 0 4 \nTerminal?: 0\n"
InformationStateTensor(0).point_totals: ◉◯◯◯◯◯◯◯◯◯◯
                                        ◯◯◯◯◉◯◯◯◯◯◯
InformationStateTensor(0).player_hand: ◉◉◯◉
InformationStateTensor(0).win_sequence: ◯◉
                                        ◯◯
                                        ◯◯
                                        ◯◯
InformationStateTensor(0).point_card_sequence: ◯◯◯◉
                                               ◯◯◉◯
                                               ◯◯◯◯
                                               ◯◯◯◯
InformationStateTensor(0).player_action_sequence: ◯◯◉◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
InformationStateTensor(1).point_totals: ◯◯◯◯◉◯◯◯◯◯◯
                                        ◉◯◯◯◯◯◯◯◯◯◯
InformationStateTensor(1).player_hand: ◉◉◉◯
InformationStateTensor(1).win_sequence: ◯◉
                                        ◯◯
                                        ◯◯
                                        ◯◯
InformationStateTensor(1).point_card_sequence: ◯◯◯◉
                                               ◯◯◉◯
                                               ◯◯◯◯
                                               ◯◯◯◯
InformationStateTensor(1).player_action_sequence: ◯◯◯◉
                                                  ◯◯◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
ObservationString(0) = "Current point card: 3\nPoints: 0 4 \nP0 hand: 1 2 4 \nWin sequence: 1 \n"
ObservationString(1) = "Current point card: 3\nPoints: 0 4 \nP1 hand: 1 2 3 \nWin sequence: 1 \n"
PublicObservationString() = "Current point card: 3\nWin sequence: 1 \nPoints: 0 4 \n"
PrivateObservationString(0) = "Current point card: 3\nPoints: 0 4 \nP0 hand: 1 2 4 \nWin sequence: 1 \n"
PrivateObservationString(1) = "Current point card: 3\nPoints: 0 4 \nP1 hand: 1 2 3 \nWin sequence: 1 \n"
ObservationTensor(0).current_point_card: ◯◯◉◯
ObservationTensor(0).point_totals: ◉◯◯◯◯◯◯◯◯◯◯
                                   ◯◯◯◯◉◯◯◯◯◯◯
ObservationTensor(0).player_hand: ◉◉◯◉
ObservationTensor(0).win_sequence: ◯◉
                                   ◯◯
                                   ◯◯
                                   ◯◯
ObservationTensor(1).current_point_card: ◯◯◉◯
ObservationTensor(1).point_totals: ◯◯◯◯◉◯◯◯◯◯◯
                                   ◉◯◯◯◯◯◯◯◯◯◯
ObservationTensor(1).player_hand: ◉◉◉◯
ObservationTensor(1).win_sequence: ◯◉
                                   ◯◯
                                   ◯◯
                                   ◯◯
Rewards() = [0.0, 0.0]
Returns() = [0.0, 0.0]
LegalActions(0) = [0, 1, 3]
LegalActions(1) = [0, 1, 2]
StringLegalActions(0) = ["[P0]Bid: 1", "[P0]Bid: 2", "[P0]Bid: 4"]
StringLegalActions(1) = ["[P1]Bid: 1", "[P1]Bid: 2", "[P1]Bid: 3"]

# Apply joint action ["[P0]Bid: 2", "[P1]Bid: 1"]
actions: [1, 0]

# State 2
# P0 hand: 1 4
# P1 hand: 2 3
# P0 actions: 2 1
# P1 actions: 3 0
# Point card sequence: 4 3 2
# Points: 3 4
IsTerminal() = False
History() = [2, 3, 1, 0]
HistoryString() = "2, 3, 1, 0"
IsChanceNode() = False
IsSimultaneousNode() = True
CurrentPlayer() = -2
InformationStateString(0) = "P0 hand: 1 4 \nP0 action sequence: 2 1 \nPoint card sequence: 4 3 2 \nWin sequence: 1 0 \nPoints: 3 4 \nTerminal?: 0\n"
InformationStateString(1) = "P1 hand: 2 3 \nP1 action sequence: 3 0 \nPoint card sequence: 4 3 2 \nWin sequence: 1 0 \nPoints: 3 4 \nTerminal?: 0\n"
InformationStateTensor(0).point_totals: ◯◯◯◉◯◯◯◯◯◯◯
                                        ◯◯◯◯◉◯◯◯◯◯◯
InformationStateTensor(0).player_hand: ◉◯◯◉
InformationStateTensor(0).win_sequence: ◯◉
                                        ◉◯
                                        ◯◯
                                        ◯◯
InformationStateTensor(0).point_card_sequence: ◯◯◯◉
                                               ◯◯◉◯
                                               ◯◉◯◯
                                               ◯◯◯◯
InformationStateTensor(0).player_action_sequence: ◯◯◉◯
                                                  ◯◉◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
InformationStateTensor(1).point_totals: ◯◯◯◯◉◯◯◯◯◯◯
                                        ◯◯◯◉◯◯◯◯◯◯◯
InformationStateTensor(1).player_hand: ◯◉◉◯
InformationStateTensor(1).win_sequence: ◯◉
                                        ◉◯
                                        ◯◯
                                        ◯◯
InformationStateTensor(1).point_card_sequence: ◯◯◯◉
                                               ◯◯◉◯
                                               ◯◉◯◯
                                               ◯◯◯◯
InformationStateTensor(1).player_action_sequence: ◯◯◯◉
                                                  ◉◯◯◯
                                                  ◯◯◯◯
                                                  ◯◯◯◯
ObservationString(0) = "Current point card: 2\nPoints: 3 4 \nP0 hand: 1 4 \nWin sequence: 1 0 \n"
ObservationString(1) = "Current point card: 2\nPoints: 3 4 \nP1 hand: 2 3 \nWin sequence: 1 0 \n"
PublicObservationString() = "Current point card: 2\nWin sequence: 1 0 \nPoints: 3 4 \n"
PrivateObservationString(0) = "Current point card: 2\nPoints: 3 4 \nP0 hand: 1 4 \nWin sequence: 1 0 \n"
PrivateObservationString(1) = "Current point card: 2\nPoints: 3 4 \nP1 hand: 2 3 \nWin sequence: 1 0 \n"
ObservationTensor(0).current_point_card: ◯◉◯◯
ObservationTensor(0).point_totals: ◯◯◯◉◯◯◯◯◯◯◯
                                   ◯◯◯◯◉◯◯◯◯◯◯
ObservationTensor(0).player_hand: ◉◯◯◉
ObservationTensor(0).win_sequence: ◯◉
                                   ◉◯
                                   ◯◯
                                   ◯◯
ObservationTensor(1).current_point_card: ◯◉◯◯
ObservationTensor(1).point_totals: ◯◯◯◯◉◯◯◯◯◯◯
                                   ◯◯◯◉◯◯◯◯◯◯◯
ObservationTensor(1).player_hand: ◯◉◉◯
ObservationTensor(1).win_sequence: ◯◉
                                   ◉◯
                                   ◯◯
                                   ◯◯
Rewards() = [0.0, 0.0]
Returns() = [0.0, 0.0]
LegalActions(0) = [0, 3]
LegalActions(1) = [1, 2]
StringLegalActions(0) = ["[P0]Bid: 1", "[P0]Bid: 4"]
StringLegalActions(1) = ["[P1]Bid: 2", "[P1]Bid: 3"]

# Apply joint action ["[P0]Bid: 4", "[P1]Bid: 2"]
actions: [3, 1]

# State 3
# P0 hand:
# P1 hand:
# P0 actions: 2 1 3 0
# P1 actions: 3 0 1 2
# Point card sequence: 4 3 2 1
# Points: 5 5
IsTerminal() = True
History() = [2, 3, 1, 0, 3, 1]
HistoryString() = "2, 3, 1, 0, 3, 1"
IsChanceNode() = False
IsSimultaneousNode() = False
CurrentPlayer() = -4
InformationStateString(0) = "P0 hand: \nP0 action sequence: 2 1 3 0 \nPoint card sequence: 4 3 2 1 \nWin sequence: 1 0 0 1 \nPoints: 5 5 \nTerminal?: 1\n"
InformationStateString(1) = "P1 hand: \nP1 action sequence: 3 0 1 2 \nPoint card sequence: 4 3 2 1 \nWin sequence: 1 0 0 1 \nPoints: 5 5 \nTerminal?: 1\n"
InformationStateTensor(0).point_totals: ◯◯◯◯◯◉◯◯◯◯◯
                                        ◯◯◯◯◯◉◯◯◯◯◯
InformationStateTensor(0).player_hand: ◯◯◯◯
InformationStateTensor(0).win_sequence: ◯◉
                                        ◉◯
                                        ◉◯
                                        ◯◉
InformationStateTensor(0).point_card_sequence: ◯◯◯◉
                                               ◯◯◉◯
                                               ◯◉◯◯
                                               ◉◯◯◯
InformationStateTensor(0).player_action_sequence: ◯◯◉◯
                                                  ◯◉◯◯
                                                  ◯◯◯◉
                                                  ◉◯◯◯
InformationStateTensor(1).point_totals: ◯◯◯◯◯◉◯◯◯◯◯
                                        ◯◯◯◯◯◉◯◯◯◯◯
InformationStateTensor(1).player_hand: ◯◯◯◯
InformationStateTensor(1).win_sequence: ◯◉
                                        ◉◯
                                        ◉◯
                                        ◯◉
InformationStateTensor(1).point_card_sequence: ◯◯◯◉
                                               ◯◯◉◯
                                               ◯◉◯◯
                                               ◉◯◯◯
InformationStateTensor(1).player_action_sequence: ◯◯◯◉
                                                  ◉◯◯◯
                                                  ◯◉◯◯
                                                  ◯◯◉◯
ObservationString(0) = "Current point card: 1\nPoints: 5 5 \nP0 hand: \nWin sequence: 1 0 0 1 \n"
ObservationString(1) = "Current point card: 1\nPoints: 5 5 \nP1 hand: \nWin sequence: 1 0 0 1 \n"
PublicObservationString() = "Current point card: 1\nWin sequence: 1 0 0 1 \nPoints: 5 5 \n"
PrivateObservationString(0) = "Current point card: 1\nPoints: 5 5 \nP0 hand: \nWin sequence: 1 0 0 1 \n"
PrivateObservationString(1) = "Current point card: 1\nPoints: 5 5 \nP1 hand: \nWin sequence: 1 0 0 1 \n"
ObservationTensor(0).current_point_card: ◉◯◯◯
ObservationTensor(0).point_totals: ◯◯◯◯◯◉◯◯◯◯◯
                                   ◯◯◯◯◯◉◯◯◯◯◯
ObservationTensor(0).player_hand: ◯◯◯◯
ObservationTensor(0).win_sequence: ◯◉
                                   ◉◯
                                   ◉◯
                                   ◯◉
ObservationTensor(1).current_point_card: ◉◯◯◯
ObservationTensor(1).point_totals: ◯◯◯◯◯◉◯◯◯◯◯
                                   ◯◯◯◯◯◉◯◯◯◯◯
ObservationTensor(1).player_hand: ◯◯◯◯
ObservationTensor(1).win_sequence: ◯◉
                                   ◉◯
                                   ◉◯
                                   ◯◉
Rewards() = [0.0, 0.0]
Returns() = [0.0, 0.0]
