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.6.tar.gz (82.9 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.6-py3-none-any.whl (107.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: algorhino_anemone-0.1.6.tar.gz
  • Upload date:
  • Size: 82.9 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.6.tar.gz
Algorithm Hash digest
SHA256 2b92cfb1a200df0d826a75d9c994bcc98266b7fc1ad309b30e4d85a0ac362cb5
MD5 461f922b9542818a77cc086ba3642fd6
BLAKE2b-256 1047dd5d440acb940a376df559db589651b3072f55c4d2e2007b1176129a03e2

See more details on using hashes here.

Provenance

The following attestation bundles were made for algorhino_anemone-0.1.6.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.6-py3-none-any.whl.

File metadata

File hashes

Hashes for algorhino_anemone-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 e18f715cfd960fd1524518b8280afeb331bd2f3dcc260652d08fcc69cfe14d34
MD5 e4f0c24fd6766251ba0e55829f1ab113
BLAKE2b-256 28120e050a7495f6c3dfc4b71bc7f3a3c12b80fad945042bb314169ffd8f7789

See more details on using hashes here.

Provenance

The following attestation bundles were made for algorhino_anemone-0.1.6-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