Module tinytroupe.utils.behavior

Various utility functions for behavior analysis and action similarity computation.

Expand source code
"""
Various utility functions for behavior analysis and action similarity computation.
"""

import textdistance



def next_action_jaccard_similarity(agent, proposed_next_action):
    """
    Computes the Jaccard similarity between the agent's current action and a proposed next action,
    modulo target and type (i.e., similarity will be computed using only the content, provided that the action 
    type and target are the same). If the action type or target is different, the similarity will be 0.

    Jaccard similarity is a measure of similarity between two sets, defined as the size of the intersection 
    divided by the size of the union of the sets.

    Args:
        agent (TinyPerson): The agent whose current action is to be compared.
        proposed_next_action (dict): The proposed next action to be compared against the agent's current action.

    Returns:
        float: The Jaccard similarity score between the agent's current action and the proposed next action.
    """
    # Get the agent's current action
    current_action = agent.last_remembered_action()
    
    if current_action is None:
        return 0.0
    
    # Check if the action type and target are the same
    if ("type" in current_action) and ("type" in proposed_next_action) and ("target" in current_action) and ("target" in proposed_next_action) and \
            (current_action["type"] != proposed_next_action["type"] or current_action["target"] != proposed_next_action["target"]):
        return 0.0
    
    # Compute the Jaccard similarity between the content of the two actions
    current_action_content = current_action["content"]
    proposed_next_action_content = proposed_next_action["content"]

    # using textdistance to compute the Jaccard similarity
    jaccard_similarity = textdistance.jaccard(current_action_content, proposed_next_action_content)

    return jaccard_similarity

Functions

def next_action_jaccard_similarity(agent, proposed_next_action)

Computes the Jaccard similarity between the agent's current action and a proposed next action, modulo target and type (i.e., similarity will be computed using only the content, provided that the action type and target are the same). If the action type or target is different, the similarity will be 0.

Jaccard similarity is a measure of similarity between two sets, defined as the size of the intersection divided by the size of the union of the sets.

Args

agent : TinyPerson
The agent whose current action is to be compared.
proposed_next_action : dict
The proposed next action to be compared against the agent's current action.

Returns

float
The Jaccard similarity score between the agent's current action and the proposed next action.
Expand source code
def next_action_jaccard_similarity(agent, proposed_next_action):
    """
    Computes the Jaccard similarity between the agent's current action and a proposed next action,
    modulo target and type (i.e., similarity will be computed using only the content, provided that the action 
    type and target are the same). If the action type or target is different, the similarity will be 0.

    Jaccard similarity is a measure of similarity between two sets, defined as the size of the intersection 
    divided by the size of the union of the sets.

    Args:
        agent (TinyPerson): The agent whose current action is to be compared.
        proposed_next_action (dict): The proposed next action to be compared against the agent's current action.

    Returns:
        float: The Jaccard similarity score between the agent's current action and the proposed next action.
    """
    # Get the agent's current action
    current_action = agent.last_remembered_action()
    
    if current_action is None:
        return 0.0
    
    # Check if the action type and target are the same
    if ("type" in current_action) and ("type" in proposed_next_action) and ("target" in current_action) and ("target" in proposed_next_action) and \
            (current_action["type"] != proposed_next_action["type"] or current_action["target"] != proposed_next_action["target"]):
        return 0.0
    
    # Compute the Jaccard similarity between the content of the two actions
    current_action_content = current_action["content"]
    proposed_next_action_content = proposed_next_action["content"]

    # using textdistance to compute the Jaccard similarity
    jaccard_similarity = textdistance.jaccard(current_action_content, proposed_next_action_content)

    return jaccard_similarity