Skip to main content

anemone searches trees

Project description

anemone

anemone is a Python library for tree search over valanga game states. It builds a shared tree graph and layers algorithm-specific wrappers on top so you can plug in node evaluation, exploration indices, and selection policies for "tree and value" searches.

Highlights

  • Tree-and-value exploration pipeline driven by TreeAndValueBranchSelector.
  • Modular factories for node evaluation, selection, index computation, and tree management.
  • Pluggable stopping criteria and recommender rules for final branch selection.
  • Optional torch-based evaluator for batched neural evaluations.

Installation

pip install anemone

Optional torch integration:

pip install anemone[nn]

Quick start

anemone exposes factory helpers to build a branch selector configured with your node selector, evaluation, and stopping-criterion choices. At runtime you feed it a valanga state and a seed to get back a branch recommendation.

from random import Random

from anemone import TreeAndValuePlayerArgs, create_tree_and_value_branch_selector
from anemone.node_selector.factory import UniformArgs
from anemone.node_selector.node_selector_types import NodeSelectorType
from anemone.progress_monitor.progress_monitor import (
    StoppingCriterionTypes,
    TreeBranchLimitArgs,
)
from anemone.recommender_rule.recommender_rule import SoftmaxRule

# Populate the pieces specific to your game domain.
args = TreeAndValuePlayerArgs(
    node_selector=UniformArgs(type=NodeSelectorType.UNIFORM),
    opening_type=None,
    stopping_criterion=TreeBranchLimitArgs(
        type=StoppingCriterionTypes.TREE_BRANCH_LIMIT,
        tree_branch_limit=100,
    ),
    recommender_rule=SoftmaxRule(type="softmax", temperature=1.0),
)

selector = create_tree_and_value_branch_selector(
    state_type=YourStateType,
    args=args,
    random_generator=Random(0),
    master_state_evaluator=your_state_evaluator,
    state_representation_factory=None,
    queue_progress_player=None,
)

recommendation = selector.select_branch(state=current_state, selection_seed=0)
print(recommendation.branch_key)

Design

This codebase follows a “core node + wrappers” pattern.

  • TreeNode (core)

    • TreeNode is the canonical, shared data structure.
    • It stores the graph structure: branches_children and parent_nodes.
    • There is conceptually a single tree/graph of TreeNodes.
  • Wrappers implement ITreeNode

    • Higher-level nodes (e.g. AlgorithmNode) wrap a TreeNode and add algorithm-specific state: evaluation, indices, representations, etc.
    • Wrappers expose navigation by delegating to the underlying TreeNode.
  • Homogeneity at the wrapper level

    • Even though TreeNode is the core place where connections are stored, each wrapper is intended to be closed under parent/child links:
      • a wrapper’s branches_children and parent_nodes contain that same wrapper type.
      • today this is typically either “all TreeNode” or “all AlgorithmNode”.
      • in the future, another wrapper can exist (still implementing ITreeNode), and it should also be homogeneous within itself.

The practical motivation is:

  • algorithms can be written against ITreeNode (for navigation) and against wrappers like AlgorithmNode (for algorithm-specific fields),
  • while keeping a single shared underlying structure that can be accessed consistently from any wrapper.

Repository layout

Each important package folder includes a local README with details. Start with:

  • src/anemone/ for the main search pipeline and public entry points.
  • src/anemone/node_selector/ for selection strategies (Uniform, RecurZipf, Sequool).
  • src/anemone/node_evaluation/ for direct evaluation and minmax tree evaluation.
  • src/anemone/tree_manager/, src/anemone/trees/, and src/anemone/updates/ for tree construction, expansion, and backpropagation.
  • src/anemone/indices/ for exploration index computation and updates.
  • tests/ for index and tree-building fixtures.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

algorhino_anemone-0.1.5.tar.gz (82.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

algorhino_anemone-0.1.5-py3-none-any.whl (107.6 kB view details)

Uploaded Python 3

File details

Details for the file algorhino_anemone-0.1.5.tar.gz.

File metadata

  • Download URL: algorhino_anemone-0.1.5.tar.gz
  • Upload date:
  • Size: 82.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for algorhino_anemone-0.1.5.tar.gz
Algorithm Hash digest
SHA256 1539f8595b7344fd85fee690da6d9c58544aee6edffe4170b4875a39284e6550
MD5 c149927cd1e43c08e351852202b7e2c4
BLAKE2b-256 978c8476d9b6f5ccf1d474293557f03358a7da7238cbdf781ca77861117d558d

See more details on using hashes here.

Provenance

The following attestation bundles were made for algorhino_anemone-0.1.5.tar.gz:

Publisher: release.yml on victorgabillon/anemone

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file algorhino_anemone-0.1.5-py3-none-any.whl.

File metadata

File hashes

Hashes for algorhino_anemone-0.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 f3e5fe34fe3f6f20d9349b7f7a8b561655233b5d7804e512bd2629041f415e1d
MD5 e58b32792c519d3bfa8bce55b10ff199
BLAKE2b-256 45921630955a1bb0f448c0f925144e32844178790d0f595aff6bcf4321c5f3d5

See more details on using hashes here.

Provenance

The following attestation bundles were made for algorhino_anemone-0.1.5-py3-none-any.whl:

Publisher: release.yml on victorgabillon/anemone

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page