From f92b0858ca41d8191b2371e009b08c0444a6379f Mon Sep 17 00:00:00 2001 From: zichao Date: Mon, 4 Dec 2023 12:01:25 -0600 Subject: [PATCH] fix task format --- benchmark/tasks/CountSavory.py | 251 ++++++------------ benchmark/tasks/ElevatorTour.py | 139 ++++------ benchmark/tasks/FindBackpack.py | 113 +++----- benchmark/tasks/GetDrink.py | 125 +++------ benchmark/tasks/GrilledCheese.py | 53 ++-- benchmark/tasks/HalloweenList.py | 200 ++++++-------- benchmark/tasks/HalloweenShopping.py | 172 +++++------- benchmark/tasks/LunchBreak.py | 167 +++++------- benchmark/tasks/LunchTime.py | 91 +++---- benchmark/tasks/MailDelivery.py | 200 +++++--------- benchmark/tasks/MovieMessenger.py | 162 +++++------ benchmark/tasks/SayGoodDay.py | 126 ++++----- benchmark/tasks/SetTemperature.py | 73 +++-- benchmark/tasks/StaplerDelivery.py | 151 ++++------- benchmark/tasks/StaplerSupply.py | 132 ++++----- benchmark/tasks/WeatherPoll.py | 213 ++++++--------- .../CountSavoryAblation.py | 145 ++++------ .../GrilledCheeseAblation.py | 43 ++- .../open_world_knowledge/LunchTimeAblation.py | 65 ++--- .../SetTemperatureAblation.py | 58 ++-- 20 files changed, 1019 insertions(+), 1660 deletions(-) diff --git a/benchmark/tasks/CountSavory.py b/benchmark/tasks/CountSavory.py index ca7db49..9491f9c 100644 --- a/benchmark/tasks/CountSavory.py +++ b/benchmark/tasks/CountSavory.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,77 +12,43 @@ "Visit all offices. If anyone is present; ask them to choose from the options of cupcake, ham sandwich, donut, or beef jerky. Let me know how many people selected a savory option when you return.", "Go through each office; if someone is there, ask about their preference among cupcake, donut, beef jerky, or ham sandwich. Report the number of individuals who opted for a savory item after returning.", "Go visit each office. If there is a person in the office, inquire about their liking for cupcake, ham sandwich, beef jerky, or donut. Come back and tell me of the count of people who went for a savory option.", - "Go to every office, and if there is someone there, ask them whether they'd like a beef jerky, cupcake, ham sandwich, or donut. Come back and tell me how many people preferred a savory option.", + "Go to every office, and if there is someone there, ask them whether they'd like a beef jerky, cupcake, ham sandwich, or donut. Come back and tell me how many people preferred a savory option." ] # construct state -state0 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "alice's office", [r"donut"]) - .addAgent(".*", "bob's office", [r"cake"]) - .addAgent(".*", "charlie's office", [r"donut"]) - .addAgent(".*", "david's office", [r"cake"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "alice's office", [r"sandwich"]) - .addAgent(".*", "bob's office", [r"donut"]) - .addAgent(".*", "charlie's office", [r"cake"]) - .addAgent(".*", "david's office", [r"beef|jerky"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "alice's office", [r"beef|jerky"]) - .addAgent(".*", "bob's office", [r"cake"]) - .addAgent(".*", "charlie's office", [r"cake"]) - .addRobotLocation("start_loc") -) - -state3 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "bob's office", [r"sandwich"]) - .addAgent(".*", "charlie's office", [r"beef|jerky"]) - .addAgent(".*", "david's office", [r"sandwich"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "alice's office", [r"donut"]).addAgent(".*", "bob's office", [r"cake"]) \ + .addAgent(".*", "charlie's office", [r"donut"]).addAgent(".*", "david's office", [r"cake"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "alice's office", [r"sandwich"]).addAgent(".*", "bob's office", [r"donut"]) \ + .addAgent(".*", "charlie's office", [r"cake"]).addAgent(".*", "david's office", [r"beef|jerky"]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "alice's office", [r"beef|jerky"]).addAgent(".*", "bob's office", [r"cake"]) \ + .addAgent(".*", "charlie's office", [r"cake"]) \ + .addRobotLocation("start_loc") + +state3 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "bob's office", [r"sandwich"]).addAgent(".*", "charlie's office", [r"beef|jerky"]) \ + .addAgent(".*", "david's office", [r"sandwich"]) \ + .addRobotLocation("start_loc") # helper checks def ask_times_con(trace: Trace, times: int, VERBOSE: bool = False) -> bool: ask_sc = Ask(r".*", r".*") - ask_times = True + ask_times = True new_trace = trace for _ in range(times): ask_times = ask_times and new_trace.Exists(ask_sc) @@ -95,88 +60,65 @@ def ask_times_con(trace: Trace, times: int, VERBOSE: bool = False) -> bool: return ask_times - def ask_con(trace: Trace, agent_name: str, food: str, VERBOSE: bool = False) -> bool: contained_food = contain_words([food]) - ask_food = trace.ActAtFirst( - f"{agent_name}'s office", Ask(contained_food, r".*") - ) or trace.ActAtFirst(f"{agent_name}'s office", Ask(r".*", contained_food)) - + ask_food = trace.ActAtFirst(f"{agent_name}'s office", Ask(contained_food, r".*")) or \ + trace.ActAtFirst(f"{agent_name}'s office", Ask(r".*", contained_food)) + # ask after check - check_before_ask = ( - trace.AfterFirst(GoTo(f"{agent_name}'s office")) - .BeforeFirst(Ask(contained_food, r".*")) - .Exists(CheckEntity(r".*")) - ) - + check_before_ask = trace.AfterFirst(GoTo(f"{agent_name}'s office")) \ + .BeforeFirst(Ask(contained_food, r".*")).Exists(CheckEntity(r".*")) + if VERBOSE: # print_debug("contained_food", contained_food) # not a bool print_debug("ask_food", ask_food, [label_A, label_AL]) - print_debug( - "check_before_ask", check_before_ask, [label_EO, label_CE, label_AL] - ) + print_debug("check_before_ask", check_before_ask, [label_EO, label_CE, label_AL]) return ask_food and check_before_ask - def say_con(trace: Trace, count: str, VERBOSE: bool = False) -> bool: say_pattern = contain_words([count]) - goto_before_say = ( - trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"alice's office")) - and trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"bob's office")) - and trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"charlie's office")) - and trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"david's office")) - ) + goto_before_say = trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"alice's office")) and \ + trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"bob's office")) and \ + trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"charlie's office")) and \ + trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"david's office")) exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - - say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Say(say_pattern) - ) + + say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(say_pattern)) if VERBOSE: - print_debug( - f"say_constraint say_pattern {say_pattern}", say, [label_S, label_AL] - ) - print_debug( - f"goto_before_say count {count}", goto_before_say, [label_EO, label_ES] - ) + print_debug(f"say_constraint say_pattern {say_pattern}", say, [label_S, label_AL]) + print_debug(f"goto_before_say count {count}", goto_before_say, [label_EO, label_ES]) return goto_before_say and say - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: # visit all offices - go_to_check = ( - trace.Exists(GoTo(r"alice's office")) - and trace.Exists(GoTo(r"bob's office")) - and trace.Exists(GoTo(r"charlie's office")) - and trace.Exists(GoTo(r"david's office")) - ) - - not_go_to_check = not trace.Exists(GoTo(r"lobby")) and not trace.Exists( - GoTo(r"cafeteria") - ) - + go_to_check = trace.Exists(GoTo(r"alice's office")) and \ + trace.Exists(GoTo(r"bob's office")) and \ + trace.Exists(GoTo(r"charlie's office")) and \ + trace.Exists(GoTo(r"david's office")) + + not_go_to_check = not trace.Exists(GoTo(r"lobby")) and \ + not trace.Exists(GoTo(r"cafeteria")) + # check if someone is there - check_person = ( - trace.ActAtFirst(r"alice's office", CheckEntity(r".*")) - and trace.ActAtFirst(r"bob's office", CheckEntity(r".*")) - and trace.ActAtFirst(r"charlie's office", CheckEntity(r".*")) - and trace.ActAtFirst(r"david's office", CheckEntity(r".*")) - ) - + check_person = trace.ActAtFirst(r"alice's office", CheckEntity(r".*")) and \ + trace.ActAtFirst(r"bob's office", CheckEntity(r".*")) and \ + trace.ActAtFirst(r"charlie's office", CheckEntity(r".*")) and \ + trace.ActAtFirst(r"david's office", CheckEntity(r".*")) + if VERBOSE: print_debug("go_to_check", go_to_check, [label_ES]) print_debug("not_go_to_check", not_go_to_check, [label_ES]) print_debug("check_person", check_person, [label_CE, label_AL]) - + return go_to_check and not_go_to_check and check_person - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 0 trace = Trace(trace_elements) generic = generic_con(trace) @@ -187,18 +129,9 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: say = say_con(trace, "0|.*zero|.*no", VERBOSE) ask_times = ask_times_con(trace, 4, VERBOSE) - return ( - generic - and ask_alice - and ask_bob - and ask_charlie - and ask_david - and say - and ask_times - ) - + return generic and ask_alice and ask_bob and ask_charlie and ask_david and say and ask_times -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 2 trace = Trace(trace_elements) generic = generic_con(trace) @@ -209,18 +142,10 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: say = say_con(trace, "2|.*two", VERBOSE) ask_times = ask_times_con(trace, 4, VERBOSE) - return ( - generic - and ask_alice - and ask_bob - and ask_charlie - and ask_david - and say - and ask_times - ) + return generic and ask_alice and ask_bob and ask_charlie and ask_david and say and ask_times -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 1 trace = Trace(trace_elements) generic = generic_con(trace) @@ -231,18 +156,9 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: say = say_con(trace, "1|.*one", VERBOSE) ask_times = ask_times_con(trace, 3, VERBOSE) - return ( - generic - and ask_alice - and ask_bob - and ask_charlie - and not_ask_david - and say - and ask_times - ) + return generic and ask_alice and ask_bob and ask_charlie and not_ask_david and say and ask_times - -def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 3 trace = Trace(trace_elements) generic = generic_con(trace) @@ -253,20 +169,29 @@ def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: say = say_con(trace, "3|.*three", VERBOSE) ask_times = ask_times_con(trace, 3, VERBOSE) - return ( - generic - and not_ask_alice - and ask_bob - and ask_charlie - and ask_david - and say - and ask_times - ) + return generic and not_ask_alice and ask_bob and ask_charlie and ask_david and say and ask_times tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, - {"state": state3, "test": test3, "timeout": False}, + { + "state" : state0, + "test" : test0, + "timeout": False + }, + { + "state" : state1, + "test" : test1, + "timeout": False + }, + { + "state" : state2, + "test" : test2, + "timeout": False + }, + { + "state" : state3, + "test" : test3, + "timeout": False + } ] + diff --git a/benchmark/tasks/ElevatorTour.py b/benchmark/tasks/ElevatorTour.py index 0ad7a88..807ed5a 100644 --- a/benchmark/tasks/ElevatorTour.py +++ b/benchmark/tasks/ElevatorTour.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State @@ -15,39 +14,24 @@ "Go to the elevator, and wait until someone shows up. Ask them if they are here for the tour. If yes, welcome them to the university, tell them to follow you, and take them to the main conference room. If not, wait for the next person. When you get to the conference room, say you have arrived at the conference room and wish them an enjoyable visit.", "Go to the elevator and wait for someone to arrive. Inquire if they are here for the tour, and if they say yes, welcome them to the university and tell them to follow you. Then take them to the main conference room. If they say no, wait for someone else. When you get to the conference room, announce your arrival at the conference room and wish them an enjoyable visit.", "Go to the elevator and wait for a person to show up. When someone shows up, ask them if they are here for the tour, and if they say yes, welcome them to the university and tell them to follow you. Then take them to the main conference room. If they say no, wait for the next person. When you get to the conference room, announce your arrival at the conference room and wish them an enjoyable visit.", - "Go to the elevator, wait until someone arrives, and then ask them if they are here for the tour. If they say yes, welcome them to the university and tell them to follow you, and guide them to the main conference room. If they say no, wait for the next person. When you get to the conference room, announce your arrival at the conference room and wish them an enjoyable visit.", + "Go to the elevator, wait until someone arrives, and then ask them if they are here for the tour. If they say yes, welcome them to the university and tell them to follow you, and guide them to the main conference room. If they say no, wait for the next person. When you get to the conference room, announce your arrival at the conference room and wish them an enjoyable visit." ] # construct state -state0 = ( - State() - .addLocation("elevator") - .addLocation("conference room") - .addLocation("lobby") - .addLocation("start_loc") - .addAgent(".*", "elevator", ["yes"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("elevator") - .addLocation("conference room") - .addLocation("lobby") - .addLocation("start_loc") - .addAgent(".*", "elevator", ["no"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("elevator") - .addLocation("conference room") - .addLocation("lobby") - .addLocation("start_loc") - .addAgent(".*", "start_loc", ["yes"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("elevator").addLocation("conference room") \ + .addLocation("lobby").addLocation("start_loc") \ + .addAgent(".*", "elevator", ["yes"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("elevator").addLocation("conference room") \ + .addLocation("lobby").addLocation("start_loc") \ + .addAgent(".*", "elevator", ["no"]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("elevator").addLocation("conference room") \ + .addLocation("lobby").addLocation("start_loc") \ + .addAgent(".*", "start_loc", ["yes"]) \ + .addRobotLocation("start_loc") # helper checks def answer_yes(trace: Trace, VERBOSE: bool = False) -> bool: @@ -60,35 +44,21 @@ def answer_yes(trace: Trace, VERBOSE: bool = False) -> bool: say_follow = trace.ActAtFirst("elevator", Say(follow_pattern)) loc = "elevator" - ask_before_say = trace.AfterFirst(GoTo(loc)).BeforeFirst( - GoTo(r"^(?!.*\b{loc}\b).*$".format(loc=loc)) - ).BeforeFirst(Say(welcome_pattern)).Exists( - Ask(tour_pattern, r".*") - ) and trace.AfterFirst( - GoTo(loc) - ).BeforeFirst( - GoTo(r"^(?!.*\b{loc}\b).*$".format(loc=loc)) - ).BeforeFirst( - Say(follow_pattern) - ).Exists( - Ask(tour_pattern, r".*") - ) - + ask_before_say = trace.AfterFirst(GoTo(loc)).BeforeFirst(GoTo(r"^(?!.*\b{loc}\b).*$".format(loc=loc))) \ + .BeforeFirst(Say(welcome_pattern)).Exists(Ask(tour_pattern, r".*")) and \ + trace.AfterFirst(GoTo(loc)).BeforeFirst(GoTo(r"^(?!.*\b{loc}\b).*$".format(loc=loc))) \ + .BeforeFirst(Say(follow_pattern)).Exists(Ask(tour_pattern, r".*")) + # go to main conference room - go_to_conf_room = trace.BeforeFirst(GoTo("conference")).Exists( - Say(welcome_pattern) - ) and trace.BeforeFirst(GoTo("conference")).Exists(Say(follow_pattern)) + go_to_conf_room = trace.BeforeFirst(GoTo("conference")).Exists(Say(welcome_pattern)) and \ + trace.BeforeFirst(GoTo("conference")).Exists(Say(follow_pattern)) exclude_elevator = contain_words_and_exlude_words([], ["elevator"]) - conf_after_elevator = ( - not trace.AfterFirst(GoTo("elevator")) - .BeforeFirst(GoTo("conference")) - .Exists(GoTo(exclude_elevator)) - ) - - say_at_conf = trace.ActAtFirst( - "conference", Say(contain_words(["arrive"])) - ) and trace.ActAtFirst("conference", Say(contain_words(["enjoy"]))) + conf_after_elevator = not trace.AfterFirst(GoTo("elevator")).BeforeFirst(GoTo("conference")).Exists(GoTo(exclude_elevator)) + + say_at_conf = trace.ActAtFirst("conference", Say(contain_words(["arrive"]))) and \ + trace.ActAtFirst("conference", Say(contain_words(["enjoy"]))) + if VERBOSE: print_debug("say_welcome", say_welcome, [label_S, label_AL]) @@ -98,15 +68,8 @@ def answer_yes(trace: Trace, VERBOSE: bool = False) -> bool: print_debug("conf_after_elevator", conf_after_elevator, [label_EO]) print_debug("say_at_conf", say_at_conf, [label_S, label_AL]) - return ( - say_welcome - and say_follow - and ask_before_say - and go_to_conf_room - and conf_after_elevator - and say_at_conf - ) - + return say_welcome and say_follow and ask_before_say and \ + go_to_conf_room and conf_after_elevator and say_at_conf def ask_con(trace: Trace, VERBOSE: bool = False) -> bool: # ask if person is here for the tour @@ -118,28 +81,22 @@ def ask_con(trace: Trace, VERBOSE: bool = False) -> bool: return ask - def generic_con(trace, VERBOSE: bool = False) -> bool: # first go to elevator exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - go_to_check = not trace.BeforeFirst(GoTo(r"elevator")).Exists( - GoTo(exclude_start_loc) - ) + go_to_check = not trace.BeforeFirst(GoTo(r"elevator")).Exists(GoTo(exclude_start_loc)) not_go_to_check = not trace.Exists(GoTo(r"lobby")) - + check_person_at_elevator = trace.ActAtFirst("elevator", CheckEntity(".*")) if VERBOSE: print_debug("go_to_check", go_to_check, [label_IT]) print_debug("not_go_to_check", not_go_to_check, [label_L]) - print_debug( - "check_person_at_elevator", check_person_at_elevator, [label_CE, label_AL] - ) - + print_debug("check_person_at_elevator", check_person_at_elevator, [label_CE, label_AL]) + return go_to_check and not_go_to_check and check_person_at_elevator - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # person is at elevator and says "yes". trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -147,25 +104,35 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: answer = answer_yes(trace, VERBOSE) return generic and ask and answer - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # person is at elevator and says "no". trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) ask = ask_con(trace, VERBOSE) return generic and ask - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # person is at start_loc. trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) not_ask = not ask_con(trace, VERBOSE) return generic and not_ask - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": True}, - {"state": state2, "test": test2, "timeout": True}, + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": True + }, + { + "state": state2, + "test": test2, + "timeout": True + } ] + diff --git a/benchmark/tasks/FindBackpack.py b/benchmark/tasks/FindBackpack.py index 07ca76f..ea67438 100644 --- a/benchmark/tasks/FindBackpack.py +++ b/benchmark/tasks/FindBackpack.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,51 +12,24 @@ "Search all the conference rooms for my backpack and return it to me.", "Please find my backpack in each conference room and then bring it to me.", "Go through every conference room and find my backpack, then bring it back to me.", - "Look in all of the conference rooms to search for my backpack and then bring it back to me.", + "Look in all of the conference rooms to search for my backpack and then bring it back to me." ] # construct state -state0 = ( - State() - .addLocation("conference room 1") - .addLocation("conference room 2") - .addLocation("conference room 3") - .addLocation("tom's office") - .addLocation("lobby") - .addLocation("start_loc") - .addObject("backpack", "conference room 1") - .addObject("laptop", "conference room 1") - .addObject("chair", "conference room 2") - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("conference room 1") - .addLocation("conference room 2") - .addLocation("conference room 3") - .addLocation("tom's office") - .addLocation("lobby") - .addLocation("start_loc") - .addObject("backpack", "conference room 2") - .addObject("laptop", "conference room 1") - .addObject("chair", "conference room 2") - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("conference room 1") - .addLocation("conference room 2") - .addLocation("conference room 3") - .addLocation("tom's office") - .addLocation("lobby") - .addLocation("start_loc") - .addObject("backpack", "conference room 3") - .addObject("laptop", "conference room 1") - .addObject("chair", "conference room 2") - .addRobotLocation("start_loc") -) +state0 = State().addLocation("conference room 1").addLocation("conference room 2").addLocation("conference room 3") \ + .addLocation("tom's office").addLocation("lobby").addLocation("start_loc") \ + .addObject("backpack", "conference room 1").addObject("laptop", "conference room 1").addObject("chair", "conference room 2") \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("conference room 1").addLocation("conference room 2").addLocation("conference room 3") \ + .addLocation("tom's office").addLocation("lobby").addLocation("start_loc") \ + .addObject("backpack", "conference room 2").addObject("laptop", "conference room 1").addObject("chair", "conference room 2") \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("conference room 1").addLocation("conference room 2").addLocation("conference room 3") \ + .addLocation("tom's office").addLocation("lobby").addLocation("start_loc") \ + .addObject("backpack", "conference room 3").addObject("laptop", "conference room 1").addObject("chair", "conference room 2") \ + .addRobotLocation("start_loc") # helper checks def pick_con(trace: Trace, loc: str, VERBOSE: bool = False) -> bool: @@ -72,32 +44,26 @@ def pick_con(trace: Trace, loc: str, VERBOSE: bool = False) -> bool: pick_once = not trace.AfterFirst(Pick(r".*")).Exists(Pick(r".*")) # check if there is a backpack in every conference room upon visiting the room - check_backpack = trace.ActAtFirst(loc, CheckEntity(r"backpack")) + check_backpack = trace.ActAtFirst(loc, CheckEntity(r"backpack")) if VERBOSE: print_debug("pick_backpack", pick_backpack, [label_M, label_AL]) print_debug("pick_once", pick_once, [label_M, label_AL]) print_debug("check_backpack", check_backpack, [label_CE, label_AL]) - + return pick_backpack and pick_once and check_backpack - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - - not_go_to_other = not trace.Exists(GoTo(r"lobby")) and not trace.Exists( - GoTo(r"tom's office") - ) - bring_backpack = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Place(r"backpack") - ) or not trace.Exists(Place(r"backpack")) + + not_go_to_other = not trace.Exists(GoTo(r"lobby")) and not trace.Exists(GoTo(r"tom's office")) + bring_backpack = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Place(r"backpack")) or \ + not trace.Exists(Place(r"backpack")) # exist pick and place - exist_pick = ( - trace.Exists(Pick(r"backpack")) - and not trace.Exists(Place(r"laptop")) - and not trace.Exists(Place(r"chair")) - ) + exist_pick = trace.Exists(Pick(r"backpack")) and \ + not trace.Exists(Place(r"laptop")) and \ + not trace.Exists(Place(r"chair")) if VERBOSE: print_debug("not_go_to_other", not_go_to_other, [label_ES]) @@ -106,33 +72,42 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: return not_go_to_other and bring_backpack and exist_pick - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) pick_conf1 = pick_con(trace, r"conference room 1", VERBOSE) return generic and pick_conf1 - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) pick_conf2 = pick_con(trace, r"conference room 2", VERBOSE) return generic and pick_conf2 - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) pick_conf3 = pick_con(trace, r"conference room 3", VERBOSE) return generic and pick_conf3 - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, + { + "state" : state0, + "test" : test0, + "timeout": False + }, + { + "state" : state1, + "test" : test1, + "timeout": False + }, + { + "state" : state2, + "test" : test2, + "timeout": False + } ] + diff --git a/benchmark/tasks/GetDrink.py b/benchmark/tasks/GetDrink.py index a4dcdd0..bbd2da9 100644 --- a/benchmark/tasks/GetDrink.py +++ b/benchmark/tasks/GetDrink.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,51 +12,24 @@ "Ask any visitor in the lobby if they would like a bottle of water, iced tea, or lemonade. Bring what they ask for from the kitchen.", "Go to the lobby. Ask if the visitor wants: a bottle of water, iced tea, or lemonade. Go to the kitchen and bring the visitor back what they asked for.", "Go to the lobby and ask any person there if they want iced tea, lemonade or a bottle of water. Bring whatever they asked for back from the kitchen.", - "Go to the lobby, and ask if the visitor would like a bottle of water, iced tea, or lemonade. If they want a bottle of water, bring it to them from the kitchen. If they want iced tea, bring it to them from the kitchen. If they want lemonade, bring it to them from the kitchen.", + "Go to the lobby, and ask if the visitor would like a bottle of water, iced tea, or lemonade. If they want a bottle of water, bring it to them from the kitchen. If they want iced tea, bring it to them from the kitchen. If they want lemonade, bring it to them from the kitchen." ] # construct state -state0 = ( - State() - .addLocation("lobby") - .addLocation("kitchen") - .addLocation("office") - .addLocation("start_loc") - .addAgent(".*", "lobby", ["water"]) - .addObject("water", "kitchen") - .addObject("tea", "kitchen") - .addObject("lemonade", "kitchen") - .addObject("drink", "kitchen") - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("lobby") - .addLocation("kitchen") - .addLocation("office") - .addLocation("start_loc") - .addAgent(".*", "lobby", ["tea"]) - .addObject("water", "kitchen") - .addObject("tea", "kitchen") - .addObject("lemonade", "kitchen") - .addObject("drink", "kitchen") - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("lobby") - .addLocation("kitchen") - .addLocation("office") - .addLocation("start_loc") - .addAgent(".*", "lobby", ["lemonade"]) - .addObject("water", "kitchen") - .addObject("tea", "kitchen") - .addObject("lemonade", "kitchen") - .addObject("drink", "kitchen") - .addRobotLocation("start_loc") -) +state0 = State().addLocation("lobby").addLocation("kitchen").addLocation("office").addLocation("start_loc") \ + .addAgent(".*", "lobby", ["water"]) \ + .addObject("water", "kitchen").addObject("tea", "kitchen").addObject("lemonade", "kitchen").addObject("drink", "kitchen") \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("lobby").addLocation("kitchen").addLocation("office").addLocation("start_loc") \ + .addAgent(".*", "lobby", ["tea"]) \ + .addObject("water", "kitchen").addObject("tea", "kitchen").addObject("lemonade", "kitchen").addObject("drink", "kitchen") \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("lobby").addLocation("kitchen").addLocation("office").addLocation("start_loc") \ + .addAgent(".*", "lobby", ["lemonade"]) \ + .addObject("water", "kitchen").addObject("tea", "kitchen").addObject("lemonade", "kitchen").addObject("drink", "kitchen") \ + .addRobotLocation("start_loc") # helper checks def pick_place_con(trace: Trace, drink_type: str, VERBOSE: bool = False) -> bool: @@ -65,30 +37,22 @@ def pick_place_con(trace: Trace, drink_type: str, VERBOSE: bool = False) -> bool pick_drink_at_kitchen = trace.ActAtFirst(r"kitchen", Pick(contain_drink)) if VERBOSE: - print_debug( - f"pick_drink_at_kitchen drink type {drink_type}", - pick_drink_at_kitchen, - [label_M, label_AL], - ) + print_debug(f"pick_drink_at_kitchen drink type {drink_type}", + pick_drink_at_kitchen, [label_M, label_AL]) return pick_drink_at_kitchen - def ask_con(trace: Trace, drink_type: str, VERBOSE: bool = False) -> bool: contain_drink = contain_words([drink_type]) - ask_drink = trace.ActAtFirst( - r"lobby", Ask(contain_drink, r".*") - ) or trace.ActAtFirst(r"lobby", Ask(r".*", contain_drink)) - + ask_drink = trace.ActAtFirst(r"lobby", Ask(contain_drink, r".*")) or \ + trace.ActAtFirst(r"lobby", Ask(r".*", contain_drink)) + if VERBOSE: - print_debug( - f"ask_constraint drink type {drink_type}", ask_drink, [label_A, label_AL] - ) + print_debug(f"ask_constraint drink type {drink_type}", ask_drink, [label_A, label_AL]) return ask_drink - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: # goes to only lobby and kitchen go_to_check = trace.Exists(GoTo(r"lobby")) and trace.Exists(GoTo(r"kitchen")) @@ -97,22 +61,11 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: # go to lobby first and then kitchen exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - goto_lobby_first = not trace.BeforeFirst(GoTo(r"lobby")).Exists( - GoTo(exclude_start_loc) - ) + goto_lobby_first = not trace.BeforeFirst(GoTo(r"lobby")).Exists(GoTo(exclude_start_loc)) kitchen_after_lobby = trace.Precedes(GoTo(r"lobby"), GoTo(r"kitchen")) lobby_after_kitchen = trace.Precedes(GoTo(r"kitchen"), GoTo(r"lobby")) - no_goto_start_between = ( - not trace.AfterFirst(GoTo(r"lobby")) - .BeforeLast(GoTo(r"lobby")) - .Exists(GoTo(r"start_loc")) - ) - go_to_order_check = ( - goto_lobby_first - and kitchen_after_lobby - and lobby_after_kitchen - and no_goto_start_between - ) + no_goto_start_between = not trace.AfterFirst(GoTo(r"lobby")).BeforeLast(GoTo(r"lobby")).Exists(GoTo(r"start_loc")) + go_to_order_check = goto_lobby_first and kitchen_after_lobby and lobby_after_kitchen and no_goto_start_between if VERBOSE: print_debug("go_to_check", go_to_check, [label_L]) @@ -124,8 +77,7 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: return go_to_check and not_go_to_check and go_to_order_check - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # ask for water trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -134,8 +86,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say and pick_place - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # ask for tea trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -144,8 +95,7 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say and pick_place - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # ask for lemonade trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -154,9 +104,20 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say and pick_place - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + }, + { + "state": state2, + "test": test2, + "timeout": False + } ] diff --git a/benchmark/tasks/GrilledCheese.py b/benchmark/tasks/GrilledCheese.py index acd1389..bf0d2b8 100644 --- a/benchmark/tasks/GrilledCheese.py +++ b/benchmark/tasks/GrilledCheese.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,56 +12,46 @@ "Create a list of ingredients needed to make grilled cheese. Visit Zarko's office and inquire which of them he possesses. Return and inform me of the items he does not have.", "Put together a compilation of grilled cheese ingredients. Head to Zarko's office, inquire about his available ingredients, and then update me on what he does not have.", "Compile the necessary ingredients for grilled cheese. Go to Zarko's office, ask him about his available items, and then report back to me which items he does not have.", - "Put together a list of grilled cheese ingredients. Head to Zarko's office and inquire about his available ingredients. Return and inform me of what he is missing.", + "Put together a list of grilled cheese ingredients. Head to Zarko's office and inquire about his available ingredients. Return and inform me of what he is missing." ] # construct state -state0 = ( - State() - .addLocation("lobby") - .addLocation("zarko's office") - .addLocation("start_loc") - .addAgent(".*", "zarko's office", [r".*"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("lobby").addLocation("zarko's office").addLocation("start_loc") \ + .addAgent(".*", "zarko's office", [r".*"]) \ + .addRobotLocation("start_loc") # helper checks def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: contain_cheese = contain_words(["cheese"]) contain_bread = contain_words(["bread"]) - go_to_check = not trace.Exists(GoTo(r"lobby")) and trace.Exists( - GoTo(r"zarko's office") - ) - ask_at_zarko_cheese = trace.ActAtFirst( - "zarko's office", Ask(r".*", contain_cheese) - ) or trace.ActAtFirst("zarko's office", Ask(contain_cheese, r".*")) - ask_at_zarko_bread = trace.ActAtFirst( - "zarko's office", Ask(r".*", contain_bread) - ) or trace.ActAtFirst("zarko's office", Ask(contain_bread, r".*")) - say_at_start = trace.AfterFirst(GoTo(r"zarko's office")).ActAtFirst( - "start_loc", Say(r".*") - ) + go_to_check = not trace.Exists(GoTo(r"lobby")) and trace.Exists(GoTo(r"zarko's office")) + ask_at_zarko_cheese = trace.ActAtFirst("zarko's office", Ask(r".*", contain_cheese)) or \ + trace.ActAtFirst("zarko's office", Ask(contain_cheese, r".*")) + ask_at_zarko_bread = trace.ActAtFirst("zarko's office", Ask(r".*", contain_bread)) or \ + trace.ActAtFirst("zarko's office", Ask(contain_bread, r".*")) + say_at_start = trace.AfterFirst(GoTo(r"zarko's office")).ActAtFirst("start_loc", Say(r".*")) if VERBOSE: print("==== generic_con ====") print_debug("go_to_check", go_to_check, [label_L]) - print_debug( - "ask_at_zarko_cheese", ask_at_zarko_cheese, [label_OWK, label_A, label_AL] - ) - print_debug( - "ask_at_zarko_bread", ask_at_zarko_bread, [label_OWK, label_A, label_AL] - ) + print_debug("ask_at_zarko_cheese", ask_at_zarko_cheese, [label_OWK, label_A, label_AL]) + print_debug("ask_at_zarko_bread", ask_at_zarko_bread, [label_OWK, label_A, label_AL]) print_debug("say_at_start", say_at_start, [label_IT, label_S, label_AL]) return go_to_check and ask_at_zarko_cheese and ask_at_zarko_bread and say_at_start - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE=VERBOSE) return generic +tests = [ + { + "state" : state0, + "test" : test0, + "timeout": False + } +] -tests = [{"state": state0, "test": test0, "timeout": False}] diff --git a/benchmark/tasks/HalloweenList.py b/benchmark/tasks/HalloweenList.py index ef907d8..9995bb9 100644 --- a/benchmark/tasks/HalloweenList.py +++ b/benchmark/tasks/HalloweenList.py @@ -1,6 +1,5 @@ import sys - -sys.path.insert(0, "../..") +sys.path.insert(0, '../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,184 +12,133 @@ "Go to every office, and if there is a person there, ask them if they'd like a chocolate, caramel, or gummy. Come back and tell me how many of each we need to buy.", "Check with every occupied office to see if the occupant would like a chocolate, caramel, or gummy. Let me know how many of each we need to buy.", "Find every occupied office and ask their occupants whether they would like a chocolate, caramel, or gummy. Let me know how many of each we need to buy.", - "Go to every office with a person, and ask them if they would like a chocolate, caramel, or gummy, then come back and tell me how many of each people asked for.", + "Go to every office with a person, and ask them if they would like a chocolate, caramel, or gummy, then come back and tell me how many of each people asked for." ] # construct state -state0 = ( - State() - .addLocation("sally's office") - .addLocation("mark's office") - .addLocation("cindy's office") - .addLocation("kitchen") - .addLocation("start_loc") - .addAgent(r".*", "sally's office", ["gumm"]) - .addAgent(r".*", "mark's office", ["caramel"]) - .addAgent(r".*", "cindy's office", ["choco"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("sally's office") - .addLocation("mark's office") - .addLocation("cindy's office") - .addLocation("kitchen") - .addLocation("start_loc") - .addAgent(r".*", "sally's office", ["caramel"]) - .addAgent(r".*", "mark's office", ["gumm"]) - .addAgent(r".*", "cindy's office", ["caramel"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("sally's office") - .addLocation("mark's office") - .addLocation("cindy's office") - .addLocation("kitchen") - .addLocation("start_loc") - .addAgent(r".*", "sally's office", ["choco"]) - .addAgent(r".*", "mark's office", ["choco"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("sally's office").addLocation("mark's office").addLocation("cindy's office") \ + .addLocation("kitchen").addLocation("start_loc") \ + .addAgent(r".*", "sally's office", ["gumm"]) \ + .addAgent(r".*", "mark's office", ["caramel"]) \ + .addAgent(r".*", "cindy's office", ["choco"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("sally's office").addLocation("mark's office").addLocation("cindy's office") \ + .addLocation("kitchen").addLocation("start_loc") \ + .addAgent(r".*", "sally's office", ["caramel"]) \ + .addAgent(r".*", "mark's office", ["gumm"]) \ + .addAgent(r".*", "cindy's office", ["caramel"]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("sally's office").addLocation("mark's office").addLocation("cindy's office") \ + .addLocation("kitchen").addLocation("start_loc") \ + .addAgent(r".*", "sally's office", ["choco"]) \ + .addAgent(r".*", "mark's office", ["choco"]) \ + .addRobotLocation("start_loc") # helper checks -def say_con( - trace: Trace, candy_type: str, candy_num: str, VERBOSE: bool = False -) -> bool: +def say_con(trace: Trace, candy_type: str, candy_num: str, VERBOSE: bool = False) -> bool: # say the choice of candies contained_say = [candy_type, candy_num] say_pattern = contain_words(contained_say) - goto1_before_say = trace.BeforeFirst(Say(say_pattern)).Exists( - GoTo(r"sally's office") - ) - goto2_before_say = trace.BeforeFirst(Say(say_pattern)).Exists( - GoTo(r"mark's office") - ) - goto2_before_say = trace.BeforeFirst(Say(say_pattern)).Exists( - GoTo(r"cindy's office") - ) - + goto1_before_say = trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"sally's office")) + goto2_before_say = trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"mark's office")) + goto2_before_say = trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"cindy's office")) + exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Say(say_pattern) - ) + say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(say_pattern)) if VERBOSE: - print_debug( - f"say_constraint candy type {candy_type} candy num {candy_num}", - say, - [label_S, label_AL], - ) - print_debug( - f"goto1_before_say candy type {candy_type} candy num {candy_num}", - goto1_before_say, - [label_EO], - ) - print_debug( - f"goto2_before_say candy type {candy_type} candy num {candy_num}", - goto2_before_say, - [label_EO], - ) - print_debug( - f"goto2_before_say candy type {candy_type} candy num {candy_num}", - goto2_before_say, - [label_EO], - ) + print_debug(f"say_constraint candy type {candy_type} candy num {candy_num}", say, [label_S, label_AL]) + print_debug(f"goto1_before_say candy type {candy_type} candy num {candy_num}", goto1_before_say, [label_EO]) + print_debug(f"goto2_before_say candy type {candy_type} candy num {candy_num}", goto2_before_say, [label_EO]) + print_debug(f"goto2_before_say candy type {candy_type} candy num {candy_num}", goto2_before_say, [label_EO]) return goto1_before_say and goto2_before_say and goto2_before_say and say - -def ask_con( - trace: Trace, person: str, candy_choice: str, VERBOSE: bool = False -) -> bool: +def ask_con(trace: Trace, person: str, candy_choice: str, VERBOSE: bool = False) -> bool: # ask person if they want chocolate, caramel, or gummy contain_candy = contain_words([candy_choice]) - ask_candy = trace.ActAtFirst( - f"{person}'s office", Ask(contain_candy, r".*") - ) or trace.ActAtFirst(f"{person}'s office", Ask(".*", contain_candy)) + ask_candy = trace.ActAtFirst(f"{person}'s office", Ask(contain_candy, r".*")) or \ + trace.ActAtFirst(f"{person}'s office", Ask(".*", contain_candy)) if VERBOSE: - print_debug( - f"person {person} ask_{candy_choice}", ask_candy, [label_A, label_AL] - ) + print_debug(f"person {person} ask_{candy_choice}", ask_candy, [label_A, label_AL]) return ask_candy - def generic_con(trace, VERBOSE: bool = False) -> bool: # goes to only alice and bob's office - go_to_check = ( - trace.Exists(GoTo(r"sally's office")) - and trace.Exists(GoTo(r"mark's office")) - and trace.Exists(GoTo(r"cindy's office")) - ) - + go_to_check = trace.Exists(GoTo(r"sally's office")) and \ + trace.Exists(GoTo(r"mark's office")) and \ + trace.Exists(GoTo(r"cindy's office")) + not_go_to_check = not trace.Exists(GoTo(r"kitchen")) - check_person_in_office = ( - trace.ActAtFirst(r"sally's office", CheckEntity(".*")) - and trace.ActAtFirst(r"mark's office", CheckEntity(".*")) - and trace.ActAtFirst(r"cindy's office", CheckEntity(".*")) - ) - + check_person_in_office = trace.ActAtFirst(r"sally's office", CheckEntity(".*")) and \ + trace.ActAtFirst(r"mark's office", CheckEntity(".*")) and \ + trace.ActAtFirst(r"cindy's office", CheckEntity(".*")) + if VERBOSE: print_debug("go_to_check", go_to_check, [label_ES]) print_debug("not_go_to_check", not_go_to_check, [label_ES]) - print_debug( - "check_person_in_office", check_person_in_office, [label_CE, label_AL] - ) - + print_debug("check_person_in_office", check_person_in_office, [label_CE, label_AL]) + return go_to_check and not_go_to_check and check_person_in_office - -def test_0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: - # go to all offices and get one each +def test_0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: + # go to all offices and get one each trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) ask_sally = ask_con(trace, "sally", "gumm", VERBOSE) ask_mark = ask_con(trace, "mark", "caramel", VERBOSE) ask_cindy = ask_con(trace, "cindy", "choco", VERBOSE) - - say_candy = ( - say_con(trace, "choco", "1|.*one", VERBOSE) - and say_con(trace, "gumm", "1|.*one", VERBOSE) - and say_con(trace, "caramel", "1|.*one", VERBOSE) - ) + + say_candy = say_con(trace, "choco", "1|.*one", VERBOSE) and \ + say_con(trace, "gumm", "1|.*one", VERBOSE) and \ + say_con(trace, "caramel", "1|.*one", VERBOSE) return generic and ask_sally and ask_mark and ask_cindy and say_candy - -def test_1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: - # go to all offices and get 2 caramel and 1 gummy +def test_1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: + # go to all offices and get 2 caramel and 1 gummy trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) ask_sally = ask_con(trace, "sally", "caramel", VERBOSE) ask_mark = ask_con(trace, "mark", "gumm", VERBOSE) ask_cindy = ask_con(trace, "cindy", "caramel", VERBOSE) - - say_candy = say_con(trace, "gumm", "1|.*one", VERBOSE) and say_con( - trace, "caramel", "2|.*two", VERBOSE - ) + + say_candy = say_con(trace, "gumm", "1|.*one", VERBOSE) and \ + say_con(trace, "caramel", "2|.*two", VERBOSE) return generic and ask_sally and ask_mark and ask_cindy and say_candy - -def test_2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test_2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # go to sally and mark's office and 2 chocolate trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) ask_sally = ask_con(trace, "sally", "choco", VERBOSE) ask_mark = ask_con(trace, "mark", "choco", VERBOSE) not_ask_cindy = not ask_con(trace, "cindy", ".*", VERBOSE) - + say_candy = say_con(trace, "choco", "2|.*two", VERBOSE) return generic and ask_sally and ask_mark and not_ask_cindy and say_candy - tests = [ - {"state": state0, "test": test_0, "timeout": False}, - {"state": state1, "test": test_1, "timeout": False}, - {"state": state2, "test": test_2, "timeout": False}, + { + "state": state0, + "test": test_0, + "timeout": False + }, + { + "state": state1, + "test": test_1, + "timeout": False + }, + { + "state": state2, + "test": test_2, + "timeout": False + } ] + diff --git a/benchmark/tasks/HalloweenShopping.py b/benchmark/tasks/HalloweenShopping.py index 019eb5e..092531c 100644 --- a/benchmark/tasks/HalloweenShopping.py +++ b/benchmark/tasks/HalloweenShopping.py @@ -1,6 +1,5 @@ import sys - -sys.path.insert(0, "../..") +sys.path.insert(0, '../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,72 +12,33 @@ "For each office, check if there is anyone there. If there is, ask the person to choose how many (0-4) of each of the following they'd like: caramel, chocolate, or gummy. Come back and tell me how many of each we need to buy.", "Visit every office. If there is a person in the office, ask the person to select 0 to 4 for each of the following categories: gummy, chocolate, or caramel. Return to me and say how many of each we need to buy.", "Go to each office. If no person is in the office, skip this office. Otherwise, ask the person in the office to whether they'd like 0,1,2,3, or 4 for each of the following: gummy, caramel, or chocolate. Return to me and say how many of each we need to buy.", - "Go to every office and skip any office without a person in there. Otherwise, ask the person in the office to decide on how many, from zero to four, of the following they'd like: gummy, caramel, or chocolate. Return to me and say how many of each we need to buy. ", + "Go to every office and skip any office without a person in there. Otherwise, ask the person in the office to decide on how many, from zero to four, of the following they'd like: gummy, caramel, or chocolate. Return to me and say how many of each we need to buy. " ] # construct state -state0 = ( - State() - .addLocation("gavin's office") - .addLocation("sunny's office") - .addLocation("frank's office") - .addLocation("lobby") - .addLocation("robotics lab") - .addLocation("start_loc") - .addAgent(".*", "gavin's office", [r"4|four"]) - .addAgent(".*", "sunny's office", [r"4|four"]) - .addAgent(".*", "frank's office", [r"4|four"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("gavin's office") - .addLocation("sunny's office") - .addLocation("frank's office") - .addLocation("lobby") - .addLocation("robotics lab") - .addLocation("start_loc") - .addAgent(".*", "gavin's office", [r"3|three"]) - .addAgent(".*", "sunny's office", [r"1|one"]) - .addAgent(".*", "frank's office", [r"2|two"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("gavin's office") - .addLocation("sunny's office") - .addLocation("frank's office") - .addLocation("lobby") - .addLocation("robotics lab") - .addLocation("start_loc") - .addAgent(".*", "frank's office", [r"4|four"]) - .addRobotLocation("start_loc") -) - -state3 = ( - State() - .addLocation("gavin's office") - .addLocation("sunny's office") - .addLocation("frank's office") - .addLocation("lobby") - .addLocation("robotics lab") - .addLocation("start_loc") - .addAgent(".*", "frank's office", [r"0|zero"]) - .addRobotLocation("start_loc") -) - -state4 = ( - State() - .addLocation("gavin's office") - .addLocation("sunny's office") - .addLocation("frank's office") - .addLocation("lobby") - .addLocation("robotics lab") - .addLocation("start_loc") - .addRobotLocation("start_loc") -) +state0 = State().addLocation("gavin's office").addLocation("sunny's office").addLocation("frank's office") \ + .addLocation("lobby").addLocation("robotics lab").addLocation("start_loc") \ + .addAgent(".*", "gavin's office", [r"4|four"]).addAgent(".*", "sunny's office", [r"4|four"]).addAgent(".*", "frank's office", [r"4|four"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("gavin's office").addLocation("sunny's office").addLocation("frank's office") \ + .addLocation("lobby").addLocation("robotics lab").addLocation("start_loc") \ + .addAgent(".*", "gavin's office", [r"3|three"]).addAgent(".*", "sunny's office", [r"1|one"]).addAgent(".*", "frank's office", [r"2|two"]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("gavin's office").addLocation("sunny's office").addLocation("frank's office") \ + .addLocation("lobby").addLocation("robotics lab").addLocation("start_loc") \ + .addAgent(".*", "frank's office", [r"4|four"]) \ + .addRobotLocation("start_loc") + +state3 = State().addLocation("gavin's office").addLocation("sunny's office").addLocation("frank's office") \ + .addLocation("lobby").addLocation("robotics lab").addLocation("start_loc") \ + .addAgent(".*", "frank's office", [r"0|zero"]) \ + .addRobotLocation("start_loc") + +state4 = State().addLocation("gavin's office").addLocation("sunny's office").addLocation("frank's office") \ + .addLocation("lobby").addLocation("robotics lab").addLocation("start_loc") \ + .addRobotLocation("start_loc") # helper checks def ask_con(trace: Trace, agent_name: str, VERBOSE: bool = False) -> bool: @@ -90,12 +50,8 @@ def ask_con(trace: Trace, agent_name: str, VERBOSE: bool = False) -> bool: caramel_pattern = contain_words(contained_caramel_words) gummy_pattern = contain_words(contained_gummy_words) - chocolate_ask = trace.ActAtFirst( - f"{agent_name}'s office", Ask(chocolate_pattern, r".*") - ) - caramel_ask = trace.ActAtFirst( - f"{agent_name}'s office", Ask(caramel_pattern, r".*") - ) + chocolate_ask = trace.ActAtFirst(f"{agent_name}'s office", Ask(chocolate_pattern, r".*")) + caramel_ask = trace.ActAtFirst(f"{agent_name}'s office", Ask(caramel_pattern, r".*")) gummy_ask = trace.ActAtFirst(f"{agent_name}'s office", Ask(gummy_pattern, r".*")) if VERBOSE: @@ -105,41 +61,33 @@ def ask_con(trace: Trace, agent_name: str, VERBOSE: bool = False) -> bool: return chocolate_ask and caramel_ask and gummy_ask - def say_con(trace: Trace, number: str, item: str, VERBOSE: bool = False) -> bool: exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) say_pattern = contain_words([number, item]) # don't return to start location after leaving start location until end (needs to check) - say_at_start = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Say(say_pattern) - ) + say_at_start = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(say_pattern)) if VERBOSE: print_debug("say_at_start", say_at_start, [label_IT]) return say_at_start - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: - go_to_check = ( - trace.Exists(GoTo(r"gavin's office")) - and trace.Exists(GoTo(r"sunny's office")) - and trace.Exists(GoTo(r"frank's office")) - ) - - not_go_to_check = not trace.Exists(GoTo(r"lobby")) and not trace.Exists( - GoTo(r"robotics") - ) - + go_to_check = trace.Exists(GoTo(r"gavin's office")) and \ + trace.Exists(GoTo(r"sunny's office")) and \ + trace.Exists(GoTo(r"frank's office")) + + not_go_to_check = not trace.Exists(GoTo(r"lobby")) and \ + not trace.Exists(GoTo(r"robotics")) + if VERBOSE: print_debug("go_to_check", go_to_check, [label_ES]) print_debug("not_go_to_check", not_go_to_check, [label_ES]) - + return go_to_check and not_go_to_check - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_chocolate = say_con(trace, "12", "choco", VERBOSE) @@ -148,8 +96,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_chocolate and say_caramel and say_gummy - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_chocolate = say_con(trace, "6", "choco", VERBOSE) @@ -158,8 +105,7 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_chocolate and say_caramel and say_gummy - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_chocolate = say_con(trace, "4", "choco", VERBOSE) @@ -168,21 +114,43 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_chocolate and say_caramel and say_gummy - -def test3_and_4(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test3_and_4(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_chocolate = say_con(trace, "0|.*zero|.*no", "choco", VERBOSE) say_caramel = say_con(trace, "0|.*zero|.*no", "caramel", VERBOSE) say_gummy = say_con(trace, "0|.*zero|.*no", "gumm", VERBOSE) - return generic and say_chocolate and say_caramel and say_gummy - + return generic and \ + say_chocolate and \ + say_caramel and \ + say_gummy tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, - {"state": state3, "test": test3_and_4, "timeout": False}, - {"state": state4, "test": test3_and_4, "timeout": False}, + { + "state" : state0, + "test" : test0, + "timeout": False + }, + { + "state" : state1, + "test" : test1, + "timeout": False + }, + { + "state" : state2, + "test" : test2, + "timeout": False + }, + { + "state" : state3, + "test" : test3_and_4, + "timeout": False + }, + { + "state" : state4, + "test" : test3_and_4, + "timeout": False + } ] + diff --git a/benchmark/tasks/LunchBreak.py b/benchmark/tasks/LunchBreak.py index fa16bef..89dd6ff 100644 --- a/benchmark/tasks/LunchBreak.py +++ b/benchmark/tasks/LunchBreak.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,53 +12,29 @@ "Ask Alice in her office if she is up for lunch, and if yes, tell her that we will meet in the lobby in 5 minutes. Do the same for Bob. Come back and tell me who all are joining for lunch.", "Go to Alice's and Bob's offices and ask each of them if they are up for lunch. If they say yes, tell them that we will meet in the lobby in 5 minutes. Come back and tell me who all are joining for lunch.", "Ask Alice and Bob if they are up for lunch. If they say yes, tell them that we will meet in the lobby in five minutes. Come back and tell me who all are joining for lunch.", - "Go to Alice's office and ask her if she is free for lunch. If she says yes, tell her that we will meet in the lobby in five minutes. Do the same for Bob. Come back and tell me who will join for lunch.", + "Go to Alice's office and ask her if she is free for lunch. If she says yes, tell her that we will meet in the lobby in five minutes. Do the same for Bob. Come back and tell me who will join for lunch." ] # construct state -state0 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["yes"]) - .addAgent(".*", "bob's office", ["yes"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["no"]) - .addAgent(".*", "bob's office", ["no"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["yes"]) - .addAgent(".*", "bob's office", ["no"]) - .addRobotLocation("start_loc") -) - -state3 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["no"]) - .addAgent(".*", "bob's office", ["yes"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office") \ + .addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["yes"]).addAgent(".*", "bob's office", ["yes"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office") \ + .addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["no"]).addAgent(".*", "bob's office", ["no"]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office") \ + .addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["yes"]).addAgent(".*", "bob's office", ["no"]) \ + .addRobotLocation("start_loc") + +state3 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office") \ + .addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["no"]).addAgent(".*", "bob's office", ["yes"]) \ + .addRobotLocation("start_loc") # helper checks def say_con(trace: Trace, person: str, VERBOSE: bool = False) -> bool: @@ -68,50 +43,38 @@ def say_con(trace: Trace, person: str, VERBOSE: bool = False) -> bool: excluded_words = ["no", "not"] say_pattern = contain_words_and_exlude_words(contained_say, excluded_words) - goto_before_say = trace.BeforeFirst(Say(say_pattern)).Exists( - GoTo(r"alice's office") - ) and trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"bob's office")) + goto_before_say = trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"alice's office")) and \ + trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"bob's office")) exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - - say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Say(say_pattern) - ) + + say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(say_pattern)) if VERBOSE: print_debug(f"say_constraint person {person}", say, [label_S, label_AL]) print_debug(f"goto_before_say person {person}", goto_before_say, [label_EO]) return goto_before_say and say - def meet_in_lobby_con(trace: Trace, person: str, VERBOSE: bool = False) -> bool: meet_lobby_pattern = contain_words(["5|.*five", "lobby"]) loc = f"{person}'s office" say = trace.ActAtFirst(loc, Say(meet_lobby_pattern)) lunch_pattern = contain_words(["lunch"]) - ask_before_say = ( - trace.AfterFirst(GoTo(loc)) - .BeforeFirst(GoTo(r"^(?!.*\b{loc}\b).*$".format(loc=loc))) - .BeforeFirst(Say(meet_lobby_pattern)) - .Exists(Ask(lunch_pattern, r".*")) - ) - + ask_before_say = trace.AfterFirst(GoTo(loc)).BeforeFirst(GoTo(r"^(?!.*\b{loc}\b).*$".format(loc=loc))) \ + .BeforeFirst(Say(meet_lobby_pattern)).Exists(Ask(lunch_pattern, r".*")) + if VERBOSE: - print_debug( - f"meet_in_lobby_constraint person {person}", say, [label_S, label_AL] - ) + print_debug(f"meet_in_lobby_constraint person {person}", say, [label_S, label_AL]) print_debug(f"ask_before_say person {person}", ask_before_say, [label_EO]) - + return ask_before_say and say - def generic_con(trace, VERBOSE: bool = False) -> bool: # goes to only alice and bob's office - go_to_check = trace.Exists(GoTo(r"alice's office")) and trace.Exists( - GoTo(r"bob's office") - ) - + go_to_check = trace.Exists(GoTo(r"alice's office")) and \ + trace.Exists(GoTo(r"bob's office")) + not_go_to_check = not trace.Exists(GoTo(r"charlie's office")) # ask alice and bob in their office @@ -124,11 +87,10 @@ def generic_con(trace, VERBOSE: bool = False) -> bool: print_debug("not_go_to_check", not_go_to_check, [label_L]) print_debug("ask_alice", ask_alice, [label_A, label_AL]) print_debug("bob_alice", bob_alice, [label_A, label_AL]) - + return go_to_check and not_go_to_check and ask_alice and bob_alice - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # both alice and bob join trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -138,8 +100,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: bob_say = say_con(trace, "bob", VERBOSE) return generic and alice_meet_lobby and bob_meet_lobby and alice_say and bob_say - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # neither join trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -147,16 +108,9 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: not_bob_meet_lobby = not meet_in_lobby_con(trace, "bob", VERBOSE) not_alice_say = not say_con(trace, "alice", VERBOSE) not_bob_say = not say_con(trace, "bob", VERBOSE) - return ( - generic - and not_alice_meet_lobby - and not_bob_meet_lobby - and not_alice_say - and not_bob_say - ) - + return generic and not_alice_meet_lobby and not_bob_meet_lobby and not_alice_say and not_bob_say -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # only alice joins trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -164,16 +118,9 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: not_bob_meet_lobby = not meet_in_lobby_con(trace, "bob", VERBOSE) alice_say = say_con(trace, "alice", VERBOSE) not_bob_say = not say_con(trace, "bob", VERBOSE) - return ( - generic - and alice_meet_lobby - and not_bob_meet_lobby - and alice_say - and not_bob_say - ) + return generic and alice_meet_lobby and not_bob_meet_lobby and alice_say and not_bob_say - -def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test3(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # only bob joins trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -181,18 +128,28 @@ def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: bob_meet_lobby = meet_in_lobby_con(trace, "bob", VERBOSE) not_alice_say = not say_con(trace, "alice", VERBOSE) bob_say = say_con(trace, "bob", VERBOSE) - return ( - generic - and not_alice_meet_lobby - and bob_meet_lobby - and not_alice_say - and bob_say - ) - + return generic and not_alice_meet_lobby and bob_meet_lobby and not_alice_say and bob_say tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, - {"state": state3, "test": test3, "timeout": False}, + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + }, + { + "state": state2, + "test": test2, + "timeout": False + }, + { + "state": state3, + "test": test3, + "timeout": False + } ] + diff --git a/benchmark/tasks/LunchTime.py b/benchmark/tasks/LunchTime.py index 3969502..58870a9 100644 --- a/benchmark/tasks/LunchTime.py +++ b/benchmark/tasks/LunchTime.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,34 +12,24 @@ "Go to Jill's office and ask her whether she's free to go for lunch tomorrow. If yes, ask her when (give her some reasonable times), and come back and tell me what she said.", "Visit Jill's office and ask her if she would like to go for lunch tomorrow. If yes, ask her when (offer some reasonable lunch time options). Let me know what she said.", "Ask Jill in her office whether she will be free to go for lunch tomorrow. If yes, offer her some reasonable time options to choose from, and come back and tell me what she said.", - "Ask Jill in her office if she want to go for lunch tomorrow. If yes, give her some reasonable time options and ask her to choose a time. Finally come back and tell me what she said.", + "Ask Jill in her office if she want to go for lunch tomorrow. If yes, give her some reasonable time options and ask her to choose a time. Finally come back and tell me what she said." ] # construct state -state0 = ( - State() - .addLocation("jill's office") - .addLocation("andrew's office") - .addLocation("start_loc") - .addAgent(".*", "jill's office", [r"yes", r".*"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("jill's office") - .addLocation("andrew's office") - .addLocation("start_loc") - .addAgent(".*", "jill's office", [r"no", r".*"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("jill's office").addLocation("andrew's office").addLocation("start_loc") \ + .addAgent(".*", "jill's office", [r"yes", r".*"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("jill's office").addLocation("andrew's office").addLocation("start_loc") \ + .addAgent(".*", "jill's office", [r"no", r".*"]) \ + .addRobotLocation("start_loc") # helper checks def say_con(trace: Trace, VERBOSE: bool = False) -> bool: goto_before_say = trace.BeforeFirst(Say(".*")).Exists(GoTo(r"jill's office")) exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - + say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(r".*")) if VERBOSE: @@ -48,32 +37,22 @@ def say_con(trace: Trace, VERBOSE: bool = False) -> bool: print_debug("goto_before_say", goto_before_say, [label_IT]) return goto_before_say and say - def ask_lunch_con(trace: Trace, VERBOSE: bool = False) -> bool: # ask for time lunch_pattern = contain_words(["lunch"]) - not_contain = [f"{i}:" for i in range(17, 25)] + [f"{i}:" for i in range(4, 9)] + not_contain = [f"{i}:" for i in range(17,25)] + [f"{i}:" for i in range(4,9)] not_contain = ["|.*".join(not_contain)] ask_time_pattern = contain_words(["11|.*eleven|.*12|.*twelve"]) ask_not_contain_time_pattern = contain_words(not_contain) - ask_time = trace.ActAtFirst( - r"jill's office", Ask(ask_time_pattern, r".*") - ) or trace.ActAtFirst(r"jill's office", Ask(r".*", ask_time_pattern)) + ask_time = trace.ActAtFirst(r"jill's office", Ask(ask_time_pattern, r".*")) or \ + trace.ActAtFirst(r"jill's office", Ask(r".*", ask_time_pattern)) + + not_ask_time = not (trace.ActAtFirst(r"jill's office", Ask(ask_not_contain_time_pattern, r".*")) or \ + trace.ActAtFirst(r"jill's office", Ask(r".*", ask_not_contain_time_pattern))) - not_ask_time = not ( - trace.ActAtFirst(r"jill's office", Ask(ask_not_contain_time_pattern, r".*")) - or trace.ActAtFirst(r"jill's office", Ask(r".*", ask_not_contain_time_pattern)) - ) - - ask_lunch_before_time = not ( - trace.BeforeFirst(Ask(lunch_pattern, r".*")).Exists( - Ask(ask_time_pattern, r".*") - ) - or trace.BeforeFirst(Ask(lunch_pattern, r".*")).Exists( - Ask(r".*", ask_time_pattern) - ) - ) + ask_lunch_before_time = not (trace.BeforeFirst(Ask(lunch_pattern, r".*")).Exists(Ask(ask_time_pattern, r".*")) or \ + trace.BeforeFirst(Ask(lunch_pattern, r".*")).Exists(Ask(r".*", ask_time_pattern))) if VERBOSE: print_debug("ask_time", ask_time, [label_A, label_AL]) @@ -82,24 +61,21 @@ def ask_lunch_con(trace: Trace, VERBOSE: bool = False) -> bool: return ask_time and ask_lunch_before_time and not_ask_time - def not_ask_lunch_con(trace: Trace, VERBOSE: bool = False) -> bool: lunch_pattern = contain_words(["lunch"]) - only_ask_for_lunc = not trace.Precedes( - Ask(lunch_pattern, r".*"), Ask(r".*", r".*") - ) and not trace.BeforeFirst(Ask(lunch_pattern, r".*")).Exists(Ask(r".*", r".*")) - + only_ask_for_lunc = not trace.Precedes(Ask(lunch_pattern, r".*"), Ask(r".*", r".*")) and \ + not trace.BeforeFirst(Ask(lunch_pattern, r".*")).Exists(Ask(r".*", r".*")) + if VERBOSE: print_debug("only_ask_for_lunc", only_ask_for_lunc, [label_A, label_AL]) return only_ask_for_lunc - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: # goes to only jill's office and not andrew's office - go_to_check = trace.Exists(GoTo(r"jill's office")) - + go_to_check = trace.Exists(GoTo(r"jill's office")) + not_go_to_check = not trace.Exists(GoTo(r"andrew's office")) # ask for lunch @@ -113,8 +89,7 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: return go_to_check and not_go_to_check and ask_lunch - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # jill says yes to lunch trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -122,8 +97,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: say = say_con(trace, VERBOSE) return generic and ask and say - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # jill says no to lunch trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -131,8 +105,15 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: say = say_con(trace, VERBOSE) return generic and not_ask and say - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, -] + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + } +] \ No newline at end of file diff --git a/benchmark/tasks/MailDelivery.py b/benchmark/tasks/MailDelivery.py index 1785b24..29a4e8f 100644 --- a/benchmark/tasks/MailDelivery.py +++ b/benchmark/tasks/MailDelivery.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,133 +12,67 @@ "Go to the mail room to pick a mail bin. Ask at every office if they have any mail to deliver. If they reply yes, ask them to put the mail in the bin. Return to the mail room with the mail. Tell me at the mail room which offices these mail are from and put the mail bin back.", "Grab a mail bin from the mail room. Go to every office, and ask if they have any mail to deliver. Ask them to put all mail in the bin if there is any. Put the mail bin back in the mail room and report which offices the mail is from.", "Find a mail bin in the mail room and carry it with you. Collect mail from every office by asking if there is any mail they'd like delivered. If yes, ask them to put it in the bin. Return the bin to the mail room and say which offices sent mail.", - "Take a mail bin from the mail room. For every office, ask if there is any mail to deliver and if someone says yes, ask them to put all mail in the bin. Finally find me at the mail room. Put the mail bin away, and tell me which offices had mail.", + "Take a mail bin from the mail room. For every office, ask if there is any mail to deliver and if someone says yes, ask them to put all mail in the bin. Finally find me at the mail room. Put the mail bin away, and tell me which offices had mail." ] # construct state -state0 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("mail room") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["yes", ".*"]) - .addAgent(".*", "bob's office", ["yes", ".*"]) - .addAgent(".*", "charlie's office", ["yes", ".*"]) - .addObject("bin", "mail room") - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("mail room") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["no", ".*"]) - .addAgent(".*", "bob's office", ["yes", ".*"]) - .addAgent(".*", "charlie's office", ["yes", ".*"]) - .addObject("bin", "mail room") - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("mail room") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["yes", ".*"]) - .addAgent(".*", "bob's office", ["no", ".*"]) - .addAgent(".*", "charlie's office", ["no", ".*"]) - .addObject("bin", "mail room") - .addRobotLocation("start_loc") -) - -state3 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("mail room") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "alice's office", ["no", ".*"]) - .addAgent(".*", "bob's office", ["no", ".*"]) - .addAgent(".*", "charlie's office", ["no", ".*"]) - .addObject("bin", "mail room") - .addRobotLocation("start_loc") -) +state0 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office").addLocation("mail room") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["yes", ".*"]).addAgent(".*", "bob's office", ["yes", ".*"]).addAgent(".*", "charlie's office", ["yes", ".*"]) \ + .addObject("bin", "mail room") \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office").addLocation("mail room") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["no", ".*"]).addAgent(".*", "bob's office", ["yes", ".*"]).addAgent(".*", "charlie's office", ["yes", ".*"]) \ + .addObject("bin", "mail room") \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office").addLocation("mail room") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["yes", ".*"]).addAgent(".*", "bob's office", ["no", ".*"]).addAgent(".*", "charlie's office", ["no", ".*"]) \ + .addObject("bin", "mail room") \ + .addRobotLocation("start_loc") + +state3 = State().addLocation("alice's office").addLocation("bob's office").addLocation("charlie's office").addLocation("mail room") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "alice's office", ["no", ".*"]).addAgent(".*", "bob's office", ["no", ".*"]).addAgent(".*", "charlie's office", ["no", ".*"]) \ + .addObject("bin", "mail room") \ + .addRobotLocation("start_loc") # helper checks def say_con(trace: Trace, person: str, VERBOSE: bool = False) -> bool: say = contain_words([person]) - + # don't return to start location after leaving start location until end say_at_start = trace.AfterFirst(GoTo("mail room")).ActAtFirst("mail room", Say(say)) if VERBOSE: - print_debug( - f"say_constraint person {person}", say_at_start, [label_S, label_AL] - ) + print_debug(f"say_constraint person {person}", say_at_start, [label_S, label_AL]) return say_at_start - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: - go_to_offices_mail_room = ( - trace.Exists(GoTo(r"alice's office")) - and trace.Exists(GoTo(r"bob's office")) - and trace.Exists(GoTo(r"charlie's office")) - and trace.Exists(GoTo(r"mail room")) - ) - not_go_to_other = not trace.Exists(GoTo(r"lobby")) and not trace.Exists( - GoTo(r"conference room") - ) + go_to_offices_mail_room = trace.Exists(GoTo(r"alice's office")) and \ + trace.Exists(GoTo(r"bob's office")) and \ + trace.Exists(GoTo(r"charlie's office")) and \ + trace.Exists(GoTo(r"mail room")) + not_go_to_other = not trace.Exists(GoTo(r"lobby")) and not trace.Exists(GoTo(r"conference room")) exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) pick_at_mail_room = trace.ActAtFirst("mail room", Pick("bin")) - first_mail_room = not trace.BeforeFirst(GoTo("mail room")).Exists( - GoTo(exclude_start_loc) - ) - place_at_mail_room = trace.AfterFirst(GoTo("mail room")).ActAtFirst( - "mail room", Place("bin") - ) - mail_room_after_visiting_all = ( - trace.AfterFirst(GoTo("mail room")) - .BeforeFirst(GoTo("mail room")) - .Exists(GoTo("alice's office")) - and trace.AfterFirst(GoTo("mail room")) - .BeforeFirst(GoTo("mail room")) - .Exists(GoTo("bob's office")) - and trace.AfterFirst(GoTo("mail room")) - .BeforeFirst(GoTo("mail room")) - .Exists(GoTo("charlie's office")) - ) - manipulate_at_mail = ( - pick_at_mail_room - and first_mail_room - and place_at_mail_room - and mail_room_after_visiting_all - ) + first_mail_room = not trace.BeforeFirst(GoTo("mail room")).Exists(GoTo(exclude_start_loc)) + place_at_mail_room = trace.AfterFirst(GoTo("mail room")).ActAtFirst("mail room", Place("bin")) + mail_room_after_visiting_all = trace.AfterFirst(GoTo("mail room")).BeforeFirst(GoTo("mail room")).Exists(GoTo("alice's office")) and \ + trace.AfterFirst(GoTo("mail room")).BeforeFirst(GoTo("mail room")).Exists(GoTo("bob's office")) and \ + trace.AfterFirst(GoTo("mail room")).BeforeFirst(GoTo("mail room")).Exists(GoTo("charlie's office")) + manipulate_at_mail = pick_at_mail_room and first_mail_room and place_at_mail_room and mail_room_after_visiting_all contained_ask = contain_words(["mail"]) - ask_at_office = ( - trace.ActAtFirst("alice's office", Ask(contained_ask, r".*")) - and trace.ActAtFirst("bob's office", Ask(contained_ask, r".*")) - and trace.ActAtFirst("charlie's office", Ask(contained_ask, r".*")) - ) - + ask_at_office = trace.ActAtFirst("alice's office", Ask(contained_ask, r".*")) and \ + trace.ActAtFirst("bob's office", Ask(contained_ask, r".*")) and \ + trace.ActAtFirst("charlie's office", Ask(contained_ask, r".*")) + if VERBOSE: print_debug("go_to_offices_mail_room", go_to_offices_mail_room, [label_ES]) print_debug("not_go_to_other", not_go_to_other, [label_ES]) @@ -147,19 +80,11 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: print_debug("pick_at_mail_room", pick_at_mail_room, [label_M, label_AL]) print_debug("first_mail_room", first_mail_room, [label_IT]) print_debug("place_at_mail_room", place_at_mail_room, [label_M, label_AL]) - print_debug( - "mail_room_after_visiting_all", mail_room_after_visiting_all, [label_IT] - ) - - return ( - go_to_offices_mail_room - and not_go_to_other - and ask_at_office - and manipulate_at_mail - ) + print_debug("mail_room_after_visiting_all", mail_room_after_visiting_all, [label_IT]) + return go_to_offices_mail_room and not_go_to_other and ask_at_office and manipulate_at_mail -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_alice = say_con(trace, "alice", VERBOSE) @@ -168,8 +93,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_alice and say_bob and say_charlie - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) not_say_alice = not say_con(trace, "alice", VERBOSE) @@ -177,8 +101,7 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: say_charlie = say_con(trace, "charlie", VERBOSE) return generic and not_say_alice and say_bob and say_charlie - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_alice = say_con(trace, "alice", VERBOSE) @@ -187,8 +110,7 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_alice and not_say_bob and not_say_charlie - -def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) not_say_alice = not say_con(trace, "alice", VERBOSE) @@ -197,10 +119,26 @@ def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and not_say_alice and not_say_bob and not_say_charlie - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, - {"state": state3, "test": test3, "timeout": False}, + { + "state" : state0, + "test" : test0, + "timeout": False + }, + { + "state" : state1, + "test" : test1, + "timeout": False + }, + { + "state" : state2, + "test" : test2, + "timeout": False + }, + { + "state" : state3, + "test" : test3, + "timeout": False + } ] + diff --git a/benchmark/tasks/MovieMessenger.py b/benchmark/tasks/MovieMessenger.py index f7dbe36..8e3cf13 100644 --- a/benchmark/tasks/MovieMessenger.py +++ b/benchmark/tasks/MovieMessenger.py @@ -1,6 +1,5 @@ import sys - -sys.path.insert(0, "../..") +sys.path.insert(0, '../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -14,72 +13,41 @@ "Ask Sally if she wants to go to the cinema with Mark. Tell Mark what Sally said, and if Sally said yes, ask Mark whether he wants to leave at 4PM, 5PM, or 6PM, and then go tell Sally what time Mark is leaving.", "Ask Sally if she wants to go to the cinema with Mark. Tell Mark what Sally said, and if yes, ask Mark whether he wants to leave at 4PM, 5PM, or 6PM. If Sally said yes, go tell Sally what time Mark is leaving.", "Go to Sally's office and ask her if she wants to go to the cinema with Mark. Tell Mark what Sally said, and if yes, ask Mark whether he wants to leave at 4PM, 5PM, or 6PM, and then go back to Sally's office and tell her what Mark said.", - "Ask Sally if she wants to go to the cinema with Mark. Tell Mark what Sally said, and if yes, ask Mark whether he wants to leave at 4PM, 5PM, or 6PM. Then then go tell Sally what Mark said.", + "Ask Sally if she wants to go to the cinema with Mark. Tell Mark what Sally said, and if yes, ask Mark whether he wants to leave at 4PM, 5PM, or 6PM. Then then go tell Sally what Mark said." ] # construct state -state0 = ( - State() - .addLocation("sally's office") - .addLocation("mark's office") - .addLocation("start_loc") - .addAgent(".*", "sally's office", ["yes"]) - .addAgent(".*", "mark's office", ["6pm"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("sally's office") - .addLocation("mark's office") - .addLocation("start_loc") - .addAgent(".*", "sally's office", ["yes"]) - .addAgent(".*", "mark's office", ["5pm"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("sally's office") - .addLocation("mark's office") - .addLocation("start_loc") - .addAgent(".*", "sally's office", ["no"]) - .addAgent(".*", "mark's office", [".*"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("sally's office").addLocation("mark's office").addLocation("start_loc") \ + .addAgent(".*", "sally's office", ["yes"]).addAgent(".*", "mark's office", [contain_words(["6","pm"])]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("sally's office").addLocation("mark's office").addLocation("start_loc") \ + .addAgent(".*", "sally's office", ["yes"]).addAgent(".*", "mark's office", [contain_words(["5","pm"])]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("sally's office").addLocation("mark's office").addLocation("start_loc") \ + .addAgent(".*", "sally's office", ["no"]).addAgent(".*", "mark's office", [".*"]) \ + .addRobotLocation("start_loc") # helper checks def answer_no_con(trace: Trace, VERBOSE: bool = False) -> bool: - new_trace = trace.AfterFirst(GoTo("mark's office")).AfterFirst( - Say(contain_words(["no"])) - ) - - not_ask_say = not new_trace.Exists(Ask(r".*", r".*")) and not new_trace.Exists( - Say(r".*") - ) + new_trace = trace.AfterFirst(GoTo("mark's office")).AfterFirst(Say(contain_words(["no"]))) + not_ask_say = not new_trace.Exists(Ask(r".*", r".*")) and not new_trace.Exists(Say(r".*")) + if VERBOSE: print_debug("not_ask_say", not_ask_say, [label_A, label_AL]) return not_ask_say +def answer_yes_con(trace: Trace, time: List[str], VERBOSE: bool = False) -> bool: + ask_mark = trace.ActAtFirst(r"mark's office", Ask(contain_words(time), r".*")) or \ + trace.ActAtFirst(r"mark's office", Ask(r".*", contain_words(time))) + + goto_sally_after_mark = trace.AfterFirst(GoTo(r"mark's office")).Exists(GoTo(r"sally's office")) and \ + not trace.AfterFirst(GoTo(r"mark's office")).BeforeFirst(GoTo(r"sally's office")).Exists(GoTo(r"start_loc")) -def answer_yes_con(trace: Trace, time: str, VERBOSE: bool = False) -> bool: - ask_mark = trace.ActAtFirst( - r"mark's office", Ask(contain_words([time]), r".*") - ) or trace.ActAtFirst(r"mark's office", Ask(r".*", contain_words([time]))) - - goto_sally_after_mark = trace.AfterFirst(GoTo(r"mark's office")).Exists( - GoTo(r"sally's office") - ) and not trace.AfterFirst(GoTo(r"mark's office")).BeforeFirst( - GoTo(r"sally's office") - ).Exists( - GoTo(r"start_loc") - ) - - say_time_sally = trace.AfterFirst(GoTo(r"mark's office")).ActAtFirst( - r"sally's office", Say(contain_words([time])) - ) + say_time_sally = trace.AfterFirst(GoTo(r"mark's office")).ActAtFirst(r"sally's office", Say(contain_words(time))) if VERBOSE: print_debug("ask_mark", ask_mark, [label_A, label_AL]) print_debug("goto_sally_after_mark", goto_sally_after_mark, [label_EO]) @@ -87,14 +55,11 @@ def answer_yes_con(trace: Trace, time: str, VERBOSE: bool = False) -> bool: return ask_mark and goto_sally_after_mark and say_time_sally - def say_sally_decision_con(trace: Trace, decision: str, VERBOSE: bool = False) -> bool: sally_decision = trace.ActAtFirst("mark's office", Say(contain_words([decision]))) - say_before_ask = ( - not trace.AfterFirst(GoTo("mark's office")) - .BeforeFirst(Say(contain_words([decision]))) - .Exists(Ask(r".*", r".*")) - ) + say_before_ask = not trace.AfterFirst(GoTo("mark's office")) \ + .BeforeFirst(Say(contain_words([decision]))) \ + .Exists(Ask(r".*", r".*")) if VERBOSE: print_debug("sally_decision", sally_decision, [label_S, label_AL]) @@ -102,74 +67,67 @@ def say_sally_decision_con(trace: Trace, decision: str, VERBOSE: bool = False) - return sally_decision and say_before_ask - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: # goes to only alice and bob's office - go_to_check = trace.Exists(GoTo(r"sally's office")) and trace.Exists( - GoTo(r"mark's office") - ) - - go_to_sally_first = not trace.BeforeFirst(GoTo(r"sally's office")).Exists( - GoTo(r"mark's office") - ) - - go_sally_to_mark = ( - not trace.AfterFirst(GoTo(r"sally's office")) - .BeforeFirst(GoTo(r"mark's office")) - .Exists(GoTo(r"start_loc")) - ) + go_to_check = trace.Exists(GoTo(r"sally's office")) and \ + trace.Exists(GoTo(r"mark's office")) + + go_to_sally_first = not trace.BeforeFirst(GoTo(r"sally's office")).Exists(GoTo(r"mark's office")) + + + go_sally_to_mark = not trace.AfterFirst(GoTo(r"sally's office")) \ + .BeforeFirst(GoTo(r"mark's office")).Exists(GoTo(r"start_loc")) ask_pattern = contain_words(["cinema|.*film|.*movie", "mark"]) - check_person_in_office = trace.ActAtFirst( - r"sally's office", Ask(ask_pattern, r".*") - ) + check_person_in_office = trace.ActAtFirst(r"sally's office", Ask(ask_pattern, r".*")) if VERBOSE: print_debug("go_to_check", go_to_check, [label_L]) print_debug("go_to_sally_first", go_to_sally_first, [label_IT]) print_debug("go_sally_to_mark", go_sally_to_mark, [label_EO]) - print_debug( - "check_person_in_office", check_person_in_office, [label_CE, label_AL] - ) - - return ( - go_to_check - and go_to_sally_first - and go_sally_to_mark - and check_person_in_office - ) - + print_debug("check_person_in_office", check_person_in_office, [label_CE, label_AL]) + + return go_to_check and go_to_sally_first and go_sally_to_mark and check_person_in_office def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # sally said yes and mark said 6pm trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - sally_yes = say_sally_decision_con(trace, "yes", VERBOSE) - mark_6pm = answer_yes_con(trace, "6pm", VERBOSE) + sally_yes = say_sally_decision_con(trace, ".*", VERBOSE) + mark_6pm = answer_yes_con(trace, ["6", "pm"], VERBOSE) return generic and sally_yes and mark_6pm - def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # sally said yes and mark said 5pm trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - sally_yes = say_sally_decision_con(trace, "yes", VERBOSE) - mark_5pm = answer_yes_con(trace, "5pm", VERBOSE) + sally_yes = say_sally_decision_con(trace, ".*", VERBOSE) + mark_5pm = answer_yes_con(trace, ["5", "pm"], VERBOSE) return generic and sally_yes and mark_5pm - def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: - # sally said no + # sally said no trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - sally_no = say_sally_decision_con(trace, "no", VERBOSE) and answer_no_con( - trace, VERBOSE - ) + sally_no = say_sally_decision_con(trace, ".*", VERBOSE) and answer_no_con(trace, VERBOSE) return generic and sally_no tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, + { + "state": state0, + "test":test0, + "timeout": False + }, + { + "state": state1, + "test":test1, + "timeout": False + }, + { + "state": state2, + "test":test2, + "timeout": False + } ] + diff --git a/benchmark/tasks/SayGoodDay.py b/benchmark/tasks/SayGoodDay.py index d2c94c0..d043c5c 100644 --- a/benchmark/tasks/SayGoodDay.py +++ b/benchmark/tasks/SayGoodDay.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,66 +12,36 @@ "Visit each lab and if someone is present, greet them with a pleasant Good Day!", "Go through all the labs, and if there's a person inside, say 'Good Day!' to them.", "Head to each lab and in case there's a person present, bid them a Good Day!", - "Visit every lab space and when encountering an individual, tell them a Good Day!", + "Visit every lab space and when encountering an individual, tell them a Good Day!" ] # construct state -state0 = ( - State() - .addLocation("sam's lab") - .addLocation("amy's lab") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "sam's lab", []) - .addAgent(".*", "amy's lab", []) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("sam's lab") - .addLocation("amy's lab") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "sam's lab", []) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("sam's lab") - .addLocation("amy's lab") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "amy's lab", []) - .addRobotLocation("start_loc") -) - -state3 = ( - State() - .addLocation("sam's lab") - .addLocation("amy's lab") - .addLocation("lobby") - .addLocation("conference room") - .addLocation("start_loc") - .addAgent(".*", "lobby", []) - .addAgent(".*", "conference room", []) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("sam's lab").addLocation("amy's lab") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "sam's lab", []).addAgent(".*", "amy's lab", []) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("sam's lab").addLocation("amy's lab") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "sam's lab", []) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("sam's lab").addLocation("amy's lab") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "amy's lab", []) \ + .addRobotLocation("start_loc") + +state3 = State().addLocation("sam's lab").addLocation("amy's lab") \ + .addLocation("lobby").addLocation("conference room").addLocation("start_loc") \ + .addAgent(".*", "lobby", []).addAgent(".*", "conference room", []) \ + .addRobotLocation("start_loc") # helper checks def say_con(trace: Trace, agent_name: str, VERBOSE: bool = False) -> bool: contained_words = ["good", "day"] pattern = contain_words(contained_words) say = trace.ActAtFirst(f"{agent_name}'s lab", Say(pattern)) - check_before_say = ( - trace.AfterFirst(GoTo(f"{agent_name}'s lab")) - .BeforeFirst(Say(pattern)) - .Exists(CheckEntity(r".*")) - ) + check_before_say = trace.AfterFirst(GoTo(f"{agent_name}'s lab")).BeforeFirst(Say(pattern)).Exists(CheckEntity(r".*")) if VERBOSE: print_debug("say", say, [label_S, label_AL]) @@ -80,20 +49,15 @@ def say_con(trace: Trace, agent_name: str, VERBOSE: bool = False) -> bool: return say and check_before_say - def not_say_con(trace: Trace, loc: str, VERBOSE: bool = False) -> bool: return not trace.ActAtFirst(loc, Say(r".*")) - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: go_to_lab = trace.Exists(GoTo(r"sam's lab")) and trace.Exists(GoTo(r"amy's lab")) - not_go_to_other = not trace.Exists(GoTo(r"lobby")) and not trace.Exists( - GoTo(r"conference") - ) - check_person_at_lab = trace.ActAtFirst( - r"sam's lab", CheckEntity(r".*") - ) and trace.ActAtFirst(r"amy's lab", CheckEntity(r".*")) - + not_go_to_other = not trace.Exists(GoTo(r"lobby")) and not trace.Exists(GoTo(r"conference")) + check_person_at_lab = trace.ActAtFirst(r"sam's lab", CheckEntity(r".*")) and \ + trace.ActAtFirst(r"amy's lab", CheckEntity(r".*")) + if VERBOSE: print_debug("go_to_lab", go_to_lab, [label_ES]) print_debug("not_go_to_other", not_go_to_other, [label_ES]) @@ -101,8 +65,7 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: return go_to_lab and not_go_to_other and check_person_at_lab - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_sam = say_con(trace, "sam", VERBOSE) @@ -110,8 +73,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_sam and say_amy - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) say_sam = say_con(trace, "sam", VERBOSE) @@ -119,8 +81,7 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_sam and not_say_amy - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) not_say_sam = not_say_con(trace, "sam's lab", VERBOSE) @@ -128,8 +89,7 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and not_say_sam and say_amy - -def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) not_say_sam = not_say_con(trace, "sam's lab", VERBOSE) @@ -137,10 +97,26 @@ def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and not_say_sam and not_say_amy - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, - {"state": state3, "test": test3, "timeout": False}, + { + "state" : state0, + "test" : test0, + "timeout": False + }, + { + "state" : state1, + "test" : test1, + "timeout": False + }, + { + "state" : state2, + "test" : test2, + "timeout": False + }, + { + "state" : state3, + "test" : test3, + "timeout": False + }, ] + diff --git a/benchmark/tasks/SetTemperature.py b/benchmark/tasks/SetTemperature.py index fd4bf08..5b17368 100644 --- a/benchmark/tasks/SetTemperature.py +++ b/benchmark/tasks/SetTemperature.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,45 +12,31 @@ "Ask Arjun in his office if he would like it to be warmer or colder. The thermostat is currently set to 72 degrees. Come back and tell me what temperature I should set the thermostat to based on what Arjun says.", "The thermostat is currently set to 72 degrees. Go ask if Arjun thinks his office should be colder or warmer. Come back and tell me what temperature in degrees I should change the thermostat to.", "Go to Arjun's office and ask him if he would like his office to be warmer or colder. The thermostat says the temperature in the office is currently 72 degrees. Come back and tell me what temperature I should reset it to based on Arjun's preferences.", - "The thermostat is set to 72 degrees. Go to Arjun's office and ask if he would like the temperature to be set to a warmer or colder value. Return and tell me what temperature in degrees I should set the thermostat to.", + "The thermostat is set to 72 degrees. Go to Arjun's office and ask if he would like the temperature to be set to a warmer or colder value. Return and tell me what temperature in degrees I should set the thermostat to." ] # construct state -state0 = ( - State() - .addLocation("arjun's office") - .addLocation("joydeep's office") - .addLocation("start_loc") - .addAgent(".*", "arjun's office", [r"warm"]) - .addAgent(".*", "joydeep's office", [r"cold"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("arjun's office") - .addLocation("joydeep's office") - .addLocation("start_loc") - .addAgent(".*", "arjun's office", [r"cold"]) - .addAgent(".*", "joydeep's office", [r"warm"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("arjun's office").addLocation("joydeep's office").addLocation("start_loc") \ + .addAgent(".*", "arjun's office", [r"warm"]).addAgent(".*", "joydeep's office", [r"cold"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("arjun's office").addLocation("joydeep's office").addLocation("start_loc") \ + .addAgent(".*", "arjun's office", [r"cold"]).addAgent(".*", "joydeep's office", [r"warm"]) \ + .addRobotLocation("start_loc") # helper checks def say_con(trace: Trace, status: str, VERBOSE: bool = False) -> bool: if status == "warm": # 73-99 degrees allowable - say_pattern = r"\b(?:[8][0-9]|7[3-9])\b" + say_pattern = r"\b(?:[8][0-9]|7[3-9])\b" elif status == "cold": # 40-71 degrees allowable - say_pattern = r"\b(?:[5-6][0-9]|7[01])\b" - + say_pattern = r"\b(?:[5-6][0-9]|7[01])\b" + exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - + go_back_to_start = trace.Precedes(GoTo(r"arjun's office"), GoTo("start_loc")) - say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Say(say_pattern) - ) + say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(say_pattern)) if VERBOSE: print_debug(f"go_back_to_start status {status}", go_back_to_start, [label_IT]) @@ -59,20 +44,17 @@ def say_con(trace: Trace, status: str, VERBOSE: bool = False) -> bool: return say and go_back_to_start - def ask_con(trace: Trace, status: str, VERBOSE: bool = False) -> bool: # ask at arjun's office contain_status = contain_words([status]) - ask_status = trace.ActAtFirst( - "arjun's office", Ask(contain_status, r".*") - ) or trace.ActAtFirst("arjun's office", Ask(r".*", contain_status)) - + ask_status = trace.ActAtFirst("arjun's office", Ask(contain_status, r".*")) or \ + trace.ActAtFirst("arjun's office", Ask(r".*", contain_status)) + if VERBOSE: print_debug("ask_status", ask_status, [label_A, label_AL]) - + return ask_status - def generic_con(trace, VERBOSE: bool = False) -> bool: # goes to arjun's office but not joydeep's office go_to_check = trace.Exists(GoTo(r"arjun's office")) @@ -84,8 +66,7 @@ def generic_con(trace, VERBOSE: bool = False) -> bool: return go_to_check and not_go_to_check - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # arjun says warmer trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -94,8 +75,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and ask and say - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # arjun says colder trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -104,8 +84,15 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and ask and say - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + } ] diff --git a/benchmark/tasks/StaplerDelivery.py b/benchmark/tasks/StaplerDelivery.py index 818e2a1..4f5c551 100644 --- a/benchmark/tasks/StaplerDelivery.py +++ b/benchmark/tasks/StaplerDelivery.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,54 +12,26 @@ "Go to every printer room and check if there is a stapler. For each visited room that does not have a stapler, deliver a stapler from the supply room to that room.", "Check if there is a stapler in every printer room. For each visited room without a stapler, deliver a stapler from the supply room to that room.", "Make sure there is a stapler in each printer room. Otherwise, bring a stapler from the supply room to each printer room that currently lacks one.", - "Check if every printer room has a stapler. If not, put a stapler from the supply room to every printer room without a stapler.", + "Check if every printer room has a stapler. If not, put a stapler from the supply room to every printer room without a stapler." ] # construct state -state0 = ( - State() - .addLocation("printer room 1") - .addLocation("printer room 2") - .addLocation("printer room 3") - .addLocation("supply room") - .addLocation("meeting room") - .addLocation("start_loc") - .addObject("stapler", "supply room") - .addObject("stapler", "supply room") - .addObject("stapler", "supply room") - .addObject("stapler", "printer room 1") - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("printer room 1") - .addLocation("printer room 2") - .addLocation("printer room 3") - .addLocation("supply room") - .addLocation("meeting room") - .addLocation("start_loc") - .addObject("stapler", "supply room") - .addObject("stapler", "supply room") - .addObject("stapler", "supply room") - .addObject("stapler", "printer room 2") - .addObject("stapler", "printer room 3") - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("printer room 1") - .addLocation("printer room 2") - .addLocation("printer room 3") - .addLocation("supply room") - .addLocation("meeting room") - .addLocation("start_loc") - .addObject("stapler", "supply room") - .addObject("stapler", "supply room") - .addObject("stapler", "supply room") - .addRobotLocation("start_loc") -) +state0 = State().addLocation("printer room 1").addLocation("printer room 2").addLocation("printer room 3").addLocation("supply room") \ + .addLocation("meeting room").addLocation("start_loc") \ + .addObject("stapler", "supply room").addObject("stapler", "supply room").addObject("stapler", "supply room") \ + .addObject("stapler", "printer room 1") \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("printer room 1").addLocation("printer room 2").addLocation("printer room 3").addLocation("supply room") \ + .addLocation("meeting room").addLocation("start_loc") \ + .addObject("stapler", "supply room").addObject("stapler", "supply room").addObject("stapler", "supply room") \ + .addObject("stapler", "printer room 2").addObject("stapler", "printer room 3") \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("printer room 1").addLocation("printer room 2").addLocation("printer room 3").addLocation("supply room") \ + .addLocation("meeting room").addLocation("start_loc") \ + .addObject("stapler", "supply room").addObject("stapler", "supply room").addObject("stapler", "supply room") \ + .addRobotLocation("start_loc") # helper checks def manipulation_con(trace: Trace, room_nums: List[int], VERBOSE: bool = False) -> bool: @@ -76,16 +47,10 @@ def manipulation_con(trace: Trace, room_nums: List[int], VERBOSE: bool = False) n_place = True for room_num in room_nums: new_trace = trace - place_at_printer = new_trace.ActAtFirst( - f"printer room {room_num}", Place("stapler") - ) - while new_trace.AfterFirst(GoTo(f"printer room {room_num}")).Exists( - GoTo(f"printer room {room_num}") - ): + place_at_printer = new_trace.ActAtFirst(f"printer room {room_num}", Place("stapler")) + while new_trace.AfterFirst(GoTo(f"printer room {room_num}")).Exists(GoTo(f"printer room {room_num}")): new_trace = new_trace.AfterFirst(GoTo(f"printer room {room_num}")) - place_at_printer = place_at_printer or new_trace.ActAtFirst( - f"printer room {room_num}", Place("stapler") - ) + place_at_printer = place_at_printer or new_trace.ActAtFirst(f"printer room {room_num}", Place("stapler")) n_place = place_at_printer and n_place @@ -94,30 +59,23 @@ def manipulation_con(trace: Trace, room_nums: List[int], VERBOSE: bool = False) if VERBOSE: print_debug("n_pick", n_pick, [label_M, label_AL]) print_debug("n_place", n_place, [label_M, label_AL]) - print_debug( - "not_pick_at_printer_room", not_pick_at_printer_room, [label_M, label_AL] - ) + print_debug("not_pick_at_printer_room", not_pick_at_printer_room, [label_M, label_AL]) return n_pick and n_place and not_pick_at_printer_room - def generic_con(trace, VERBOSE: bool = False) -> bool: # goes to all printer rooms but not any other room - go_to_check = ( - trace.Exists(GoTo(r"printer room 1")) - and trace.Exists(GoTo(r"printer room 2")) - and trace.Exists(GoTo(r"printer room 3")) - ) - + go_to_check = trace.Exists(GoTo(r"printer room 1")) and \ + trace.Exists(GoTo(r"printer room 2")) and \ + trace.Exists(GoTo(r"printer room 3")) + not_go_to_check = not trace.Exists(GoTo(r"meeting room")) # stapler is checked stapler_pattern = contain_words(["stapler"]) - check_room_stapler = ( - trace.ActAtFirst(r"printer room 1", CheckEntity(stapler_pattern)) - and trace.ActAtFirst(r"printer room 2", CheckEntity(stapler_pattern)) - and trace.ActAtFirst(r"printer room 3", CheckEntity(stapler_pattern)) - ) + check_room_stapler = trace.ActAtFirst(r"printer room 1", CheckEntity(stapler_pattern)) and \ + trace.ActAtFirst(r"printer room 2", CheckEntity(stapler_pattern)) and \ + trace.ActAtFirst(r"printer room 3", CheckEntity(stapler_pattern)) if VERBOSE: print_debug("go_to_check", go_to_check, [label_ES]) @@ -126,34 +84,29 @@ def generic_con(trace, VERBOSE: bool = False) -> bool: return go_to_check and not_go_to_check and check_room_stapler - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: """ - stapler in printer room 1. + stapler in printer room 1. """ trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - manipulation = manipulation_con(trace, [2, 3], VERBOSE) + manipulation = manipulation_con(trace, [2,3], VERBOSE) return generic and manipulation - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: """ - stapler in printer room 1. + stapler in printer room 1. """ trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - manipulation = manipulation_con( - trace, [2, 3], VERBOSE - ) # no need to check not place at 1 because only 2 picks - + manipulation = manipulation_con(trace, [2,3], VERBOSE) # no need to check not place at 1 because only 2 picks + return generic and manipulation - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: """ - stapler in printer room 1. + stapler in printer room 1. """ trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) @@ -161,20 +114,30 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and manipulation - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: """ - stapler in printer room 1. + stapler in printer room 1. """ trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - manipulation = manipulation_con(trace, [1, 2, 3], VERBOSE) + manipulation = manipulation_con(trace, [1,2,3], VERBOSE) return generic and manipulation - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, -] + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + }, + { + "state": state2, + "test": test2, + "timeout": False + } +] \ No newline at end of file diff --git a/benchmark/tasks/StaplerSupply.py b/benchmark/tasks/StaplerSupply.py index 178336a..e45b41c 100644 --- a/benchmark/tasks/StaplerSupply.py +++ b/benchmark/tasks/StaplerSupply.py @@ -1,6 +1,5 @@ import sys - -sys.path.insert(0, "../..") +sys.path.insert(0, '../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,92 +12,59 @@ "Go to every printer room and check to see if there is a stapler. Come back and tell me which printer rooms do not have a stapler.", "Go find all printer rooms that do not have a stapler. Come back and tell me.", "Check all printer rooms for staplers, and come back and tell me which ones do not have any staplers.", - "Tell me the name of every printer room that does not have a stapler.", + "Tell me the name of every printer room that does not have a stapler." ] # construct state -state0 = ( - State() - .addLocation("printer room 1") - .addLocation("printer room 2") - .addLocation("printer room 3") - .addLocation("meeting room") - .addLocation("start_loc") - .addObject("stapler", "printer room 1") - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("printer room 1") - .addLocation("printer room 2") - .addLocation("printer room 3") - .addLocation("meeting room") - .addLocation("start_loc") - .addObject("stapler", "meeting room") - .addObject("stapler", "printer room 2") - .addObject("stapler", "printer room 3") - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("printer room 1") - .addLocation("printer room 2") - .addLocation("printer room 3") - .addLocation("meeting room") - .addLocation("start_loc") - .addObject("stapler", "meeting room") - .addRobotLocation("start_loc") -) +state0 = State().addLocation("printer room 1").addLocation("printer room 2").addLocation("printer room 3") \ + .addLocation("meeting room").addLocation("start_loc") \ + .addObject("stapler", "printer room 1") \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("printer room 1").addLocation("printer room 2").addLocation("printer room 3") \ + .addLocation("meeting room").addLocation("start_loc") \ + .addObject("stapler", "meeting room").addObject("stapler", "printer room 2").addObject("stapler", "printer room 3") \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("printer room 1").addLocation("printer room 2").addLocation("printer room 3") \ + .addLocation("meeting room").addLocation("start_loc") \ + .addObject("stapler", "meeting room") \ + .addRobotLocation("start_loc") # helper checks def say_con(trace: Trace, room_num: Union[int, str], VERBOSE: bool = False) -> bool: - # say printer room room_num does not have a stapler. + #say printer room room_num does not have a stapler. contained_say = [str(room_num), "not|.*no|.*don't|.*doesn't"] - + say_pattern = contain_words(contained_say) - goto_before_say = ( - trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"printer room 1")) - and trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"printer room 2")) - and trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"printer room 3")) - ) + goto_before_say = trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"printer room 1")) and \ + trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"printer room 2")) and \ + trace.BeforeFirst(Say(say_pattern)).Exists(GoTo(r"printer room 3")) exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - - say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Say(say_pattern) - ) + + say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(say_pattern)) if VERBOSE: - print_debug( - f"say_constraint room num {room_num}", say, [label_S, label_AL, label_IT] - ) - print_debug( - f"goto1_before_say room num {room_num}", goto_before_say, [label_EO] - ) + print_debug(f"say_constraint room num {room_num}", say, [label_S, label_AL, label_IT]) + print_debug(f"goto1_before_say room num {room_num}", goto_before_say, [label_EO]) return goto_before_say and say - def generic_con(trace, VERBOSE: bool = False) -> bool: # goes to all printer rooms but not any other room - go_to_check = ( - trace.Exists(GoTo(r"printer room 1")) - and trace.Exists(GoTo(r"printer room 2")) - and trace.Exists(GoTo(r"printer room 3")) - ) - + go_to_check = trace.Exists(GoTo(r"printer room 1")) and \ + trace.Exists(GoTo(r"printer room 2")) and \ + trace.Exists(GoTo(r"printer room 3")) + not_go_to_check = not trace.Exists(GoTo(r"meeting room")) # stapler is checked stapler_pattern = contain_words(["stapler"]) - check_room_stapler = ( - trace.ActAtFirst(r"printer room 1", CheckEntity(stapler_pattern)) - and trace.ActAtFirst(r"printer room 2", CheckEntity(stapler_pattern)) - and trace.ActAtFirst(r"printer room 3", CheckEntity(stapler_pattern)) - ) + check_room_stapler = trace.ActAtFirst(r"printer room 1", CheckEntity(stapler_pattern)) and \ + trace.ActAtFirst(r"printer room 2", CheckEntity(stapler_pattern)) and \ + trace.ActAtFirst(r"printer room 3", CheckEntity(stapler_pattern)) if VERBOSE: print_debug("go_to_check", go_to_check, [label_ES]) @@ -108,9 +74,9 @@ def generic_con(trace, VERBOSE: bool = False) -> bool: return go_to_check and not_go_to_check and check_room_stapler -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: """ - stapler in printer room 1. + stapler in printer room 1. Say printer rooms 2,3 don't have stapler. Don't say printer room 1 has stapler. """ @@ -122,10 +88,9 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and not_say_1 and say_2 and say_3 - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: """ - stapler in printer room 2,3. + stapler in printer room 2,3. Say printer rooms 1 don't have stapler. Don't say printer room 2,3 has stapler. """ @@ -137,10 +102,9 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_1 and not_say_2 and not_say_3 - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: """ - stapler in printer room 2,3. + stapler in printer room 2,3. Say printer rooms 1,2,3 don't have stapler. Don't say printer room 0 has stapler. """ @@ -152,9 +116,21 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return generic and say_1 and say_2 and say_3 - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + }, + { + "state": state2, + "test": test2, + "timeout": False + } ] + diff --git a/benchmark/tasks/WeatherPoll.py b/benchmark/tasks/WeatherPoll.py index 97abb2d..514f464 100644 --- a/benchmark/tasks/WeatherPoll.py +++ b/benchmark/tasks/WeatherPoll.py @@ -1,6 +1,5 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State from misc.benchmark_utils import * @@ -13,85 +12,45 @@ "Go to the main entrance. When someone shows up, ask them if they feel that it's hot out. Do this until you collect ten people's responses. Come back and tell me which percent of people think it's hot out.", "Go wait for someone at the main entrance. Ask them if they feel it is hot out, then wait for the next person and ask the same question. Do this until you have ten responses, then come back and report the percentage of people who think it is hot out.", "Go to the main entrance. If there is no one there, wait for someone. Ask them if they feel it is hot out. Ask 10 people this same question until you have 10 replies. Finally, come back and tell me the percentage of people that think it's hot outside.", - "Go to the main entrance, and if there is no one there, wait for someone to show up. Ask them if they feel it is hot out. Wait for the next person and ask the same question again. Do this 10 times. Come back and report the percentage of people who think it's hot out.", + "Go to the main entrance, and if there is no one there, wait for someone to show up. Ask them if they feel it is hot out. Wait for the next person and ask the same question again. Do this 10 times. Come back and report the percentage of people who think it's hot out." ] # construct state -state0 = ( - State() - .addLocation("main entrance") - .addLocation("main conference room") - .addLocation("start_loc") - .addAgent(".*", "main entrance", ["yes"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("main entrance") - .addLocation("main conference room") - .addLocation("start_loc") - .addAgent(".*", "main entrance", ["no"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("main entrance") - .addLocation("main conference room") - .addLocation("start_loc") - .addAgent( - ".*", - "main entrance", - ["yes", "no", "yes", "no", "yes", "yes", "no", "yes", "no", "yes"], - ) - .addRobotLocation("start_loc") -) - -state3 = ( - State() - .addLocation("main entrance") - .addLocation("main conference room") - .addLocation("start_loc") - .addAgent( - ".*", - "main entrance", - ["no", "yes", "yes", "no", "yes", "no", "no", "yes", "no", "no"], - ) - .addRobotLocation("start_loc") -) - -state4 = ( - State() - .addLocation("main entrance") - .addLocation("main conference room") - .addLocation("start_loc") - .addRobotLocation("start_loc") -) +state0 = State().addLocation("main entrance").addLocation("main conference room").addLocation("start_loc") \ + .addAgent(".*", "main entrance", ["yes"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("main entrance").addLocation("main conference room").addLocation("start_loc") \ + .addAgent(".*", "main entrance", ["no"]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("main entrance").addLocation("main conference room").addLocation("start_loc") \ + .addAgent(".*", "main entrance", ["yes", "no", "yes", "no", "yes", "yes", "no", "yes", "no", "yes"]) \ + .addRobotLocation("start_loc") + +state3 = State().addLocation("main entrance").addLocation("main conference room").addLocation("start_loc") \ + .addAgent(".*", "main entrance", ["no", "yes", "yes", "no", "yes", "no", "no", "yes", "no", "no"]) \ + .addRobotLocation("start_loc") + +state4 = State().addLocation("main entrance").addLocation("main conference room").addLocation("start_loc") \ + .addRobotLocation("start_loc") # helper checks def say_con(trace: Trace, percentage: str, VERBOSE: bool = False) -> bool: say_pattern = contain_words([percentage]) exclude_start_loc = contain_words_and_exlude_words([], ["start_loc"]) - say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst( - "start_loc", Say(say_pattern) - ) + say = trace.AfterFirst(GoTo(exclude_start_loc)).ActAtFirst("start_loc", Say(say_pattern)) if VERBOSE: - print_debug( - f"say_constraint percentage {percentage}", - say, - [label_S, label_IT, label_AL], - ) + print_debug(f"say_constraint percentage {percentage}", say, [label_S, label_IT, label_AL]) return say - def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: # goes to only entrance and not conference room - go_to_check = trace.Exists(GoTo(r"entrance")) - + go_to_check = trace.Exists(GoTo(r"entrance")) + not_go_to_check = not trace.Exists(GoTo(r"conference")) # exist 10 checks for person and asks for person @@ -100,9 +59,7 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: check_entity_10_times = True ask_10_times = True for _ in range(10): - check_entity_10_times = check_entity_10_times and new_trace_check.Exists( - CheckEntity(r".*") - ) + check_entity_10_times = check_entity_10_times and new_trace_check.Exists(CheckEntity(r".*")) new_trace_check = new_trace_check.AfterFirst(CheckEntity(r".*")) ask_10_times = ask_10_times and new_trace_ask.Exists(Ask(r".*", r".*")) @@ -117,106 +74,102 @@ def generic_con(trace: Trace, VERBOSE: bool = False) -> bool: for _ in range(10): - between_trace = new_trace_ask.BeforeFirst(Ask(r".*", r".*")).AfterLast( - CheckEntity(r".*") - ) + between_trace = new_trace_ask.BeforeFirst(Ask(r".*", r".*")).AfterLast(CheckEntity(r".*")) ask_exist = new_trace_ask.Exists(Ask(r".*", r".*")) - check_exist_before_ask = new_trace_ask.BeforeFirst(Ask(r".*", r".*")).Exists( - CheckEntity(r".*") - ) - check_ask_consecutive = ( - not between_trace.Exists(GoTo(goto_all_but_entrance)) - and not between_trace.Exists(Say(r".*")) - and not between_trace.Exists(Pick(r".*")) - and not between_trace.Exists(Place(r".*")) - ) - - ask_after_check = ( - ask_after_check - and ask_exist - and check_exist_before_ask - and check_ask_consecutive - ) - + check_exist_before_ask = new_trace_ask.BeforeFirst(Ask(r".*", r".*")).Exists(CheckEntity(r".*")) + check_ask_consecutive = not between_trace.Exists(GoTo(goto_all_but_entrance)) and \ + not between_trace.Exists(Say(r".*")) and \ + not between_trace.Exists(Pick(r".*")) and \ + not between_trace.Exists(Place(r".*")) + + ask_after_check = ask_after_check and \ + ask_exist and \ + check_exist_before_ask and \ + check_ask_consecutive + new_trace_ask = trace.AfterFirst(Ask(r".*", r".*")) - + if VERBOSE: print_debug(f"go_to_check", go_to_check, [label_L]) print_debug(f"not_go_to_check", not_go_to_check, [label_L]) print_debug(f"check_entity_10_times", check_entity_10_times, [label_ES]) print_debug(f"ask_10_times", ask_10_times, [label_A, label_ES, label_AL]) print_debug(f"ask_after_check", ask_after_check, [label_EO]) + + return go_to_check and not_go_to_check and check_entity_10_times and ask_10_times and ask_after_check - return ( - go_to_check - and not_go_to_check - and check_entity_10_times - and ask_10_times - and ask_after_check - ) - - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # all say hot trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - say = say_con(trace, r"100|.*hundred|.*all", VERBOSE=VERBOSE) or say_con( - trace, r" 10", VERBOSE=VERBOSE - ) - + say = say_con(trace, r"100|.*hundred|.*all", VERBOSE=VERBOSE) or \ + say_con(trace, r" 10", VERBOSE=VERBOSE) + return generic and say - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # none says hot trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - say = say_con(trace, r"0|.*zero|.*no", VERBOSE=VERBOSE) + say = say_con(trace, r"0|.*zero|.*no", VERBOSE=VERBOSE) return generic and say - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # 60% trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - say = say_con(trace, r"60|.*sixty|.*6", VERBOSE=VERBOSE) or say_con( - trace, r" 6", VERBOSE=VERBOSE - ) + say = say_con(trace, r"60|.*sixty|.*6", VERBOSE=VERBOSE) or \ + say_con(trace, r" 6", VERBOSE=VERBOSE) return generic and say - -def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test3(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # 40% trace = Trace(trace_elements) generic = generic_con(trace, VERBOSE) - say = say_con(trace, r"40|.*forty|.*fourty|\b4\b", VERBOSE=VERBOSE) or say_con( - trace, r" 4", VERBOSE=VERBOSE - ) + say = say_con(trace, r"40|.*forty|.*fourty|\b4\b", VERBOSE=VERBOSE) or \ + say_con(trace, r" 4", VERBOSE=VERBOSE) return generic and say - -def test4(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test4(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # no person exists so it should timeout trace = Trace(trace_elements) - generic = ( - trace.Exists(GoTo(r"entrance")) - and not trace.Exists(GoTo(r"conference")) - and trace.Exists(CheckEntity(r".*")) - and not trace.Exists(Ask(r".*", r".*")) - and not trace.Exists(Say(r".*")) - ) + generic = trace.Exists(GoTo(r"entrance")) and \ + not trace.Exists(GoTo(r"conference")) and \ + trace.Exists(CheckEntity(r".*")) and \ + not trace.Exists(Ask(r".*", r".*")) and \ + not trace.Exists(Say(r".*")) return generic tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, - {"state": state3, "test": test3, "timeout": False}, - {"state": state4, "test": test4, "timeout": True}, + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + }, + { + "state": state2, + "test": test2, + "timeout": False + }, + { + "state": state3, + "test": test3, + "timeout": False + }, + { + "state": state4, + "test": test4, + "timeout": True + } ] diff --git a/benchmark/tasks/open_world_knowledge/CountSavoryAblation.py b/benchmark/tasks/open_world_knowledge/CountSavoryAblation.py index 4eac693..7634126 100644 --- a/benchmark/tasks/open_world_knowledge/CountSavoryAblation.py +++ b/benchmark/tasks/open_world_knowledge/CountSavoryAblation.py @@ -1,13 +1,8 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State -from misc.benchmark_utils import ( - contain_words, - contain_words_and_exlude_words, - print_debug, -) +from misc.benchmark_utils import contain_words, contain_words_and_exlude_words, print_debug from typing import List name = "CountSavory" @@ -17,74 +12,39 @@ "Visit all offices. If anyone is present; ask them to choose from the options of cupcake, ham sandwich, donut, or beef jerky. Let me know how many people selected a savory option when you return.", "Go through each office; if someone is there, ask about their preference among cupcake, donut, beef jerky, or ham sandwich. Report the number of individuals who opted for a savory item after returning.", "Go visit each office. If there is a person in the office, inquire about their liking for cupcake, ham sandwich, beef jerky, or donut. Come back and tell me of the count of people who went for a savory option.", - "Go to every office, and if there is someone there, ask them whether they'd like a beef jerky, cupcake, ham sandwich, or donut. Come back and tell me how many people preferred a savory option.", + "Go to every office, and if there is someone there, ask them whether they'd like a beef jerky, cupcake, ham sandwich, or donut. Come back and tell me how many people preferred a savory option." ] # construct state -state0 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "alice's office", [r"donut"]) - .addAgent(".*", "bob's office", [r"cake"]) - .addAgent(".*", "charlie's office", [r"donut"]) - .addAgent(".*", "david's office", [r"cake"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "alice's office", [r"sandwich"]) - .addAgent(".*", "bob's office", [r"donut"]) - .addAgent(".*", "charlie's office", [r"cake"]) - .addAgent(".*", "david's office", [r"beef|jerky"]) - .addRobotLocation("start_loc") -) - -state2 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "alice's office", [r"beef|jerky"]) - .addAgent(".*", "bob's office", [r"cake"]) - .addAgent(".*", "charlie's office", [r"cake"]) - .addRobotLocation("start_loc") -) - -state3 = ( - State() - .addLocation("alice's office") - .addLocation("bob's office") - .addLocation("charlie's office") - .addLocation("david's office") - .addLocation("lobby") - .addLocation("cafeteria") - .addLocation("start_loc") - .addAgent(".*", "bob's office", [r"sandwich"]) - .addAgent(".*", "charlie's office", [r"beef|jerky"]) - .addAgent(".*", "david's office", [r"sandwich"]) - .addRobotLocation("start_loc") -) - - -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +state0 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "alice's office", [r"donut"]).addAgent(".*", "bob's office", [r"cake"]) \ + .addAgent(".*", "charlie's office", [r"donut"]).addAgent(".*", "david's office", [r"cake"]) \ + .addRobotLocation("start_loc") + +state1 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "alice's office", [r"sandwich"]).addAgent(".*", "bob's office", [r"donut"]) \ + .addAgent(".*", "charlie's office", [r"cake"]).addAgent(".*", "david's office", [r"beef|jerky"]) \ + .addRobotLocation("start_loc") + +state2 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "alice's office", [r"beef|jerky"]).addAgent(".*", "bob's office", [r"cake"]) \ + .addAgent(".*", "charlie's office", [r"cake"]) \ + .addRobotLocation("start_loc") + +state3 = State().addLocation("alice's office").addLocation("bob's office") \ + .addLocation("charlie's office").addLocation("david's office") \ + .addLocation("lobby").addLocation("cafeteria").addLocation("start_loc") \ + .addAgent(".*", "bob's office", [r"sandwich"]).addAgent(".*", "charlie's office", [r"beef|jerky"]) \ + .addAgent(".*", "david's office", [r"sandwich"]) \ + .addRobotLocation("start_loc") + +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 0 trace = Trace(trace_elements) say_pattern = contain_words(["0|.*zero|.*no"]) @@ -95,8 +55,7 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return say - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 2 trace = Trace(trace_elements) say_pattern = contain_words(["2|.*two"]) @@ -104,11 +63,10 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: if VERBOSE: print_debug("say", say) - + return say - -def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 1 trace = Trace(trace_elements) say_pattern = contain_words(["1|.*one"]) @@ -116,11 +74,10 @@ def test2(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: if VERBOSE: print_debug("say", say) - + return say - -def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: # count: 3 trace = Trace(trace_elements) say_pattern = contain_words(["3|.*three"]) @@ -128,13 +85,29 @@ def test3(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: if VERBOSE: print_debug("say", say) - + return say - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, - {"state": state2, "test": test2, "timeout": False}, - {"state": state3, "test": test3, "timeout": False}, + { + "state" : state0, + "test" : test0, + "timeout": False + }, + { + "state" : state1, + "test" : test1, + "timeout": False + }, + { + "state" : state2, + "test" : test2, + "timeout": False + }, + { + "state" : state3, + "test" : test3, + "timeout": False + } ] + diff --git a/benchmark/tasks/open_world_knowledge/GrilledCheeseAblation.py b/benchmark/tasks/open_world_knowledge/GrilledCheeseAblation.py index c4e51de..537c99f 100644 --- a/benchmark/tasks/open_world_knowledge/GrilledCheeseAblation.py +++ b/benchmark/tasks/open_world_knowledge/GrilledCheeseAblation.py @@ -1,13 +1,8 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State -from misc.benchmark_utils import ( - contain_words_and_exlude_words, - contain_words, - print_debug, -) +from misc.benchmark_utils import contain_words_and_exlude_words, contain_words, print_debug from typing import List name = "GrilledCheese" @@ -17,33 +12,29 @@ "Create a list of ingredients needed to make grilled cheese. Visit Zarko's office and inquire which of them he possesses. Return and inform me of the items he does not have.", "Put together a compilation of grilled cheese ingredients. Head to Zarko's office, inquire about his available ingredients, and then update me on what he does not have.", "Compile the necessary ingredients for grilled cheese. Go to Zarko's office, ask him about his available items, and then report back to me which items he does not have.", - "Put together a list of grilled cheese ingredients. Head to Zarko's office and inquire about his available ingredients. Return and inform me of what he is missing.", + "Put together a list of grilled cheese ingredients. Head to Zarko's office and inquire about his available ingredients. Return and inform me of what he is missing." ] # construct state -state0 = ( - State() - .addLocation("lobby") - .addLocation("zarko's office") - .addLocation("start_loc") - .addAgent(".*", "zarko's office", [r".*"]) - .addRobotLocation("start_loc") -) - +state0 = State().addLocation("lobby").addLocation("zarko's office").addLocation("start_loc") \ + .addAgent(".*", "zarko's office", [r".*"]) \ + .addRobotLocation("start_loc") -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: trace = Trace(trace_elements) - + contain_cheese = contain_words(["cheese"]) contain_bread = contain_words(["bread"]) - ask_cheese = trace.Exists(Ask(r".*", contain_cheese)) or trace.Exists( - Ask(contain_cheese, r".*") - ) - ask_bread = trace.Exists(Ask(r".*", contain_bread)) or trace.Exists( - Ask(contain_bread, r".*") - ) + ask_cheese = trace.Exists(Ask(r".*", contain_cheese)) or trace.Exists(Ask(contain_cheese, r".*")) + ask_bread = trace.Exists(Ask(r".*", contain_bread)) or trace.Exists(Ask(contain_bread, r".*")) return ask_cheese and ask_bread +tests = [ + { + "state" : state0, + "test" : test0, + "timeout": False + } +] -tests = [{"state": state0, "test": test0, "timeout": False}] diff --git a/benchmark/tasks/open_world_knowledge/LunchTimeAblation.py b/benchmark/tasks/open_world_knowledge/LunchTimeAblation.py index 8052562..74f5c05 100644 --- a/benchmark/tasks/open_world_knowledge/LunchTimeAblation.py +++ b/benchmark/tasks/open_world_knowledge/LunchTimeAblation.py @@ -1,13 +1,8 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State -from misc.benchmark_utils import ( - contain_words, - contain_words_and_exlude_words, - print_debug, -) +from misc.benchmark_utils import contain_words, contain_words_and_exlude_words, print_debug from typing import List name = "LunchTime" @@ -17,45 +12,29 @@ "Go to Jill's office and ask her whether she's free to go for lunch tomorrow. If yes, ask her when (give her some reasonable times), and come back and tell me what she said.", "Visit Jill's office and ask her if she would like to go for lunch tomorrow. If yes, ask her when (offer some reasonable lunch time options). Let me know what she said.", "Ask Jill in her office whether she will be free to go for lunch tomorrow. If yes, offer her some reasonable time options to choose from, and come back and tell me what she said.", - "Ask Jill in her office if she want to go for lunch tomorrow. If yes, give her some reasonable time options and ask her to choose a time. Finally come back and tell me what she said.", + "Ask Jill in her office if she want to go for lunch tomorrow. If yes, give her some reasonable time options and ask her to choose a time. Finally come back and tell me what she said." ] # construct state -state0 = ( - State() - .addLocation("aiden's office") - .addLocation("andrew's office") - .addLocation("start_loc") - .addAgent(".*", "aiden's office", [r"yes", r".*"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("aiden's office") - .addLocation("andrew's office") - .addLocation("start_loc") - .addAgent(".*", "aiden's office", [r"no", r".*"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("aiden's office").addLocation("andrew's office").addLocation("start_loc") \ + .addAgent(".*", "aiden's office", [r"yes", r".*"]) \ + .addRobotLocation("start_loc") +state1 = State().addLocation("aiden's office").addLocation("andrew's office").addLocation("start_loc") \ + .addAgent(".*", "aiden's office", [r"no", r".*"]) \ + .addRobotLocation("start_loc") -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # aiden says yes to lunch trace = Trace(trace_elements) ask_time_pattern = contain_words(["11|.*eleven|.*12|.*twelve"]) - not_contain = [f"{i}:" for i in range(17, 25)] + [f"{i}:" for i in range(4, 9)] + not_contain = [f"{i}:" for i in range(17,25)] + [f"{i}:" for i in range(4,9)] not_contain = ["|.*".join(not_contain)] ask_not_contain_time_pattern = contain_words(not_contain) - ask = trace.Exists(Ask(r".*", ask_time_pattern)) or trace.Exists( - Ask(ask_time_pattern, r".*") - ) - not_ask = not ( - trace.Exists(Ask(r".*", ask_not_contain_time_pattern)) - or trace.Exists(Ask(ask_not_contain_time_pattern, r".*")) - ) + ask = trace.Exists(Ask(r".*", ask_time_pattern)) or trace.Exists(Ask(ask_time_pattern, r".*")) + not_ask = not(trace.Exists(Ask(r".*", ask_not_contain_time_pattern)) or trace.Exists(Ask(ask_not_contain_time_pattern, r".*"))) if VERBOSE: print_debug("ask_time_pattern", ask_time_pattern) @@ -64,13 +43,19 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return ask and not_ask - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # aiden says no to lunch return True - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, -] + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + } +] \ No newline at end of file diff --git a/benchmark/tasks/open_world_knowledge/SetTemperatureAblation.py b/benchmark/tasks/open_world_knowledge/SetTemperatureAblation.py index 6543465..7d84f7e 100644 --- a/benchmark/tasks/open_world_knowledge/SetTemperatureAblation.py +++ b/benchmark/tasks/open_world_knowledge/SetTemperatureAblation.py @@ -1,13 +1,8 @@ import sys - -sys.path.append("../..") +sys.path.append('../..') from benchmark.rtl import * from benchmark.simulator import State -from misc.benchmark_utils import ( - contain_words, - contain_words_and_exlude_words, - print_debug, -) +from misc.benchmark_utils import contain_words, contain_words_and_exlude_words, print_debug from typing import List name = "SetTemperature" @@ -17,36 +12,23 @@ "Ask Arjun in his office if he would like it to be warmer or colder. The thermostat is currently set to 72 degrees. Come back and tell me what temperature I should set the thermostat to based on what Arjun says.", "The thermostat is currently set to 72 degrees. Go ask if Arjun thinks his office should be colder or warmer. Come back and tell me what temperature in degrees I should change the thermostat to.", "Go to Arjun's office and ask him if he would like his office to be warmer or colder. The thermostat says the temperature in the office is currently 72 degrees. Come back and tell me what temperature I should reset it to based on Arjun's preferences.", - "The thermostat is set to 72 degrees. Go to Arjun's office and ask if he would like the temperature to be set to a warmer or colder value. Return and tell me what temperature in degrees I should set the thermostat to.", + "The thermostat is set to 72 degrees. Go to Arjun's office and ask if he would like the temperature to be set to a warmer or colder value. Return and tell me what temperature in degrees I should set the thermostat to." ] # construct state -state0 = ( - State() - .addLocation("arjun's office") - .addLocation("joydeep's office") - .addLocation("start_loc") - .addAgent(".*", "arjun's office", [r"warm"]) - .addAgent(".*", "joydeep's office", [r"cold"]) - .addRobotLocation("start_loc") -) - -state1 = ( - State() - .addLocation("arjun's office") - .addLocation("joydeep's office") - .addLocation("start_loc") - .addAgent(".*", "arjun's office", [r"cold"]) - .addAgent(".*", "joydeep's office", [r"warm"]) - .addRobotLocation("start_loc") -) +state0 = State().addLocation("arjun's office").addLocation("joydeep's office").addLocation("start_loc") \ + .addAgent(".*", "arjun's office", [r"warm"]).addAgent(".*", "joydeep's office", [r"cold"]) \ + .addRobotLocation("start_loc") +state1 = State().addLocation("arjun's office").addLocation("joydeep's office").addLocation("start_loc") \ + .addAgent(".*", "arjun's office", [r"cold"]).addAgent(".*", "joydeep's office", [r"warm"]) \ + .addRobotLocation("start_loc") -def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test0(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # arjun says warmer trace = Trace(trace_elements) - say_pattern = r"\b(?:[8][0-9]|7[3-9])\b" + say_pattern = r"\b(?:[8][0-9]|7[3-9])\b" say = trace.Exists(Say(say_pattern)) if VERBOSE: @@ -54,12 +36,11 @@ def test0(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return say - -def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: +def test1(trace_elements : List[TraceElement], VERBOSE: bool = False) -> bool: # arjun says colder trace = Trace(trace_elements) - say_pattern = r"\b(?:[5-6][0-9]|7[01])\b" + say_pattern = r"\b(?:[5-6][0-9]|7[01])\b" say = trace.Exists(Say(say_pattern)) if VERBOSE: @@ -67,8 +48,15 @@ def test1(trace_elements: List[TraceElement], VERBOSE: bool = False) -> bool: return say - tests = [ - {"state": state0, "test": test0, "timeout": False}, - {"state": state1, "test": test1, "timeout": False}, + { + "state": state0, + "test": test0, + "timeout": False + }, + { + "state": state1, + "test": test1, + "timeout": False + } ]