def find(object) -> str:
    """
    <Description> 
    Find and navigate to an object. You can go to the position of the object even if you haven't seen it yet. 
    Notes:
    **You can get close to an object by calling find action even when you can see the object!**
    </Description>
    <Params>
    object: A string representing the object or receptacle you want to find.
    </Params>
    """
    return f"find a {object}"

def pick_up(object) -> str:
    """
    <Description>
    Pick up the object (in your hand). Only valid if the robot is close to the object (may not visiable), not holding another object, and the object is not inside a closed receptacle.
    Notes:
    You can still try to pick_up something you can not see. It may tell you the location of the target object!!!
    </Description>
    <Params>
    object: An object you want to pick up. 
    </Params>
    """
    
    if "_" in object:
        object = object.split('_')[0] # delete underline
    
    return f"pick up the {object}"


def put_down() -> str:
    """
    <Description>
    put done the object in your hands.
    Notice:
    To put down object in/on an receptacle. You should first find the receptacle and then immidiately put object down. (no other action allowed during this process).
    e.g., find('sink') -> put_down() means put down object in your hand to the sink.
    <Params>
    NO PARAMATER
    </Params>
    """
    return "put down the object in hand"

def drop() -> str:
    """
    <Description>
    Drop the object in your hand to ground. Only valid if the robot is holding an object.
    </Description>
    <Params>
    NO PARAMATER.
    </Params>
    """
    return "drop the object in hand"

def open(object) -> str:
    """
    <Description>
    Open a closed receptacle. Only valid if the receptacle is closed and the robot is close to the receptacle.
    Garbage Can Constraint: The garbage can cannot be opened or closed; it is always open. Do not attempt to perform open/close actions on the garbage can.
    </Description>
    <Params>
    object: A string, the name of the receptacle you want to open.
    </Params>
    """
    return f"open the {object}"

def close(object) -> str:
    """
    <Description>
    Close an open receptacle. Only valid if the receptacle is open and the robot is close to the receptacle.
    </Description>
    <Params>
    object: A string, the name of the receptacle you want to close.
    </Params>
    """
    return f"close the {object}"

def turn_on(object) -> str:
    """
    <Description>
    Turn on an object. Only valid if the object is turned off and the robot is close to the object.
    Notes:
    Even when you can see the object, you may not close enough. Try to call `find` action to get close to the object!
    </Description>
    <Params>
    object: A string, the name of the object you want to turn on.
    </Params>
    """
    return f"turn on the {object}"

def turn_off(object) -> str:
    """
    <Description>
    Turn off an object. Only valid if the object is turned on and the robot is close to the object.
    Notice:
    Even when you can see the object, you may not close enough. Try to call `find` action to get close to the object!
    </Description>
    <Params>
    object: A string, the name of the object you want to turn off.
    </Params>
    """
    return f"turn off the {object}"

def slice(object) -> str:
    """
    <Description>
    Slice an object. You have to get close to the object you want to cut.
    Please find Knife or ButterKnife first to slice.
    You don't need to pick up object you want to slice! Just holding knife and slice object!
    You can only slice a object once. If you try to slice an object that is already sliced, the aciton will failed.
    </Description>
    <Params>
    object: A string, the name of the object you want to slice
    </Params>
    """
    
    if "_" in object:
        object = object.split('_')[0] # delete underline
    
    return f"slice the {object}"

