Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
SYSTEM AND METHOD FOR COLLECTING AND PROCESSING DATA AND FOR UTILIZING ROBOTIC AND/OR HUMAN RESOURCES
Document Type and Number:
WIPO Patent Application WO/2014/138472
Kind Code:
A2
Abstract:
A roaming sensor system is described herein. The system can have one or more robots. The system can collect and process data efficiently and utilize robotic and/or human resources effectively by scheduling priorities of robot and/ or human tasks, allocating the use of robot and/ or human resources, and optimizing robot and/or human routes across the infrastructure of an organization.

Inventors:
GETTINGS ADAM M (US)
STEVENS ANDREW G (US)
Application Number:
PCT/US2014/021391
Publication Date:
September 12, 2014
Filing Date:
March 06, 2014
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
ROBOTEX INC (US)
International Classes:
G06F19/00; G06Q10/06
Foreign References:
US20080109114A12008-05-08
US20100242041A12010-09-23
US20110153079A12011-06-23
US20070168082A12007-07-19
Attorney, Agent or Firm:
LEVINE, David A. et al. (2400 Geng Road Suite 12, Palo Alto California, US)
Download PDF:
Claims:
CLAIMS We claim:

1. A robot system comprising:

a memory configured to stor a database having a task list having a first task and a second task, and priority score list having a first priority scare for fee first task and a second priority score for the second task;

a first robot comprising a mobility element configured to move the first robot; one or a set of processors configured to instruct the first robot to perform a first task: and

wherein at least one of the processors are configured to compare fee first priority score to the second priority score, and wherein the system is configured so that when the first priority score is lower ranked than the second priority score, the robot stops fee first task and starts the second task. 2. The system of claim 1, wherein the first robot comprises a sensor, and wherein the sensor is configured to detect a signal in the environment of the first robot, and wherein when fee sensor detects the signal then the robot transmits at least one of the signal or data representing the signal to at least one of the processors, and wherein the at least one processor is configured to trigger an instruction for the robot system to perfomi the second task. 3. The system of claim 1, wherein the one or the set of processors comprises a priority engine. 4. The system of claim 3, wherein the priority engine process comprises an interrupt request register configured to receive an instruction for the system to execute a task. 5. The system of claim 3, wherein the priority engine comprises a priority resolver configured to rank tasks at least in part according to the priority scores of the tasks, 6. The system of claim 3, wherein the priority engine comprises an in-service register configured to track tasks currently executed by the system.

7. The system of claim 3, wherein the priority engine comprises an interrupt mask register configured to store a queue of tasks awaiting execution by the system. 8. The system of claim 1 , further comprising a server ih communication wit the first robot wherein the server comprises at. least one of the processors. 9. The system of claim 1, further comprising a second robot in coniimmicafion with the server, wherein the server is configured to instruct the second robot to perform tasks, 10. A method for controlling a robot system comprising a first robot, the method comprising:

mobilizing the first robot from a first location to a second location;

assigning a first priority score to a first task;

assigning a second priority score to a second task;

controlling the robot to perform the first task:

comparing the first priority' score to the second priority score, wherein the comparing is after the controlling the robot to perform the first task; and

wherein when the comparing comprises determining the first priority score is lower ranked than the second priority score, the method further comprises controlling the robot to stop the first task and start the second task after the deterinining. 11. The method of claim 10, wherein the controlling the robot to perform the first task, comprises controlling with a processor. 12. The method of claim 11 , wherein the comparing comprises comparing with the processor. 13. The method of claim 12, wherein when the controlling the robot to sto the first task and start the second task comprises controlling with the processor, and wher ein the system further comprises a server that comprises the processor. 14. The method of claim 10, further comprising:

detectin a signal in the environment of the first robot;

IS transmittnig at least one of the signal or data representing the signal to one or a set of processors; and

triggering an instruction for the robot system to perform the second task, wherein the triggering is performed by a t least one of the processors; and wherein the triggering is after the transmitting of the signal. 15. The method of claim 14, wherein the detecting is performed by the first robot. 16. The me thod of claim 14, wherein the detecting comprises detecting with a sensor in cormimnicatio with at least one of the first robot and a ser ver. 17. The method of claim 10, further comprising receiving an instruction for the fir st robot to execute a task. 18. The method of claim 10, further comprising tracking tasks currently executed by the system. 19. The method of claim 10, further comprising storing queue of tasks awaiting execution by the system. 20. A method for controlling robot system comprising a first robot, the method comprising:

mobilizing the fust robot from a first location to a second location;

communicating a first task to the first robot, wherei the communicating is performed by a server;

detecting a signal with a sensor,

transmitting at least one of the signal and data at least partially representing the signal to the server:

triggering by the server of a second task;

comparing by the server a first priority score of the first task and a second priority score of the second task;

comimtnicating by the server a second task to the first robot, wherein the communicating of the second task comprises communicating to stop the first task and to presently start the second task.

21. A roaming sensor system comprising:

a first robot;

a second robot;

a coinniunication network in cornm inicatioii with the first robot and the second robot;

a controller configured to distiibvite a first task to the first robot and a second task to the second robot and wherein the controiier is configured to monitor a task capacirv of the first robot, and wherein when the controller detects that t e first robot has capacity for an additional task, the controller is configured to instruct the first robot to perform at least one of all or part of the second task remaining to be performed. 22. The system of claim 2 i„ wherein the first robot comprises a first antenna, and wherein the second robot comprises a second antenna, and wherein the communication network comprises the first antenna and the second antenna, 23. The system of claim 21 , further comprising a server, wherein the server comprises the controller, and wherein the server comprises a networking device, and wherein the networking device is in the communication network, and wherein the networking device is in communication with the first robot and the second robot. 24. The system of claim 23, the first robot comprises a first processor 25. The system of claim 23, the second robot comprises a second processor 26. The system of claim 21 , wherein the first robot is mobile. 27. The system of claim 26, wherein the second robot is mobile. 28. A method for controlling a roaming sensor system, wherein the system comprises a first robot and a second robot, the method comprising:

assigning a first task to the first robot;

assigning a second task to the second robot; reporting that the first robot has completed the first task or that the first robot has completed a sufficient portion of the first task that the first robot has capacity for an additional task: and

assigning the second task to the first robot after the reporting of the completion by the first robot 29. The method of claim 28, wherein the assigning of the first task to the first robot comprises assigning by a controller. 30. The method of claim 29, wherein the assigning of the second task to the second robot comprises assigning by the controller; 3 i . The method of claim 30, wherein the reporting by the first robot of the completion of the first task comprises reporting to the controller; 32. The method of claim 30, wherein the assigning of the second task to the first robot after the reporting of the completion of the first task comprises assigning by a controller. 33. The method of claim 28, wherein the reporting by the first robot of the completion of the first task comprises reporting to the controller; 34. The method of claim 28, wherein the assigning of the second task to the first robot after the reporting of the completion of the first task comprises assigning by a controller. 35. The method of claim 28, wherein the system further comprises a third robot, and wherein the first and second robots are tagged as having a first ft ctionalify, and wherein the third robot is tagged as having a second functionality, and further assigning a third task to the third robot, wherein the second nationality comprises the third task. 36. The method of claim 28, wherem the first robot is mobile. 37. The method of claim 36, wherem the second robot is mobile.

38. A method for coatrolling a roaming sensor system,, wherein the system comprises a first robot and a second robot, the method comprising:

dividing a first task into a first portion and a second portion:

assigning th firs portion of the first task to the first robot;

assigning the second portion of the first task to the second robot;

reporting that, the first robot has completed the fir st portion of the first task [or that the first robot has completed a sufficient portion of the first portion of the first task that the first robot has capacity for an additional task]; and

assigning a second task to the first robot after the reporting of the completion by the of the first portion by the first robot. 39. The method of claim 38, wherein the first robot is mobile, 40. The method of claim 39, wherein the second robot is mobile. 41. A roaming sensor system comprising:

a first robot:

a server comprising a processor, wherein the server is configured to have data communication with the robot: and

a memory, wherein the memory has data comprising a ma of an environment and wherein the map comprises a map having a zone:

and wherein the server is configured to instruct the robot to follow a first path in the zone at a first time and a second path in the zone at a second time. 42. The system of claim 41 , wherein the system is configured to sense wear levels of a floor under the first path and adjacent to the first path, and wherein the system is configured to create the second path based at least in part on the wear levels. 43. The system of claim 41, wherein the system is configured to monitor a security patrol coverage of the first path, and wherem the system is configur ed to create the second path based at least in part on the security patrol coverage of the first path. 44. The system of claim 41 ; a second robot, wherein the processor is configured to instruct the second robot to follow a third path in the zone.

45. The system of claim 41 , wherein processor is configured to randomly generate the first path. 46. The system of claim 45, wherein processor is. configured to. randomly generate the second path. 47. The system of claim 41, further comprising a server, wherein th server comprises the processor and the map, and wherein the server communicates instructions from the processor to the first robot. 48. The system of claim 47, wherein the server is configured to wirelessly communicate with the first robot. 49. The system of claim 41, further comprising a second robot, wherein the processor is configured to instruct the second robot to follow a third path in the map. 50. The method of claim 41 , wherein the first robot comprises the processor and the memory. 51. A method for controlling a roaming sensor system in an environment having a zone. wherein the roaming sensor system comprises a fust robot, the method comprising:

controlling the first robot from a server detached from the first robo wherein the server can access map data in a memory, and wherein the map data comprises a map of the zone;

instructing the first robot to move along a first path in the zone at a first time; and instructing the first robot to move along a second path in the zone at a second time. 52. The method of claim 51, further comprising sensing wear levels of a floor under the first path and adjacent to the first path, and creating the second path based at least in part on the wear levels.

53. The method of claim 51, further comprising computing security patrol coverage of the first path, and creating the second path based at least in part on the security patrol coverage of the first pa th. 54. The method of claim 51, wherein the roairin sensor system further comprises a second robot, the method further comprising instructing the second robot to move along a third path on the map at a third time. 55. The method of claim 54, wherein the third path is based at least in part on a security patrol coverage of the first path and the second path. 56. The method of claim 54, further comprising sensing wear levels of a floor under the first path, adjacent to the first path, under the second path, and adjacent to the second path, and creating the third path based at least in part on the wear levels. 57. The method of claim 51, further comprising generating a ma of the environment, wherein generating the map comprises moving the robot through the environment. 58. The method of claim 51, further comprising randomly generating the fust path. 59. The method of claim 51, wherein the server wirelessiy communicates with the first robot to instruct the first robot to move along the first path and the second path. 60. The method of claim 59, wherein the server wirelessiy communicates with a second robot to instruct the second robot to move along a third path. 61. A method for controlling a roaming sensor system in an environment having a zone, wherein the roaming sensor system comprises a first robot and a second robot, the method comprising:

accessing map data in a memory, wherein the map data comprises a map of the zone;

instructing the first robot by a processor to move along a first path in the zone at a first time; and instructing the second robot by the processor fo move along a second path in the zone at a second time. 62. The method of claim 61 , further compiismg sensing wear levels of a floor under the fir st path and adjacent to the first path, and creating the second path based at least in part on the wear levels. 63. The method of claim 61, further comprising creating the second path based at least in part on a security patrol coverage of the first path and the second path. 64. The method of claim 61 , further comprising mstructing the first robot to move along the second path in the zone at a third time.

Description:
TITLE OF THE INVENTION

SYSTEM AND METHOD FOR COLLECTING AND PROCESSING DATA AND FOR UTILIZING ROBOTIC AND/OR HUMAN RESOURCES Adam M. Gettings

Andrew G. Stevens CROSS-REFERENCE TO RELATED APPLICATION

[0001] This application claims priority to U.S. Provisional No. 61/773,759, filed 6 March 2013, which is incorporated by reference herein in its entirety. BACKGROUND

[0002] There are a number of challenges in operating a robot in conjunction with humans and biii ings/enwonments. When multiple robots are available, the challenges can multiply significantly. Thus, there is a need in the robotics field to create a new system for managing robots and their interactions with buiidrngs/eiiviiOmiiente and humans. This inventio provides such a new system and method for collecting and processing data efficiently and utilizing robotic and/or human resources effectively.

[0003] Security, maintenance, and operations staff have a large amount of territory to cover and large amounts of data to process when coordinating humans, robots, computer systems, and/or sensors in a building, worksite, campus, or other large environment There are a variety of sensors, navigation devices, mapping devices, and other data collection and/or task performing devices mat can generate large amounts of data . This information can be recorded, stored, processed, filtered, and/or otherwise utilized in real-time or with post- processing. Allocating robotic and/or human resources in response to collected and/or processed data can be complex. Effectively utilizing resources, prioritizing tasks, and allocating routes (possibly in real-time) while performing operational tasks, maintenance tasks, security tasks, safety tasks, and or any other suitable tasks can be challenging. SUMMARY OF THE INVENTION

[0004] A system is described herein that can collect and process data and utilize robotic and/or human resources by scheduling priorities of robot and/or human tasks, allocating the use of robot and/or human resources, and optimizing robot and/or human routes across the mftastmcture of an organization. The system can have a roaming sensor system. BRIEF DESCRIPTION OF THE FIGURES

[0005] FIGURE 1 is a schematic diagram of a variation ©fan environment having a roaming sensor system.

[§006] FIGURE 2a is a diagram of a variation of an allocation of fimctioiialities or division of tasks betwee three robots: Robot A, Robot B, and Robot C.

[0007] FIGURE 2b is a diagr am of a variation of an allocation of functionalities or division of tasks between three robots: Robot A, Robot B, and Robot C.

[0008] FIGURES 3a through 3c are diagrams of variations of allocations of time between tasks for a cleaning/compliance robot.

[0009] FIGURE. 4a is a schematic diagram of a variation of process flow for an interrupt handler.

[0010] FIGURES 4b through 4d are tables of variations of interrupt signals with a a priority score.

[0011] FIGURES 5a through 5c illustrate variations of routes or paths on a map of an environment for a wear-leveling selection process for the robot route.

[0012] FIGURES 6a through 6d illustrate variations of routes or paths on a ma of an environment for a randomized selection process for the robot route.

[0013] FIGURE 7 illustrates a variation of a route or path on a map of an environment for a flanking selection process tor the robot route.

[0014] FIGURE 8 illustrates a variation of a route or path on a map of an environment for a high-alert area or zone targeting selection process for the robot route,

[0015] FIGURE 9 illustrates a variation of a route or path on a map of an environment for a selection process for allocating the route across multiple robots.

[0016] FIGURE. 10 illustrates a variation of a building equipped with sensors and an example of a robot equipped with sensors,

[0017] FIGURE 11 illustrates a variation of a building equipped with robot navigation beacons. DETAILED DESCRIPTION

[0018] Figure 1 illustrates that a roaming sensor system 10 can be located in and operate in an environment 300, such as a building (as s own), campus of one or more indoor and outdoor areas, yard, transportation construct (e.g., road, bridge, tunnel, airport tarmac, train platform, seaport), or combinations thereof. The environment 300 can have exterior and interior walls 315a and 315b and doors 310. The environment 300 can have one or more sensors 12. The sensors 12 can be mounted and fixed to the ceilings, walls, floor, ground, window's, electrical outlets, data outlets (e.g.. ethemet ports, wail-mounted audio ports), fixtures, movable objects/chattel (e.g., furniture,, computers, appliances such as

refrigerators, livestock), unmounted, unfixed, or combinations thereof.

[0019] The roaming sensor system 10 can have a server 14, a first robot 20a. a second robot 20b, and more robots (not mown). The robots 20 can be mobile and can have one or more mobility elements 16, such as tracks, arms, wheels, or combinations thereof. The robots 20 can have one or more microprocessors and memory (e.g., solid-state/flash memory, one or more hard drives, combinations thereof). The robots can have robot antennas 18 that ca transmit and receive data and/or power over a wireless communication and/or power network. The robots 20 can broadcast and/or receive wired and/or wireless data or power to and/or from the se e 14, sensors 12, other robots 20, or combinations thereof (e.g., the aforementioned elements can be in a commuriication and/or power network). The robots 20 can have any of the elements described in U.S. Patent No.

8.100.205. issued 24 January 2012, or U.S. Pat. App. No. 13/740,928, filed 14 January 2013, which are incorporated by reference herein in their entireties.

[0020] The server 14 can have one or more microprocessors and memory 19 (e.g. , solid- state/flash memory, one or more hard drives, combinations thereof). The server 19 can represent one or more local (i.e., in the environment) or remotely (i.e., outside of the environment) located servers, processors, memory, or combinations thereof. The server and/or robot microprocessors can act in collaboration as a set (e.g., distributing processor tasks) or independently to control the robots. The server can have a networking device in communicatio with the robots, or other networked elements in the environment or on a WAN outside of the environment or the Internet.

[0021] The robot and/or server memory can have one or more databases having a list of tasks, interrupt signals ior each task, priority scores for each task (described below and i Figures 4b-4d), task histories for each robot, performance (e.g. , speed, time to completion, interruption logs, result) for each robot for each task, or combinations there. The robot and/or server memory can have a map of the environment 300. For example, the map can include the location of the perimeter of the environment 300, walls 315, doors, 310, locations of the robots 20, sensors 12, server 14. and combinations thereof. The

environment 300 can have one or more zones in the map. For example, hallways/corridors, rooms, cubicles, yards, !anes, platforms, ports, docks, and runways can individually or combination by labeled as different zones in the map data. The zones in a single map can overlap or be non-overlapping.

[0022] As the robots 20 move through the environment, sensors on the robots 20 can detect and confirm or update the map data. For example, the robots 20 can have RF tag sensors, visual sensors and/or rada to detect the distance and direction of the surfaces of nearby objects, such as walls, or RF tagged objects such as specific chattel, to the sensors, and the robots 20 can have GPS and dead-reckoning sensors to determine the position of the robot 20. The robots 20 can confirm or update the map data in the robot and/or server memory based on the surroundin surfaces and position of the robot.

[0023] The roaming sensor system can include sensors and/or systems one or more robots 20, on a permanent, semi-permanent, or temporary building or environment 300, on other mobile objects including people (e.g., on clothing, in a backpack or suitcase) or animals (e.g., in or on a police K-9 vest), or combinations thereof. Robots, enwomnents biiildings, and other mobile objects can be equipped with sensors, navigation systems, control systems, communication systems, data processing systems, or combinations thereof.

[0024] A roaming sensor system can include at least one robot. The robot can b outfitted with sensors and task performing devices. One or more robots c an be deployed and managed as service platform designed to provide services and tasks for an organization and/or a facility or campus, and the software can be managed from a centralized location that may or may not be located at the facility or campus. Such a service could have fixed capital costs or could ha ve a subscription fee for the use of services, tasks, the number of robotic systems deployed simultaneously or serially, the number of patrols, the number of routes, the number of security events detected, or any other suitable measurement of use of the robotic system service platform. The system can assign multiple tasks to one or more robots, to perform multiple simultaneous tasks on one or more robots, to allocate

computing resources to process sensor data collected by one or more robots and/or make allocation decisions based upon the results of the data processing, to prioritize the performance of tasks by one or more robots, to enable one or more robots to cooperate with one or more robots, humans, or other elements in the environment to complete a task, and/or to cooperate with at least one other robot to perform a task that can be performed more effectively and/or faster by at least 2 robots, such as a cleaning task or a security patrol.

[0025] Roamin sensor system tasks can include security tasks, safety tasks, seif- maintenance tasks, bidlding/enviromnent maintenance tasks, compliance tasks, cleaning tasks, gofer tasks, or combinations thereof. Security' tasks can include patrolling an area, responding to alarm signals, and detecting suspicious people and/or activities. Tire alarm signals can be sacrificial alerts, for example, a robot patrolling an area that detects radiation or comes into contact with dangerous chemicals or biological agents can 'sacrifice' itself, and cease all activity and ' or movement except sending an alert, which can prevent contamination. In this way, the robotic system can be Hsppocratic and "first do no harm." A robot sacrifice could be that the robot self-destructs either partially or fully, to prevent a malicious or careless operator from accidentally spreading contamination. Safety tasks can include monitoring radiation levels, detecting and responding to chemical spills, fires, and leaks, and determining the extent and/or source(s) of chemical spills, fires, and leaks. Self- maintenance tasks can include charging robot batteries, repairing motors and/or other parts, uploading data and/or syncing with other robots, and downloading data (which can include maps, instructions,, and updates). Bu dmg environment maintenance tasks can include checking for burnt out lights, performing lifecycle analysis (e.g. for fluorescent lights and mattresses), monitoring soil moisrare levels, checking for cracks in sidewalks and roads, checking for discoloration in ceiling tiles, monitoring building temperatures (e.g. HVAC effect mapping), checking for structural damage and ' or other abnormalities (e.g. slippery floors and unusual machine sounds), monitoring silt levels along barge route, and turning off lights (e.g. at the end of the business day and in unused rooms). Compliance tasks can include monitoring hallways and exits (e.g. detecting boxes that are stacked too high and checking that fire exits are accessible), detecting unsafe activities (e.g. smoking near building entrances), and monitoring parking structures (e.g. checking for illegal parking in handicap spaces). Cleaning tasks can include monitoring buUding environment

cleanliness; waxing, sweeping, vacuuming, and/or mopping floors; emptying garbage bins; and sorting garbage and/or recyclables. Gofer tasks can include retrieving and'or delivering mail and other packages, fetching refreshments, making copies, answering doors, and shopping (e.g. retrieving paper from a storage closet, notifying an operator that there are no more staples, and'or going to a supply store).

[0026] The roaming sensor system can commimicate, for example by sharing acquired data with humans and'or othe robots, triggering responses, and providing instructions. The roaming sensor system can tr ansmit numerical data to a storage server via a wireless network (e.g., Wi-Fi. Bluetooth, 4G, 3G, LTE, GPRS modem, hard line wire docking station). [0027} The roaming sensor -system can eoraniiinieate through a social interface between one or more robots and one or more humans. A social interface would allow a robot to interact with humans using voices and or images, pictograms, facial expressions, gestures, touch, and other conmiumealion methods that humans use. A robot equipped with a social interface can use customizable social interfaces, such as one or more novelty voices, which can include licensable theme voices and corporate officer voices. Licensable theme voices can include Star Wars, Borat, Star Trek, The Simpsons, Family Guy, and combinations thereof. Corporate officer voices can include Sieve Jobs, Larry Ellison, Bill Gates, Steve Ballmer, and combinations thereof. A robot can counsel and provide people management by asking questions, detecting stress in human voices, and responding appropriately to influence emotions. For example, a robot detecting sadness can sympathize, tell jokes, offer to bring coffee or a newspaper, or simply leave the person alone (e.g. if the person was annoyed by the robot). A robot can perform customer service tasks. For example, a robot can answer customer questions about store horn's, product location, and product availability. Resource management system

[0028] Resource management hardware and/or software executing on the processors in the server or robots can allocate resources and manage tasks for the roaming sensor system. Resource allocation can include dividing workloads (e.g. across multiple robots and/or humans); optimizing resource consumption, tune spent on particular tasks, battery usage (e. g. amount of battery life spent on collecting and/or transmitting da ta), and robot patrol coverage (e.g. dividing paths among multiple robots); improving task completion times; and coordinating responses to events such as security threats, safety threats, maintenance events (e.g. a light bulb burning out), or combinations thereof.

[0029] The resource management hardware and/or software can dir ect the processor to instruct the first robot with a first task, and the second robot with the first or second task. Urgent instructions for the robots to perform tasks are interrupt, request (IR) signal inputs. The resource management hardware can receive or create interrupt request (IR) signal inputs.

[0030] Sensors on the robot and or elsewhere in the environment can detect signals and send data relating to the detected signals to the processors on the robots and/or servers. The processors can then instruct the robots to perform a task based on the data relating to the detected signals. [0031] As shown in Figure 2 , robots can be designed with compartmentalized

functionalities. For example, one robot can be a security /cieanmg robot, a second robot can be a mamtenance/compliance robot, and a third robot can be a safety/gopher robot , Workloads, which can include security tasks, safety tasks, self-maintenance tasks, biiilding/eaviiOnnient maintenance tasks, compliance tasks, cleaning tasks, and/or gofer tasks, can be shared, allocated, balanced, and/ or divided among two or more robotic systems according to functionality. For example, a workload including security tasks and compliance tasks can be shared such that a security/cleaning robot performs security tasks and a mamtenance/eoniplianee robot performs compliance tasks. Alternatively, a workload including security tasks and compliance tasks can be shared such that security/cleaning robot and security/maintenance robot perform security tasks and a

gofer/safety/compliance robot performs compliance tasks. In some embodiments, the system may be configured to reassign or reallocate functionalities between the robots of the system. For example, as shown in Figure 2a, if Robot A were to breakdown or otherwise become unavailable, the system would reassign at least a portion of the tasks assigned to Robot A to Robots B and C. In some embodiments, only higher priority tasks might be reassigned, while lower priority tasks might remai uncompleted until Robot A returns to service. Such adjustments or modifications can be optimized for specific organizational priorities, which can also vary. This reassignment of tasks, as needed, could be managed manually, automatically, or self-directed between robots.

[0032] For example, a controller on one or more processors can distribute (i.e., instruct to perform) a first task to a first robot and a second task to a second robot. When the controller detects that the first robot has completed the first task or is otherwise has capacity to perform another task (e.g., while waiting for step in the first task that the robot does not actively perform, such as waiting for a slow chemical reaction to occur before detecting the results), the controller can instruct the first robot to perform the second task. For example, the controller can instruct the first robot to perform the entire, only the remaining portion, or a part of the remaining portion of the second task and let the second robot continue to perform the remainder of the second ta sk. The first robot can

communicate with the controller (e.g., on the server) that the first robot has completed the tasks, or is waiting for the tasks assigned to the first robot when the first robot is at that respective stage.

[0033] The controller can divide a single task into multiple parts and initially instruct different robots to perform different parts of the first task (e.g., the first robot can be assigned the first portion of the fust task and tire second robot can be assi gned the second portion of the fu st task). The controller can the rebalance the remahiing processes required by the first task between the first and second robots when the first and/or second robots are partially complete with the first task. The controller can assign second task to the first robot to finish the assigned portion of the task,

[0034] A robot ca be outfitted (either manually, automatically, or self-directed) with service modules. Manual outfitting can be performed by an operator or a ser vice technician or another robot. Self directed outfitting can be performed by the robot itself and similarly, automatic outfitting can be performed as a robot interacts with another system, such as a battery changer, or an automatic module changing device. Sen-ice modules can include tools or features adapted for specific tasks. For example, a robot can attach a basket on top of itself when preparing to perform gopher tasks and/or deliver mail. As another example, a robot could attach a spotlight to itself for an outdoor security patr ol at night.

[0035] As shown in Figure 2b, Robot A can be tasked by processors in t e system with 50% of a security patrol route or task. Robot B can be tasked with 45% of a security patr ol route or task. Robot C can be tasked primarily with a cleaning duty and can finish up an allocation of 5% of a security patrol route or task (e.g. on the way to and from a cleaning site) to assist the other robots and possibly to speed up the completion of the security task. The tasking can be read by the processors from a database listing the robots and the tasks for each robot. Tasks requiring uncertain amounts of time can be re-divided and allocated across and/or assigned among multiple robots. Coordinating responses ca involve collaborating w h one or more robots, maintenance staff security staff, and/or

adniimstrative / support staff.

[0036] A robot having two or more fimctioiialities can share and/or divide its time among particular tasks. A robot can perform multiple tasks simultaneously and/or allocate a certain percentage of its time on each task. As an example, a robot running 3 tasks can pause the first task and perform a second task while running a third task simultaneously. Simultaneously in this context can include naming a task completely or partially in parallel, or simultaneously can also mean sharing time on a processor and context switching between two tasks until one or both of the tasks complete, similar to how a modem operating system fakes multitasking for users of a GUI on a Windows, Mac or Linu operating system. As shown in Figure 3a, a cleaning/compliance robot can divide its available capacity for tasks and/or operating time evenly among cleaning tasks and compliance tasks. As shown in Figure 3b, a cleaning/compliance robot can spend more time performing compliance tasks than cleaning tasks. As shown in Figure 3c, a cleaning? compliance robot can perform cleaning tasks and compliance tasks at the same time, { 037J Task management can involve tasks that can be actively started by an operator or a server allocation system, tasks that can be latent: and/or run constantly i the background, and/or tasks that can be scheduled to run regularly. For example, alarm signal response can be actively started, radiation level monitoring can run constantly, and robot battery charging can be scheduled. For example, a security patrol robot, can monitor carpet cleanliness (e.g. in a hotel or office building), wear patterns, unsafe conditions, and chemical leaks (e.g. hi an industrial environment) while also monitoring for security threats. Over time, a dataset could be used to predict or schedule maintenance, cleaning, and or safety checks; all of this information could be gathered by at least one robot as a background data collection process during regular' security patrols. Additionally, as unscheduled resources become available (e.g. a robot finishes a charge cycle or is dismissed from a task by a human operator), tasks can be re-allocated across all robots. Alternatively, these additional robots can be used to complete higher priority tasks faster, and then lower priority tasks can be re-allocated across all robots.

[0038] As shown hi Figure 4a, a roaming sensor system can be interrupt driven such that task management can involve a priority engine 90. The priority engine 90 can be hardware including one or more processors in the system or can be digital logic distributed across multiple processors hi the system and/or software executing processor's containing custom digital logic and/or software distributed across one or more processors. The priority engine 90 can include one or more interrupt request (IR) signal inputs 95, an interrupt mask register 94, an interrupt request register 91, a priority resoiver 92, an in-service register 93, and a controller 96. The controller 96 can instruct the robot to directly perform tasks. The interrupt mask register 94 can store a queue of tasks a waiting execution by the system or specific robot 20.

[0039] Interrupt request signal inputs 95 can be logged in an interrupt request register 91 , which can pass each IR to a priority resoiver 92. A priority resoiver 92 can rank each IR according to its pre-assigned priority score and pass die IRs to a controller 96 in order, e.g. starting with the highest-priority interrupt request (i.e., the IR with the highest score), Alternatively, a priority resoiver 92 can assign priorities randomly or handle IRs in a first- in-last-out, last-m-first-out, or round robin prioritization scheme. An in-service register 93 can keep track of which IRs are currently being handled by the controller 96. An interrupt mask register 94 can keep tr ack of which IRs are currently being masked, i.e. ignored, by a ' controller 96. For example, a priority resolver 92 handling three IRs, e.g. R-l, R-2, and R- 3, can rank the IRs according to their pre-assigned priorities and pass the highest priority IE, e.g. R-2, to a controller 96. An in-service register 93 can keep track of the fact that the controller 96 is currently managing R-2, while an interrupt mask register 94 can keep track of the fact that the controller 96 is currently ignoring R-l and R-3. Once the controller 96 has finished processing se 'scing handling R-2, the in-service register 93 can keep [rack of the fact that the controller is now managing R-l and R-3, while an interrupt mask register 94 can keep track of the fact that the controller is now no longer ignoring any IRs.

[0040] For example, the robot 20 can be controlled to perform a first, instructed task. An IR can t ee be received by the interrupt request, register 91. The interrupt, request register 91 can send the IR to the priority resolver 92. The in-service register 93 can inform the priority resolver 92 that the controller 96 currently has the robot performing the first task.

[0041] The priority resolver 92 can then compare a priority score of the first task to a priority score of the second task (as found in the task list in a database in memory). If the priority' score of the first task is higher than the priority score of the second task, the priority' resolver 92 can send the second task request to the interrupt mask register 94 to wait until the second task has a higher priority score than any other tasks in the interrupt mask register and the task in the in-service register before the second task can be performed by the robot. If the priority score of the first task is lower than the priority score of the second task, the priority resolver 92 can stop the contr oller 96 from having the robot execute the first task, send the first task to the interrupt mask register 94 (along with the current execution progress of the first task) to wait until the first task has a higher priority score than the highest priority score of tasks waiting in the interrupt mask register 94 and the task in the in-service register 93 to be completed, and send the second task to the iu- sen-ice register 93 and instruct the controller 96 to execute and have the robot perform the second task. The priority engine 90 can be partially or entirely executed by processing hardware and/or software executing on a processor on the respective robot, on a different robot, on the server, or any combinations thereof.

[0042] IRs can include sensor inputs and operator commands. For example, an IR may include the detection, by a robot of one or more suspicious people or activities. IRs can be non-maskable interrupts (NMIs), i.e. the interrupt cannot be ignored. For example, an MI may include the detection, by a robot, of radiatioe exposure, and that it has been exposed to an amount of radiation that can render it unsafe to leave the area and/or return to its return location (e.g. a charging station or "home base"), hi such an instance, the radiation exposure interrupt service routine could require a robot to ignore all other interrupt requests while a radioactive contamination I was being proeessed/semeed¾«idled, and any maskable interrupt requests would therefore be masked. As shown in Figures -4b, 4C, and 4d, IRs can be optimized for robots having various mnctionahties, including

security/cleaning robots, safety/gofer robots, compliance/maintenance robo ts, and/or any other suitable combination of robot fimctionalhies.

[0043] As shown in Figure 4b, IRs for a security/cleaning robot can include detecting suspicious person(s) or activity,, detecting a broken window, detecting a wet floor, and detecting a foil garbage container. NMIs for a secmity/cleaning robot can include detecting nuclear and/or chemical contamination and battery death. Suspicious persoii(s) or activity, for example, can be assigned a higher-ranked mteniipt than a Ml garbage container. If a seairity/eleaning robot were to detect both, the priority resolver could instinct the controller to ignore the foil garbage container and respond to the suspicious person(s) or activity. If a security/cleaning robot were to detect nuclear chemical contamination and/or battery death, the priority resolver could instruct the controller to ignore, i.e. mask, all other interrupts and/or to stay in place to avoid spreading nuclear/chemical contamination while waiting for a human or another robot to provide additional support.

[0044] As shown in Figure 4c. IRs for a safety/gofer robot can include detecting an unusual radiation measurement, detecting a chemical spill receiving an order to deliver a small package, and receiving an order to deliver a large package. NMIs for a safety/gofer robot can include detecting nuclear and or chemical contamination and batter death. A chemical spill, for example, can be a higher-ranked interrupt than an order to deliver a package. If a safety/gofer robot were to detect both, the priority resolver could instruct the controller to ignore the package delivery order and respond to the chemical spill. If a safety/gofer robo wer e to detect nuclear/chemical contamination and or battery death, the priority resolver could instruct the controller to ignore all other interrupts.

[0045] In some embodiments, a gopher robot could also follow a user, possibly playing background music that the user likes, and waiting for instructions from the user. In a household, such user tasks can include fetching a newspaper; checking on a timer, temperature, water on the stove, bath water; and performing security checks and patrols while a user is away from the residence, asleep, and/or working in another part of the house, e.g. the robot can be connected over an internet connection so that the user can control the robot as an avatar while at a different location. [0046] As shown in Figure 4d, FRs for a compliance/maintenance robot can include detecting a person smoking near building entrance, detecting a blocked emergency exit, detecting a non-working light, and detecting an unusual room temperature. NMIs lor a compliance/maintenance robot ca include detecting nuclear and/ or chemical

contamination and battery death. A blocked emergency exit, for example, can be a liigher- ranked interrupt than a non-workfrig light. If a compliaiice/mamtenance robot were to detect both, the priority resolver could instruct the controller to ignore the non-working light and respond to the blocked emergency exit. If a compliance/maintenance robot were to detect nuclear/chemical contamination and/ or battery death, the priority resolver could instinct the controller to ignore all other interrupts.

[0047] Interrupt priorities can be adapted, modified, or adjusted as additional robots and/or resources become available. Such adjustments or modifications can be optimized for specific organizational priorities, which can also vary. For example, robots can function as gopher/safety robots during normal working hours, cleaning robots during evening hours, and high-alert security robots after midnight. When a robot finishes a cleaning task, the priorities of its interrupts could be adjusted to focus primarily on security. Route allocation

[0048] As shown in Figures 5a-5e, 6a-d, 7, 8, and 9, robot routes within a

buuding environnient can be selected for particular tasks and ar eas. Robot paths can be allocated entirely to a single robot or can be allocated across multiple robots. Routes can include wear-leveling routes, randomized routes, flanking routes, routes tar geting high-alert areas, and routes specialized for high-risk situations.

[0049] The robots 20 can have sensors, such as described herein including camer as. The sensors on the robots 20 and/or positioned elsewhere in the environment 300 can. for example, be cameras capturing images of the ground of the environment (e.g. , carpet, hard flooring such as tile, marble or hardwood, grass) under and near- the robots. The signals from the cameras can be processed by one or more of the processors in the system (e.g. , detennirnng height of carpet fiber s, reflection of light from carpet or tile, or combinations thereof) to identify a wear level for each location of the ground of the environment.

[0050] Wear-leveling routes can be used to prevent excess wear on floor surfaces, such as marble floors, carpeted floors, grass, or combinations thereof. One or more of the processors in the system can instruct a fir st robot 20 to follow a first path in a first zone on the map of the environment during a first traversal of the zone by the fir st robot 20 at a first time. One or mare of the processors can iiistract the first robot 20 to follow a second path in the first zone during a second traversal of the zone by the first robot 20 at a sec ond time later than the first time. The first path and the second path can, for example, cross but. not have collinear portions where the ground has more wear than the average wear along all of the robot paths instructed by the system in the zone. One or more of the processors can instinct a second robot to follow a third path in the first zone concurrent ' with the first robot or at. a third time. For example, the third path can cross but not have collinear portions with the iirst or second paths.

[0051] The processors can generate the paths based on the wear data determined by the sensors.

[0052] One or more of the processors can generate random paths through the zone for the fir st and/or second robots,

[0053] The processors generating the rentes or paths for the robots to follow can be on the robots, the server, or combinations thereof. The map data used to generate the routes can be on the memory of the robots, server, or combinations thereof.

[0054] Wear-leveling routes can also improve sensor monitoring over a larger area and refresh dat more frequently and evenly. As shown in Figure 5, robot 20 can follow a wear-leveling route 31, 32, or 33 while traversing a hallway 320 in a building/environment. 300. A robot can alternate routes to aid in wear leveling; for example, a robot 20 can follow route 31 in the mornings and route 32 in the evenings. Likewise, multiple robots can alternate routes to aid in wear leveling; for example * a robot 20 can follow route 32 while another robot 20 can follow route 33,

[0055] Randomized paths can be used to avoid detection by adversaries. As shown in Figures 6a, 6b, 6c, and 6d, a robot in a building/ environment. 300 can follow a randomized route 41. 42, 43, or 44 while patrolling the areas surrounding a room, closet, or other office space 330. A robot can alternate routes to avoid detection; for example, a robot can follow routes 41, 42, 43, and 44 according to a randomized schedule. Likewise, multiple robots can alternate routes to avoid detection. For example, robot can follow route 4 while another robot 20 can follow route 43.

[0056] Flanking routes can be used to detect, mtimidate, distract, and/or prevent suspects fleeing a scene, determine the source ancl/or extent of a leak, fire, or spill, and avoid an area that another robot is cleaning. As shown in Figure 7, a robot can follow route 51 or 52 to reach an incident location near a room 330. Two or more robots can follow flanking routes to gather more information about an incident; for example, a robot 20 can follow route 51 to reach an incident location while another robot can follow route 52 to approach the incident location from the opposite direction.

[0057] Depending on the priority of a response, flanking routes can be combined with. wear-leveling routes to improve and/or optimize wear leveling on a floor surface. Taking a wear-leveling route could slightly increase a robot's response time, but in some situations an extra second or two might not make a significant difference; for example, a small water leak (such as a drip) could be detected and monitored by pair of robots using both flanking and wear- leveling routes. In a situation where response time is more important taking a wear-leveling route can be omitted or delayed/queued; for example, a human intruder could be flanked by a pair of robots using only flanking routes.

[0058] Routes can be targeted such that a robot spends more time patrolling a high-alert ar ea, e.g. a main entrance or bank vault. As shown in Figure 8, a robot in a building/ environment 300 can follow route 61 to target a high-alert area 340.

[0059] Routes can be specialized for high-risk situations, e.g. moving valuable assets. For example, in the week prior to emptying a bank vault, robots can follow randomized routes while patrolling the area so that adversaries will be unable to find patterns in security coverage. On the day the vault is emptied, robots can follow targeted routes to increase security coverage.

[0060] Routes can also be modified in response to significant events, e.g. a robbery or chemical spiil. For example, in the weeks following a chemical spiil in a laboratory, robots patrolling the area can follow routes targeting the laboratory to ensure that the spill was properly cleaned and the area folly decontaminated. Followin a perimeter violation, a robot can be assigned a path that marks a particular portion of the perimeter as a higher risk area such that the robot patrols that area more often and/ or mor slowly. Th security patrol coverage area can be defined as the area covered by a security patrol. Some areas can have a higher security patrol requirement (e.g. the gold vault has a higher priority than the lunch room and gets more visits and thus more "security coverage" than the

lunchroom). The routes can be modified based on relative values of assets, risk assessments of entrances, exits, assessmen ts of chemical and physical maintenance requirements, safety monitoring requirements of chemical and physical machinery, previous security events, maintenance events, machinery breakdowns, or other information.

[0061] Routes can be allocated to a singl robot, or routes can be allocated across multiple robots, as shown in Figure 9. A route can be allocated across multiple robots to improve the speed of completion of a route, to improve coverage of a route, to use a robot with more battery power to back up or provide redundancy to a robot with lower battery power, e.g.. robot sentry relief duties, or any oilier purpose. As shown in Figure 9, a robot can follow routes 53 and 54 to perfomi a security patrol task near rooms 330 and 330 " in a

bmiding envsiOnment 300. Alternatively, one robot can follow route 53 to perform part of a security patrol task while another robot can follow route 54 to. perform another part of the security patrol task. Building interfaces

[0062] As shown in Figure 10, robots, buUdings/environnients 300,. humans, or combinations thereof, in a roaming sensor system can be equipped with one or more sensors 12. The sensors 12 can have cameras SO and 82, thermal imagers 81 , lasers, microphones, fire sinoke detectors, carbon monoxide detectors, chemical detectors, radiation detectors (e.g., Geiger counters), thermometers, humidity meters, and

combinations thereof. Sensors 12 can aid in navigation, control, communication, and data acquisition and processing. For example, a robot 20 can be equipped with a device that measures and records radiation levels 83, and a human analyst can check for abnormal readings.

[0063] A biulding/environment 300 in a roaming sensor system can be equipped with robot navigation beacons, which can be attached to existing doors 310, walls 315, light posts, and/or in any other suitable location or object, and a robot can be equipped with appropriate sensors. Additionally, a robot can pre-caclie one or more downloadable maps of a biii!ding/enviromnent . A robot can use a combination of data fr om its sensors, navigation beacons, and/or maps of a building/environnient to determine its position using appropriate methods; for example, a robot can use simultaneous localization and mapping to generate a real-time map of its environment as it performs tasks. Alternatively, a robot can be manitai!y controlled by a human operator.

[0064] As shown in Figure 1 1, a building/environment 300 can b equipped with robot navigation beacons that can provide a robot 20 with information for determining its current location. Robot navigation beacons can include radio frequency emitters at known locations and a robot 20 can use triiateration, triangulation, and/or other suitable methods to calculate its position; for example, a navigation beacon can be a cellular bas station 70, a radio broadcasting station 71 , a GPS satellite, and/or any other suitable emitter. [0065} As shown in Figure 1 1„ robot navigation beacons can include sonic emitters and a robot 20 can use sonar to calculate its position; for example, a navigation beacon can be an mfrasonic emitter 72, an ultrasonic emitter, and/or any other suitable sonic emitter.

[0066] As shown in Figure 1 1, robot navigation beacons can includ wimless access points and a robot 20 can measure the received signal strength to calculate its position: for example, a navigation beacon can be a wireless router 73, a Bluetooth device, a cellular communications tower, a computer with a wireless Bluetooth or Wi-Fi connection, a wireless repeater, a 3G / 4G /LTE radio modem, any type of wireless sensor, laser signals, fiber optics, and or any other suitable device that provides a wir eless connection to a wired network.

[0067] A roaming sensor system can visualize and/or analyze collected and/or aggr egated data, either hi real time for decision making or later, after more data has been collected. Data isualization can aid in detecting anomalies: for example, data visualization can reveal that a measured room temperature of 85°F is well above the average room

temperature of 70*F and should be reported to a human operator. Data visualization can aid in identifying and addressing security needs, safety needs, building/ environment

maintenance needs, compliance needs, and cleaning needs. For example, visualization of security alert locations can help a remote analyst identify high alert areas and can

correspondingly increase robot patrols of these areas. Visualization of radiation measurements can help a remote analyst identify the source of a radiation leak,

Visualization building temperature, humidity, and carbon dioxide levels can help remote analyst identify areas with inadequate or abnormal ventilation. Visualiza tion of reports of smokin near building entrances can help a remote analyst identify entrances that could benefit from additional signage. Visualization of floor cleanliness after vacuuming can help a remote analyst identify' vacuum cleaners that need to be replaced.

[0068] Modifications and combinations of disclosed elements and methods can be made without departing from the scope of this disclosure.