tiny_factory / utils /behavior.py
harvesthealth's picture
Restructure project and deploy
e9aab05 verified
"""
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