haive.games.dominoes.generic_engines ==================================== .. py:module:: haive.games.dominoes.generic_engines .. autoapi-nested-parse:: Generic Dominoes engine creation using the generic player agent system. This module provides generic engine creation functions for Dominoes games, allowing for configurable LLM models and game-specific player identifiers. Classes ------- .. autoapisummary:: haive.games.dominoes.generic_engines.DominoesEngineFactory haive.games.dominoes.generic_engines.DominoesPlayerIdentifiers haive.games.dominoes.generic_engines.DominoesPromptGenerator Functions --------- .. autoapisummary:: haive.games.dominoes.generic_engines.create_advanced_dominoes_engines haive.games.dominoes.generic_engines.create_budget_dominoes_engines haive.games.dominoes.generic_engines.create_generic_dominoes_config_from_example haive.games.dominoes.generic_engines.create_generic_dominoes_engines haive.games.dominoes.generic_engines.create_generic_dominoes_engines_simple haive.games.dominoes.generic_engines.create_mixed_dominoes_engines Module Contents --------------- .. py:class:: DominoesEngineFactory Bases: :py:obj:`haive.games.core.agent.generic_player_agent.GenericGameEngineFactory`\ [\ :py:obj:`str`\ , :py:obj:`str`\ ] Factory for creating Dominoes game engines. Init . :returns: Add return description] :rtype: [TODO .. py:method:: get_structured_output_model(role) Get the structured output model for a specific role. .. py:class:: DominoesPlayerIdentifiers Bases: :py:obj:`haive.games.core.agent.generic_player_agent.GamePlayerIdentifiers`\ [\ :py:obj:`str`\ , :py:obj:`str`\ ] Player identifiers for Dominoes game. Init . :returns: Add return description] :rtype: [TODO .. py:class:: DominoesPromptGenerator(players) Bases: :py:obj:`haive.games.core.agent.generic_player_agent.GenericPromptGenerator`\ [\ :py:obj:`str`\ , :py:obj:`str`\ ] Prompt generator for Dominoes game. Init . :param players: [TODO: Add description] .. py:method:: create_analyzer_prompt(player) Create analysis prompt for Dominoes game state. .. py:method:: create_move_prompt(player) Create move prompt for Dominoes player. .. py:function:: create_advanced_dominoes_engines(**kwargs) Create advanced Dominoes engines with high-powered models. .. py:function:: create_budget_dominoes_engines(**kwargs) Create budget-friendly Dominoes engines. .. py:function:: create_generic_dominoes_config_from_example(example_name, temperature = 0.3) Create Dominoes engines from a predefined example configuration. :param example_name: Name of the example configuration :param temperature: Generation temperature :returns: Dictionary of Dominoes engines :rtype: Dict[str, AugLLMConfig] Available examples: - "gpt_vs_claude": GPT vs Claude - "gpt_only": GPT for both players - "claude_only": Claude for both players - "budget": Cost-effective models - "mixed": Different provider per role - "advanced": High-powered models for strategic gameplay .. py:function:: create_generic_dominoes_engines(player_configs) Create Dominoes engines from detailed player configurations. :param player_configs: Dictionary mapping role names to player configurations :returns: Dictionary of Dominoes engines :rtype: Dict[str, AugLLMConfig] Expected roles: - "player1_player": Player 1 configuration - "player2_player": Player 2 configuration - "player1_analyzer": Player 1 analyzer configuration - "player2_analyzer": Player 2 analyzer configuration .. py:function:: create_generic_dominoes_engines_simple(player1_model, player2_model, temperature = 0.3) Create Dominoes engines with simple model specifications. :param player1_model: Model for player1 and analyzer :param player2_model: Model for player2 and analyzer :param temperature: Generation temperature :returns: Dictionary of Dominoes engines :rtype: Dict[str, AugLLMConfig] .. py:function:: create_mixed_dominoes_engines(**kwargs) Create mixed-provider Dominoes engines.