maverick.holding.Holding#
- class maverick.holding.Holding(*, cards: list[Card])[source]#
A number of cards held by a player.
Fields#
- cardslist[Card]
The list of cards in the holding.
Examples
>>> from maverick import Holding, Card ... pair_of_aces = Holding(cards=[ ... Card(suit='S', rank=14), # Ace of Spades ... Card(suit='H', rank=14) # Ace of Hearts ... ]) >>> pair_of_aces.estimate_strength(n_simulations=1000, n_players=8) 0.85 # Example output, actual value may vary
- __init__(**data: Any) None#
Create a new model by parsing and validating input data from keyword arguments.
Raises [ValidationError][pydantic_core.ValidationError] if the input data cannot be validated to form a valid model.
self is explicitly positional-only to allow self as a field name.
Methods
__init__(**data)Create a new model by parsing and validating input data from keyword arguments.
all_possible_holdings(cards[, n])Generate all possible holdings of n cards from the given deck.
construct([_fields_set])copy(*[, include, exclude, update, deep])Returns a copy of the model.
dict(*[, include, exclude, by_alias, ...])estimate_strength(**kwargs)Estimate the strength of the holding via Monte Carlo simulation.
from_orm(obj)json(*[, include, exclude, by_alias, ...])model_construct([_fields_set])Creates a new instance of the Model class with validated data.
model_copy(*[, update, deep])!!! abstract "Usage Documentation"
model_dump(*[, mode, include, exclude, ...])!!! abstract "Usage Documentation"
model_dump_json(*[, indent, ensure_ascii, ...])!!! abstract "Usage Documentation"
model_json_schema(by_alias, ref_template, ...)Generates a JSON schema for a model class.
model_parametrized_name(params)Compute the class name for parametrizations of generic classes.
model_post_init(context, /)Override this method to perform additional initialization after __init__ and model_construct.
model_rebuild(*[, force, raise_errors, ...])Try to rebuild the pydantic-core schema for the model.
model_validate(obj, *[, strict, extra, ...])Validate a pydantic model instance.
model_validate_json(json_data, *[, strict, ...])!!! abstract "Usage Documentation"
model_validate_strings(obj, *[, strict, ...])Validate the given object with string data against the Pydantic model.
parse_file(path, *[, content_type, ...])parse_obj(obj)parse_raw(b, *[, content_type, encoding, ...])random(*[, n, deck])Generate a random holding of 2 cards.
schema([by_alias, ref_template])schema_json(*[, by_alias, ref_template])score()Classifies and scores the hand.
update_forward_refs(**localns)validate(value)Attributes
model_computed_fieldsConfiguration for the model, should be a dictionary conforming to [ConfigDict][pydantic.config.ConfigDict].
model_extraGet extra fields set during validation.
model_fieldsmodel_fields_setReturns the set of fields that have been explicitly set on this model instance.
cards- classmethod random(*, n: int = 2, deck: Deck | None = None) Holding[source]#
Generate a random holding of 2 cards.
- classmethod all_possible_holdings(cards: list[Card], n: int = 2) iter[source]#
Generate all possible holdings of n cards from the given deck.
- score() Tuple[HandType, float][source]#
Classifies and scores the hand.
Returns (HandType, float_score) where higher scores = stronger hands.
- estimate_strength(**kwargs) float[source]#
Estimate the strength of the holding via Monte Carlo simulation.
Returns a number between 0 and 1, representing the probability of the current hand being the strongest.
The keyword arguments are passed to estimate_holding_strength.
- model_config = {}#
Configuration for the model, should be a dictionary conforming to [ConfigDict][pydantic.config.ConfigDict].