Skip to main content

No project description provided

Project description

AEPsych Python client v0.5.0

This lets you use Python to interface with the AEPsych server to do model-based adaptive experimentation.

Installation

We recommend installing the client under a virtual environment like Anaconda. Once you've created a virtual environment for AEPsychClient and activated it, you can install through pip:

pip install aepsych_client

If you are a developer, you should also install the main AEPsych package so that you can run the tests.

Basic Usage

Configuration

This interface uses AEPsych's ini-based config, which gets passed as a string to the server:

# Instantiate a client
client = AEPsychClient(ip="0.0.0.0", port=5555)

# Send a config message to the server, passing in a configuration filename
filename = 'configs/single_lse_2d.ini'
client.configure(config_path=filename)

Ask and tell

To get the next configuration from the server, we call ask; we report on the outcome with tell.

# Send an ask message to the server
trial_params = client.ask()

# Send a tell back
client.tell(config={"par1": [0], "par2": [1]}, outcome=1)

Resume functionality

We can run multiple interleaved experiments. When we call configure, we get back a strategy ID. The client keeps track of all these strategy IDs and we can use them to resume experiments. By doing this we can interleave different model runs.

# Configure the server using one config
client.configure(config_path=file1, config_name='config1')

# Run some stuff on this config
...

# Configure the server using another config
client.configure(config_path=file2, config_name='config2')

# Run some stuff on this other config
...

# Resume the past config
client.resume(config_name="config1)

Ending a session

When you are done with your experiment, you should call client.finalize(), which will stop the server and save your data to a database.

Client API

Initialization

client = AEPsychClient(ip="0.0.0.0", port=5555)

Creates a new AEPsych client. By default, it connects to a localhost server on port 5555.

Parameters:

  • ip (str, optional): IP to connect to (default: "0.0.0.0")
  • port (int, optional): Port to connect on (default: 5555)
  • connect (bool): Connect as part of init? (default: True)
  • server (AEPsychServer, optional): An in-memory AEPsychServer object to connect to

Connection Management

# Connect to a server
client.connect(ip="0.0.0.0", port=5555)

# End experiment and stop server
response = client.finalize()

The connect method establishes a connection to an AEPsych server at the specified IP address and port. This is automatically called during initialization if connect=True (the default).

Parameters:

  • ip (str): IP address of the server to connect to
  • port (int): Port number to connect on

The finalize method signals to the server that the experiment is complete and stops the server. It should be called when you're done with your experiment to ensure proper cleanup and data saving.

Returns:

  • Dictionary containing confirmation of termination

Configuration

# Configure using a file path
response = client.configure(config_path="configs/my_config.ini", config_name="my_experiment")

# Configure using a config string
config_str = """
[common]
model = GPClassificationModel
acqf = MCLevelSetEstimation
...
"""
response = client.configure(config_str=config_str, config_name="my_experiment")

# Resume a previous configuration by name
client.resume(config_name="my_experiment")

# Resume a previous configuration by ID
client.resume(config_id=0)

The configure method sets up the server with an experiment configuration. You must provide either a path to a config file or a config string.

Parameters:

  • config_path (str, optional): Path to a config.ini file
  • config_str (str, optional): Config.ini encoded as a string
  • config_name (str, optional): A name to assign to this config internally for convenience

Returns:

  • Dictionary containing the strategy ID for the configured experiment

The resume method switches back to a previously configured experiment. This allows you to interleave multiple experiments in a single session.

Parameters:

  • config_id (int, optional): ID of the config to resume
  • config_name (str, optional): Name of the config to resume (if you provided a name during configuration)

Returns:

  • Dictionary containing the strategy ID that was resumed

Active Learning

# Get next configuration to test
trial_params = client.ask()

# Get multiple configurations
trial_params = client.ask(num_points=5)

# Report results back to the server
client.tell(config={"param1": [0.5], "param2": [0.3]}, outcome=1)

# Report results with metadata
client.tell(
    config={"param1": [0.5], "param2": [0.3]},
    outcome=1,
    reaction_time=1.5,
    confidence=0.8
)

# Finish the current strategy
client.finish_strategy()

The ask method requests the next configuration(s) to test from the server. This is the core method for active learning, as it uses the model to determine the most informative points to sample next.

Parameters:

  • num_points (int, optional): Number of points to return (default: 1)

Returns:

  • Dictionary containing the suggested configuration(s) to test and whether the strategy is finished

The tell method reports the outcome of a tested configuration back to the server. This updates the model with new data.

Parameters:

  • config (dict): Configuration that was evaluated (keys are parameter names, values are lists)
  • outcome (float or dict): Outcome value(s) that were obtained
  • model_data (bool): Whether to include this data in the model (default: True)
  • **metadata: Additional metadata to record with this trial (e.g., reaction time, confidence)

Returns:

  • Dictionary containing the number of trials recorded and data points added to the model

The finish_strategy method marks the current strategy as complete.

Returns:

  • Dictionary containing information about the finished strategy

Model Querying

# Find the maximum of the model
max_point = client.query(query_type="max")

# Find the minimum of the model
min_point = client.query(query_type="min")

# Get model prediction at a specific point
prediction = client.query(
    query_type="prediction",
    x={"param1": [0.5], "param2": [0.3]}
)

# Get inverse prediction (what x gives a specific y)
inverse = client.query(
    query_type="inverse",
    y=0.75,
    probability_space=True
)

# Query with constraints
constrained_max = client.query(
    query_type="max",
    constraints={0: 0.5}  # Constrain first parameter to 0.5
)

The query method allows you to extract information from the underlying model. It supports several query types for different purposes.

Parameters:

  • query_type (str): Type of query to make. Options:
    • "max": Find the maximum value of the model
    • "min": Find the minimum value of the model
    • "prediction": Get model prediction at specific point(s)
    • "inverse": Find parameter values that would give a specific outcome
  • probability_space (bool): Whether the y value is in probability space (default: False)
  • x (dict, optional): Parameter configuration for prediction queries
  • y (float or tensor, optional): Expected y value for inverse queries
  • constraints (dict, optional): Equality constraints for parameters, where keys are parameter indices and values are the fixed values
  • **kwargs: Additional parameters to pass to the query function

Returns:

  • Dictionary containing the query response, which varies based on the query type

Information Retrieval

# Get experiment information
info = client.info()

# Get parameter bounds
params = client.parameters()

# Get full experiment config
config = client.get_config()

# Get specific config property
threshold = client.get_config(section="stopping", property="min_trial_count")

The info method retrieves information about the current running experiment.

Returns:

  • Dictionary containing details such as database name, experiment ID, strategy count, current strategy information, etc.

The parameters method gets information about each parameter in the current strategy.

Returns:

  • Dictionary where keys are parameter names and values are lists containing the lower and upper bounds

The get_config method retrieves the current experiment configuration.

Parameters:

  • section (str, optional): The section to get the property from
  • property (str, optional): The property to get from the section

Returns:

  • Dictionary representing the experiment config or a specific property value if section and property are provided

Each method returns a dictionary with relevant information about the operation performed. See the method docstrings for detailed information about the return values.

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

aepsych_client-0.5.0.tar.gz (11.7 kB view details)

Uploaded Source

Built Distribution

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

aepsych_client-0.5.0-py3-none-any.whl (10.5 kB view details)

Uploaded Python 3

File details

Details for the file aepsych_client-0.5.0.tar.gz.

File metadata

  • Download URL: aepsych_client-0.5.0.tar.gz
  • Upload date:
  • Size: 11.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for aepsych_client-0.5.0.tar.gz
Algorithm Hash digest
SHA256 b75af43dc03bee4ca7c645bc706e3cab5141aa71ba6d72cbd65b8862da518f2f
MD5 1182194c36a55b97b539c8deedfc9459
BLAKE2b-256 df8a1e538b2545082187fa34b0c4bc4113e10946ceb8444afbe6fd26e124177d

See more details on using hashes here.

Provenance

The following attestation bundles were made for aepsych_client-0.5.0.tar.gz:

Publisher: build-to-release-client.yml on facebookresearch/aepsych

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

File details

Details for the file aepsych_client-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: aepsych_client-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 10.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for aepsych_client-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b92c872c96f4f7fd83e8e585cc7a72cca5a26c7e2fba99c8df8b81b4066264d1
MD5 2df66911aa3053ce2d8901c77eb932ff
BLAKE2b-256 e6486b6eba4e8665a7765b26aacb1faaa3a1b6f6685d3c585626e44fe8702115

See more details on using hashes here.

Provenance

The following attestation bundles were made for aepsych_client-0.5.0-py3-none-any.whl:

Publisher: build-to-release-client.yml on facebookresearch/aepsych

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