game: leduc_poker

GameType.chance_mode = ChanceMode.EXPLICIT_STOCHASTIC
GameType.dynamics = Dynamics.SEQUENTIAL
GameType.information = Information.IMPERFECT_INFORMATION
GameType.long_name = "Leduc Poker"
GameType.max_num_players = 10
GameType.min_num_players = 2
GameType.parameter_specification = ["action_mapping", "players", "suit_isomorphism"]
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 = False
GameType.reward_model = RewardModel.TERMINAL
GameType.short_name = "leduc_poker"
GameType.utility = Utility.ZERO_SUM

NumDistinctActions() = 3
PolicyTensorShape() = [3]
MaxChanceOutcomes() = 6
GetParameters() = {action_mapping=False,players=2,suit_isomorphism=False}
NumPlayers() = 2
MinUtility() = -13.0
MaxUtility() = 13.0
UtilitySum() = 0.0
InformationStateTensorShape() = player: [2], private_card: [6], community_card: [6], betting: [2, 4, 2]
InformationStateTensorLayout() = TensorLayout.CHW
InformationStateTensorSize() = 30
ObservationTensorShape() = player: [2], private_card: [6], community_card: [6], pot_contribution: [2]
ObservationTensorLayout() = TensorLayout.CHW
ObservationTensorSize() = 16
MaxGameLength() = 8
ToString() = "leduc_poker()"

# State 0
# Round: 1
# Player: -1
# Pot: 2
# Money (p1 p2 ...): 99 99
# Cards (public p1 p2 ...): -10000 -10000 -10000
# Round 1 sequence:
# Round 2 sequence:
IsTerminal() = False
History() = []
HistoryString() = ""
IsChanceNode() = True
IsSimultaneousNode() = False
CurrentPlayer() = -1
InformationStateString(0) = "[Observer: 0][Private: -10000][Round 1][Player: -1][Pot: 2][Money: 99 99][Round1: ][Round2: ]"
InformationStateString(1) = "[Observer: 1][Private: -10000][Round 1][Player: -1][Pot: 2][Money: 99 99][Round1: ][Round2: ]"
InformationStateTensor(0).player: ◉◯
InformationStateTensor(0).private_card: ◯◯◯◯◯◯
InformationStateTensor(0).community_card: ◯◯◯◯◯◯
InformationStateTensor(0).betting:
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
InformationStateTensor(1).player: ◯◉
InformationStateTensor(1).private_card: ◯◯◯◯◯◯
InformationStateTensor(1).community_card: ◯◯◯◯◯◯
InformationStateTensor(1).betting:
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
ObservationString(0) = "[Observer: 0][Private: -10000][Round 1][Player: -1][Pot: 2][Money: 99 99][Ante: 1 1]"
ObservationString(1) = "[Observer: 1][Private: -10000][Round 1][Player: -1][Pot: 2][Money: 99 99][Ante: 1 1]"
PublicObservationString() = "[Round 1][Player: -1][Pot: 2][Money: 99 99][Ante: 1 1]"
PrivateObservationString(0) = "[Observer: 0][Private: -10000]"
PrivateObservationString(1) = "[Observer: 1][Private: -10000]"
ObservationTensor(0).player: ◉◯
ObservationTensor(0).private_card: ◯◯◯◯◯◯
ObservationTensor(0).community_card: ◯◯◯◯◯◯
ObservationTensor(0).pot_contribution: ◉◉
ObservationTensor(1).player: ◯◉
ObservationTensor(1).private_card: ◯◯◯◯◯◯
ObservationTensor(1).community_card: ◯◯◯◯◯◯
ObservationTensor(1).pot_contribution: ◉◉
ChanceOutcomes() = [{0, 0.166666666667}, {1, 0.166666666667}, {2, 0.166666666667}, {3, 0.166666666667}, {4, 0.166666666667}, {5, 0.166666666667}]
LegalActions() = [0, 1, 2, 3, 4, 5]
StringLegalActions() = ["Chance outcome:0", "Chance outcome:1", "Chance outcome:2", "Chance outcome:3", "Chance outcome:4", "Chance outcome:5"]

# Apply action "Chance outcome:5"
action: 5

# State 1
# Round: 1
# Player: -1
# Pot: 2
# Money (p1 p2 ...): 99 99
# Cards (public p1 p2 ...): -10000 5 -10000
# Round 1 sequence:
# Round 2 sequence:
IsTerminal() = False
History() = [5]
HistoryString() = "5"
IsChanceNode() = True
IsSimultaneousNode() = False
CurrentPlayer() = -1
InformationStateString(0) = "[Observer: 0][Private: 5][Round 1][Player: -1][Pot: 2][Money: 99 99][Round1: ][Round2: ]"
InformationStateString(1) = "[Observer: 1][Private: -10000][Round 1][Player: -1][Pot: 2][Money: 99 99][Round1: ][Round2: ]"
InformationStateTensor(0).player: ◉◯
InformationStateTensor(0).private_card: ◯◯◯◯◯◉
InformationStateTensor(0).community_card: ◯◯◯◯◯◯
InformationStateTensor(0).betting:
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
InformationStateTensor(1).player: ◯◉
InformationStateTensor(1).private_card: ◯◯◯◯◯◯
InformationStateTensor(1).community_card: ◯◯◯◯◯◯
InformationStateTensor(1).betting:
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
ObservationString(0) = "[Observer: 0][Private: 5][Round 1][Player: -1][Pot: 2][Money: 99 99][Ante: 1 1]"
ObservationString(1) = "[Observer: 1][Private: -10000][Round 1][Player: -1][Pot: 2][Money: 99 99][Ante: 1 1]"
PublicObservationString() = "[Round 1][Player: -1][Pot: 2][Money: 99 99][Ante: 1 1]"
PrivateObservationString(0) = "[Observer: 0][Private: 5]"
PrivateObservationString(1) = "[Observer: 1][Private: -10000]"
ObservationTensor(0).player: ◉◯
ObservationTensor(0).private_card: ◯◯◯◯◯◉
ObservationTensor(0).community_card: ◯◯◯◯◯◯
ObservationTensor(0).pot_contribution: ◉◉
ObservationTensor(1).player: ◯◉
ObservationTensor(1).private_card: ◯◯◯◯◯◯
ObservationTensor(1).community_card: ◯◯◯◯◯◯
ObservationTensor(1).pot_contribution: ◉◉
ChanceOutcomes() = [{0, 0.200000000000}, {1, 0.200000000000}, {2, 0.200000000000}, {3, 0.200000000000}, {4, 0.200000000000}]
LegalActions() = [0, 1, 2, 3, 4]
StringLegalActions() = ["Chance outcome:0", "Chance outcome:1", "Chance outcome:2", "Chance outcome:3", "Chance outcome:4"]

# Apply action "Chance outcome:1"
action: 1

# State 2
# Round: 1
# Player: 0
# Pot: 2
# Money (p1 p2 ...): 99 99
# Cards (public p1 p2 ...): -10000 5 1
# Round 1 sequence:
# Round 2 sequence:
IsTerminal() = False
History() = [5, 1]
HistoryString() = "5, 1"
IsChanceNode() = False
IsSimultaneousNode() = False
CurrentPlayer() = 0
InformationStateString(0) = "[Observer: 0][Private: 5][Round 1][Player: 0][Pot: 2][Money: 99 99][Round1: ][Round2: ]"
InformationStateString(1) = "[Observer: 1][Private: 1][Round 1][Player: 0][Pot: 2][Money: 99 99][Round1: ][Round2: ]"
InformationStateTensor(0).player: ◉◯
InformationStateTensor(0).private_card: ◯◯◯◯◯◉
InformationStateTensor(0).community_card: ◯◯◯◯◯◯
InformationStateTensor(0).betting:
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
InformationStateTensor(1).player: ◯◉
InformationStateTensor(1).private_card: ◯◉◯◯◯◯
InformationStateTensor(1).community_card: ◯◯◯◯◯◯
InformationStateTensor(1).betting:
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
ObservationString(0) = "[Observer: 0][Private: 5][Round 1][Player: 0][Pot: 2][Money: 99 99][Ante: 1 1]"
ObservationString(1) = "[Observer: 1][Private: 1][Round 1][Player: 0][Pot: 2][Money: 99 99][Ante: 1 1]"
PublicObservationString() = "[Round 1][Player: 0][Pot: 2][Money: 99 99][Ante: 1 1]"
PrivateObservationString(0) = "[Observer: 0][Private: 5]"
PrivateObservationString(1) = "[Observer: 1][Private: 1]"
ObservationTensor(0).player: ◉◯
ObservationTensor(0).private_card: ◯◯◯◯◯◉
ObservationTensor(0).community_card: ◯◯◯◯◯◯
ObservationTensor(0).pot_contribution: ◉◉
ObservationTensor(1).player: ◯◉
ObservationTensor(1).private_card: ◯◉◯◯◯◯
ObservationTensor(1).community_card: ◯◯◯◯◯◯
ObservationTensor(1).pot_contribution: ◉◉
Rewards() = [0.0, 0.0]
Returns() = [0.0, 0.0]
LegalActions() = [1, 2]
StringLegalActions() = ["Call", "Raise"]

# Apply action "Raise"
action: 2

# State 3
# Round: 1
# Player: 1
# Pot: 4
# Money (p1 p2 ...): 97 99
# Cards (public p1 p2 ...): -10000 5 1
# Round 1 sequence: Raise
# Round 2 sequence:
IsTerminal() = False
History() = [5, 1, 2]
HistoryString() = "5, 1, 2"
IsChanceNode() = False
IsSimultaneousNode() = False
CurrentPlayer() = 1
InformationStateString(0) = "[Observer: 0][Private: 5][Round 1][Player: 1][Pot: 4][Money: 97 99][Round1: 2][Round2: ]"
InformationStateString(1) = "[Observer: 1][Private: 1][Round 1][Player: 1][Pot: 4][Money: 97 99][Round1: 2][Round2: ]"
InformationStateTensor(0).player: ◉◯
InformationStateTensor(0).private_card: ◯◯◯◯◯◉
InformationStateTensor(0).community_card: ◯◯◯◯◯◯
InformationStateTensor(0).betting:
◯◉  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
InformationStateTensor(1).player: ◯◉
InformationStateTensor(1).private_card: ◯◉◯◯◯◯
InformationStateTensor(1).community_card: ◯◯◯◯◯◯
InformationStateTensor(1).betting:
◯◉  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
ObservationString(0) = "[Observer: 0][Private: 5][Round 1][Player: 1][Pot: 4][Money: 97 99][Ante: 3 1]"
ObservationString(1) = "[Observer: 1][Private: 1][Round 1][Player: 1][Pot: 4][Money: 97 99][Ante: 3 1]"
PublicObservationString() = "[Round 1][Player: 1][Pot: 4][Money: 97 99][Ante: 3 1]"
PrivateObservationString(0) = "[Observer: 0][Private: 5]"
PrivateObservationString(1) = "[Observer: 1][Private: 1]"
ObservationTensor(0).player: ◉◯
ObservationTensor(0).private_card: ◯◯◯◯◯◉
ObservationTensor(0).community_card: ◯◯◯◯◯◯
ObservationTensor(0).pot_contribution = [3.0, 1.0]
ObservationTensor(1).player: ◯◉
ObservationTensor(1).private_card: ◯◉◯◯◯◯
ObservationTensor(1).community_card: ◯◯◯◯◯◯
ObservationTensor(1).pot_contribution = [3.0, 1.0]
Rewards() = [0.0, 0.0]
Returns() = [0.0, 0.0]
LegalActions() = [0, 1, 2]
StringLegalActions() = ["Fold", "Call", "Raise"]

# Apply action "Fold"
action: 0

# State 4
# Round: 1
# Player: 1
# Pot: 0
# Money (p1 p2 ...): 101 99
# Cards (public p1 p2 ...): -10000 5 1
# Round 1 sequence: Raise, Fold
# Round 2 sequence:
IsTerminal() = True
History() = [5, 1, 2, 0]
HistoryString() = "5, 1, 2, 0"
IsChanceNode() = False
IsSimultaneousNode() = False
CurrentPlayer() = -4
InformationStateString(0) = "[Observer: 0][Private: 5][Round 1][Player: 1][Pot: 0][Money: 101 99][Round1: 2 0][Round2: ]"
InformationStateString(1) = "[Observer: 1][Private: 1][Round 1][Player: 1][Pot: 0][Money: 101 99][Round1: 2 0][Round2: ]"
InformationStateTensor(0).player: ◉◯
InformationStateTensor(0).private_card: ◯◯◯◯◯◉
InformationStateTensor(0).community_card: ◯◯◯◯◯◯
InformationStateTensor(0).betting:
◯◉  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
InformationStateTensor(1).player: ◯◉
InformationStateTensor(1).private_card: ◯◉◯◯◯◯
InformationStateTensor(1).community_card: ◯◯◯◯◯◯
InformationStateTensor(1).betting:
◯◉  ◯◯
◯◯  ◯◯
◯◯  ◯◯
◯◯  ◯◯
ObservationString(0) = "[Observer: 0][Private: 5][Round 1][Player: 1][Pot: 0][Money: 101 99][Ante: 3 1]"
ObservationString(1) = "[Observer: 1][Private: 1][Round 1][Player: 1][Pot: 0][Money: 101 99][Ante: 3 1]"
PublicObservationString() = "[Round 1][Player: 1][Pot: 0][Money: 101 99][Ante: 3 1]"
PrivateObservationString(0) = "[Observer: 0][Private: 5]"
PrivateObservationString(1) = "[Observer: 1][Private: 1]"
ObservationTensor(0).player: ◉◯
ObservationTensor(0).private_card: ◯◯◯◯◯◉
ObservationTensor(0).community_card: ◯◯◯◯◯◯
ObservationTensor(0).pot_contribution = [3.0, 1.0]
ObservationTensor(1).player: ◯◉
ObservationTensor(1).private_card: ◯◉◯◯◯◯
ObservationTensor(1).community_card: ◯◯◯◯◯◯
ObservationTensor(1).pot_contribution = [3.0, 1.0]
Rewards() = [1.0, -1.0]
Returns() = [1.0, -1.0]
