A portion of the disclosure of this patent document contains material that is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever.
The present application relates generally to robotics, and more specifically to systems and methods for persistent mapping of environmental parameters using a centralized cloud server.
Currently, a robot may generate a map of an environment while navigating through the environment. The map may comprise a plurality of features such as, for example, locations of objects and routes to follow. However, having a robot individually map an environment and store the map within a memory of the robot may be of issue when implementing a plurality of robots within an environment.
Additionally, it may be computationally taxing for each individual robot of a plurality of robots to generate its own map of the environment. Environments may also be dynamic, wherein robots mapping and navigating individually may not respond to dynamic changes to the environment without each individual robot observing and mapping the changes. Further, robots may require temporally accurate maps of many parameters to function optimally including locations of objects, locations of strong/weak Wi-Fi or cellular signal strength, temperature maps (e.g., to avoid extreme temperatures). Temporally accurate of parameters may additionally enhance human workflow in cooperation with robots such as, for example, a heat map of a store guiding an air conditioning maintenance worker to find a faulty vent.
Accordingly, there is a need for systems and methods of persistent mapping of an environment using a centralized cloud server communicatively coupled to a plurality of robots within the environment.
The foregoing needs are satisfied by the present disclosure, which provides for, inter alia, systems and methods for persistent mapping of environmental parameters using a centralized cloud server and a robotic network. The systems and methods disclosed herein are directed towards, inter alia, a practical application of distributed cloud computing for generating persistent maps of parameters using data collected from sensors of robots as the robots operate independent of each other and in unison as a network of multiple robots.
Exemplary embodiments described herein have innovative features, no single one of which is indispensable or solely responsible for their desirable attributes. Without limiting the scope of the claims, some of the advantageous features will now be summarized.
According to at least one non-limiting exemplary embodiment, a system comprising a cloud server communicatively coupled to a robot network, comprising a plurality of robots, is disclosed. The cloud server may be configurable to receive sensor data from at least one robot on a robot network communicatively coupled to the cloud server. The cloud server may further be configurable to utilize the received sensor data to generate a plurality of maps of parameters of an environment. These maps may be updated in real-time upon the cloud server receiving new data from one or more robots, wherein these maps updated in real-time may be considered persistent maps. The cloud server may communicate the persistent maps to the at least one robots on the robot network, wherein the robots may utilize the persistent maps to determine and perform tasks within the environment. Additionally, the cloud server may be further configurable to receive an operator query, distribute tasks to at least one robot to collect data, and respond to the operator query based on the data collected by the robots and/or data already stored within a memory of the cloud server.
According to at least one non-limiting exemplary embodiment, a method for generating and updating persistent maps is disclosed. The method may include a cloud server communicating instructions to a robot network, comprising a plurality of robots. The plurality of robots on the robot network may gather data on a plurality of parameters of an environment based on the instruction. The cloud server may then utilize the data from the plurality of robots to generate and/or update a persistent map of a parameter of an environment. The persistent map may be further utilized by the plurality of robots for task selection, route determination, and/or any other task for the robots.
These and other objects, features, and characteristics of the present disclosure, as well as the methods of operation and functions of the related elements of structure and the combination of parts and economies of manufacture, will become more apparent upon consideration of the following description and the appended claims with reference to the accompanying drawings, all of which form a part of this specification, wherein like reference numerals designate corresponding parts in the various figures. It is to be expressly understood, however, that the drawings are for the purpose of illustration and description only and are not intended as a definition of the limits of the disclosure. As used in the specification and in the claims, the singular forms of “a,” “an,” and “the” include plural referents unless the context clearly dictates otherwise.
The disclosed aspects will hereinafter be described in conjunction with the appended drawings, provided to illustrate and not to limit the disclosed aspects, wherein like designations denote like elements.
All Figures disclosed herein are © Copyright 2018 Brain Corporation. All rights reserved.
Various aspects of the novel systems and methods disclosed herein are described more fully hereinafter with reference to the accompanying drawings. This disclosure can, however, be embodied in many different forms and should not be construed as limited to any specific structure or function presented throughout this disclosure. Rather, these aspects are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the disclosure to those skilled in the art. Based on the teachings herein, one skilled in the art would appreciate that the scope of the disclosure is intended to cover any aspect of the novel systems, apparatuses, and methods disclosed herein, whether implemented independently of, or combined with, any other aspect of the disclosure. For example, an apparatus may be implemented or a method may be practiced using any number of the aspects set forth herein. In addition, the scope of the disclosure is intended to cover such an apparatus or method that is practiced using other structure, functionality, or structure and functionality in addition to or other than the various aspects of the disclosure set forth herein. It should be understood that any aspect disclosed herein may be implemented by one or more elements of a claim.
Although particular aspects are described herein, many variations and permutations of these aspects fall within the scope of the disclosure. Although some benefits and advantages of the preferred aspects are mentioned, the scope of the disclosure is not intended to be limited to particular benefits, uses, and/or objectives. The detailed description and drawings are merely illustrative of the disclosure rather than limiting, the scope of the disclosure being defined by the appended claims and equivalents thereof.
The present disclosure provides for systems and methods for persistent mapping of environmental parameters using a centralized cloud server and a robotic network.
As used herein, a robot may include mechanical and/or virtual entities configurable to carry out a complex series of tasks or actions autonomously. In some exemplary embodiments, robots may be machines that are guided and/or instructed by computer programs and/or electronic circuitry. In some exemplary embodiments, robots may include electro-mechanical components that are configurable for navigation, where the robot may move from one location to another. Such robots may include autonomous and/or semi-autonomous cars, floor cleaners, rovers, drones, planes, boats, carts, trams, wheelchairs, industrial equipment, mobile platforms, personal transportation devices (e.g., hover boards, SEGWAYS®, etc.), stocking machines, trailer movers, vehicles, and the like. Robots may also include any autonomous and/or semi-autonomous machine for transporting items, people, animals, cargo, freight, objects, luggage, and/or anything desirable from one location to another.
As used herein, a persistent map may include a computer readable map of one or more parameters of an environment comprising a persistent data structure. A parameter of an environment may include heat distributions, Wi-Fi signal strength, object localization, route data, no-go zones, and/or any other parameter of the environment measurable by a sensor of a robot. A persistent data structure may comprise a data structure that always preserves previous versions of itself when modified. A persistent map may be fully persistent (i.e., all versions of the persistent map may be accessed and modified) or partially persistent (i.e., all versions of the persistent map may be accessed but only the current version may be modified). Updates to a persistent map may include generation of a new persistent map of the parameter at a later instance in time, such that prior persistent maps of the parameter at prior instances in time may be parsed by an operator. A persistent map of one or more parameters may include a persistent map of an entire environment or a portion of the environment.
As used herein, a robot network or network of robots may comprise a plurality of robots communicatively coupled to each other and/or coupled to an external cloud server. The plurality of robots may communicate data to other robots on a robot network and to an external cloud server.
As used herein, a cloud server may comprise a server configurable to receive, request, process, and/or return data to robots, humans, and/or other devices. A cloud server may be hosted at the same location as a network of robots communicatively coupled to the cloud server or may be at a separate location.
As used herein, network interfaces may include any signal, data, or software interface with a component, network, or process including, without limitation, those of the FireWire (e.g., FW400, FW800, FWS800T, FWS1600, FWS3200, etc.), universal serial bus (“USB”) (e.g., USB 1.X, USB 2.0, USB 3.0, USB Type-C, etc.), Ethernet (e.g., 10/100, 10/100/1000 (Gigabit Ethernet), 10-Gig-E, etc.), multimedia over coax alliance technology (“MoCA”), Coaxsys (e.g., TVNET™), radio frequency tuner (e.g., in-band or OOB, cable modem, etc.), Wi-Fi (802.11), WiMAX (e.g., WiMAX (802.16)), PAN (e.g., PAN/802.15), cellular (e.g., 3G, LTE/LTE-A/TD-LTE/TD-LTE, GSM, etc.), IrDA families, etc. As used herein, Wi-Fi may include one or more of IEEE-Std. 802.11, variants of IEEE-Std. 802.11, standards related to IEEE-Std. 802.11 (e.g., 802.11 a/b/g/n/ac/ad/af/ah/ai/aj/aq/ax/ay), and/or other wireless standards.
As used herein, processor, processing device, microprocessor, and/or digital processor may include any type of digital processing device such as, without limitation, digital signal processors (“DSPs”), reduced instruction set computers (“RISC”), complex instruction set computer (“CISC”) processors, microprocessors, gate arrays (e.g., field programmable gate arrays (“FPGAs”)), programmable logic device (“PLDs”), reconfigurable computer fabrics (“RCFs”), array processors, secure microprocessors, specialized processors (e.g., neuromorphic processors), and application-specific integrated circuits (“ASICs”). Such digital processors may be contained on a single unitary integrated circuit die or distributed across multiple components.
As used herein, computer program and/or software may include any sequence or human or machine cognizable steps which perform a function. Such computer program and/or software may be rendered in any programming language or environment including, for example, C/C++, C#, Fortran, COBOL, MATLAB™, PASCAL, GO, RUST, SCALA, Python, assembly language, markup languages (e.g., HTML, SGML, XML, VoXML), and the like, as well as object-oriented environments such as the Common Object Request Broker Architecture (“CORBA”), JAVA™ (including J2ME, Java Beans, etc.), Binary Runtime Environment (e.g., “BREW”), and the like.
As used herein, connection, link, and/or wireless link may include a causal link between any two or more entities (whether physical or logical/virtual), which enables information exchange between the entities.
As used herein, computer and/or computing device may include, but are not limited to, personal computers (“PCs”) and minicomputers, whether desktop, laptop, or otherwise, mainframe computers, workstations, servers, personal digital assistants (“PDAs”), handheld computers, embedded computers, programmable logic devices, personal communicators, tablet computers, mobile devices, portable navigation aids, J2ME equipped devices, cellular telephones, smart phones, personal integrated communication or entertainment devices, and/or any other device capable of executing a set of instructions and processing an incoming data signal.
Detailed descriptions of the various embodiments of the system and methods of the disclosure are now provided. While many examples discussed herein may refer to specific exemplary embodiments, it will be appreciated that the described systems and methods contained herein are applicable to any kind of robot. Myriad other embodiments or uses for the technology described herein would be readily envisaged by those having ordinary skill in the art, given the contents of the present disclosure.
Advantageously, the systems and methods of this disclosure at least: (i) allow robots to detect sunlight in an image received by an imaging camera; (ii) remove areas of an image comprising noise due to sunlight; (iii) enable robots to navigate in more complex regions, such as regions near windows; and (iv) improve the safety of operation of the robots. Other advantages are readily discernable by one having ordinary skill in the art given the contents of the present disclosure.
According to at least one non-limiting exemplary embodiment, a system comprising a cloud server communicatively coupled to a robot network, comprising a plurality of robots, is disclosed. The cloud server may be configurable to receive sensor data from at least one robot on a robot network communicatively coupled to the cloud server. The cloud server may be further configurable to utilize the received sensor data to generate a plurality of maps of parameters of an environment. These maps may be updated in real-time upon the cloud server receiving new data from one or more robots, wherein these maps updated in real-time may be considered persistent maps. The cloud server may communicate the persistent maps to at least one robot on the robot network, wherein the robots may utilize the persistent maps to determine and perform tasks within the environment. Additionally, the cloud server may be further configurable to receive an operator query, distribute tasks to at least one robot to collect data, and respond to the operator query based on the data collected by the robots and/or data already stored within a memory of the cloud server.
According to at least one non-limiting exemplary embodiment, a method for generating and updating persistent maps is disclosed. The method may include a cloud server communicating instructions to a robot network comprising a plurality of robots. The plurality of robots on the robot network may gather data on a plurality of parameters of an environment based on the instruction. The cloud server may then utilize the data from the plurality of robots to generate and/or update a persistent map of a parameter of an environment. The persistent map may be further utilized by the plurality of robots for task selection, route determination, and/or any other task for the robots.
Controller 118 may control the various operations performed by robot 102. Controller 118 may include and/or comprise one or more processors or processing devices (e.g., microprocessors) as shown in
Controller 118 may be operatively and/or communicatively coupled to memory 120. Memory 120 may include any type of integrated circuit or other storage device configurable to store digital data, including, without limitation, read-only memory (“ROM”), random access memory (“RAM”), non-volatile random access memory (“NVRAM”), programmable read-only memory (“PROM”), electrically erasable programmable read-only memory (“EEPROM”), dynamic random-access memory (“DRAM”), Mobile DRAM, synchronous DRAM (“SDRAM”), double data rate SDRAM (“DDR/2 SDRAM”), extended data output (“EDO”) RAM, fast page mode RAM (“FPM”), reduced latency DRAM (“RLDRAM”), static RAM (“SRAM”), flash memory (e.g., NAND/NOR), memristor memory, pseudostatic RAM (“PSRAM”), etc. Memory 120 may provide instructions and data to controller 118. For example, memory 120 may be a non-transitory, computer-readable storage apparatus and/or medium having a plurality of instructions stored thereon, the instructions being executable by a processing apparatus (e.g., controller 118) to operate robot 102. In some cases, the instructions may be configurable to, when executed by the processing apparatus, cause the processing apparatus to perform the various methods, features, and/or functionality described in this disclosure. Accordingly, controller 118 may perform logical and/or arithmetic operations based on program instructions stored within memory 120. In some cases, the instructions and/or data of memory 120 may be stored in a combination of hardware, some located locally within robot 102, and some located remote from robot 102 (e.g., in a cloud, server, network, etc.).
It should be readily apparent to one of ordinary skill in the art that a processing device may be external to robot 102 and be communicatively coupled to controller 118 of robot 102 utilizing communication units 116 wherein the external processing device may receive data from robot 102, process the data, and transmit computer-readable instructions back to controller 118. In at least one non-limiting exemplary embodiment, the processing device may be on a remote server (not shown).
In some exemplary embodiments, memory 120, shown in
Still referring to
Returning to
In exemplary embodiments, navigation units 106 may include systems and methods that may computationally construct and update a map of an environment, localize robot 102 (e.g., find the position) in a map, and navigate robot 102 to/from destinations. The mapping may be performed by imposing data obtained in part by sensor units 114 into a computer-readable map representative at least in part of the environment. In exemplary embodiments, a map of an environment may be uploaded to robot 102 through user interface units 112, uploaded wirelessly or through wired connection, or taught to robot 102 by a user.
In exemplary embodiments, navigation units 106 may include components and/or software configurable to provide directional instructions for robot 102 to navigate. Navigation units 106 may process maps, routes, and localization information generated by mapping and localization units, data from sensor units 114, and/or other operative units 104.
Still referring to
Actuator unit 108 may include any system used for actuating, in some cases to perform tasks. For example, actuator unit 108 may include driven magnet systems, motors/engines (e.g., electric motors, combustion engines, steam engines, and/or any type of motor/engine known in the art), solenoid/ratchet system, piezoelectric system (e.g., an inchworm motor), magnetostrictive elements, gesticulation, and/or any actuator known in the art. According to exemplary embodiments, actuator unit 108 may include systems that allow movement of robot 102, such as motorize propulsion. For example, motorized propulsion may move robot 102 in a forward or backward direction, and/or be used at least in part in turning robot 102 (e.g., left, right, and/or any other direction). By way of illustration, actuator unit 108 may control if robot 102 is moving or is stopped and/or allow robot 102 to navigate from one location to another location.
According to exemplary embodiments, sensor units 114 may comprise systems and/or methods that may detect characteristics within and/or around robot 102. Sensor units 114 may comprise a plurality and/or a combination of sensors. Sensor units 114 may include sensors that are internal to robot 102 or external, and/or have components that are partially internal and/or partially external. In some cases, sensor units 114 may include one or more exteroceptive sensors, such as sonars, light detection and ranging (“LIDAR”) sensors, radars, lasers, cameras (including video cameras (e.g., red-blue-green (“RBG”) cameras, infrared cameras, three-dimensional (“3D”) cameras, thermal cameras, etc.), time of flight (“TOF”) cameras, structured light cameras, antennas, motion detectors, microphones, and/or any other sensor known in the art. According to exemplary embodiments, sensor units 114 may collect raw measurements (e.g., currents, voltages, resistances, gate logic, etc.) and/or transformed measurements (e.g., distances, angles, detected points in obstacles, etc.). In some cases, measurements may be aggregated and/or summarized. Sensor units 114 may generate data based at least in part on measurements. Such data may be stored in data structures, such as matrices, arrays, queues, lists, arrays, stacks, bags, etc. According to exemplary embodiments, the data structure of the sensor data may be called an image.
According to exemplary embodiments, sensor units 114 may include sensors that may measure internal characteristics of robot 102. For example, sensor units 114 may measure temperature, power levels, statuses, and/or any characteristic of robot 102. In some cases, sensor units 114 may be configurable to determine the odometry of robot 102. For example, sensor units 114 may include proprioceptive sensors, which may comprise sensors, such as accelerometers, inertial measurement units (“IMU”), odometers, gyroscopes, speedometers, cameras (e.g. using visual odometry), clock/timer, and the like. Odometry may facilitate autonomous navigation and/or autonomous actions of robot 102. This odometry may include robot 102's position (e.g., where position may include robot's location, displacement, and/or orientation, and may sometimes be interchangeable with the term pose as used herein) relative to the initial location. Such data may be stored in data structures, such as matrices, arrays, queues, lists, arrays, stacks, bags, etc. According to exemplary embodiments, the data structure of the sensor data may be called an image.
According to exemplary embodiments, user interface units 112 may be configurable to enable a user to interact with robot 102. For example, user interface units 112 may include touch panels, buttons, keypads/keyboards, ports (e.g., universal serial bus (“USB”), digital visual interface (“DVI”), Display Port, E-Sata, Firewire, PS/2, Serial, VGA, SCSI, audioport, high-definition multimedia interface (“HDMI”), personal computer memory card international association (“PCMCIA”) ports, memory card ports (e.g., secure digital (“SD”) and miniSD), and/or ports for computer-readable medium), mice, rollerballs, consoles, vibrators, audio transducers, and/or any interface for a user to input and/or receive data and/or commands, whether coupled wirelessly or through wires. Users may interact through voice commands or gestures. User interface units 218 may include a display, such as, without limitation, liquid crystal display (“LCDs”), light-emitting diode (“LED”) displays, LED LCD displays, in-plane-switching (“IPS”) displays, cathode ray tubes, plasma displays, high definition (“HD”) panels, 4K displays, retina displays, organic LED displays, touchscreens, surfaces, canvases, and/or any displays, televisions, monitors, panels, and/or devices known in the art for visual presentation. According to exemplary embodiments, user interface units 112 may be positioned on the body of robot 102. According to exemplary embodiments, user interface units 112 may be positioned away from the body of robot 102 but may be communicatively coupled to robot 102 (e.g., via communication units, including transmitters, receivers, and/or transceivers) directly or indirectly (e.g., through a network, server, and/or a cloud). According to exemplary embodiments, user interface units 112 may include one or more projections of images on a surface (e.g., the floor) proximally located to the robot, e.g., to provide information to the occupant or to people around the robot. The information could be the direction of future movement of the robot, such as an indication of moving forward, left, right, back, at an angle, and/or any other direction. In some cases, such information may utilize arrows, colors, symbols, etc.
According to exemplary embodiments, communications unit 116 may include one or more receivers, transmitters, and/or transceivers. Communications unit 116 may be configurable to send/receive a transmission protocol, such as BLUETOOTH®, ZIGBEE®, Wi-Fi, induction wireless data transmission, radio frequencies, radio transmission, radio-frequency identification (“RFID”), near-field communication (“NFC”), infrared, network interfaces, cellular technologies such as 3G (3GPP/3GPP2), high-speed downlink packet access (“HSDPA”), high-speed uplink packet access (“HSUPA”), time division multiple access (“TDMA”), code division multiple access (“CDMA”) (e.g., IS-95A, wideband code division multiple access (“WCDMA”), etc.), frequency hopping spread spectrum (“FHSS”), direct sequence spread spectrum (“DSSS”), global system for mobile communication (“GSM”), Personal Area Network (“PAN”) (e.g., PAN/802.15), worldwide interoperability for microwave access (“WiMAX”), 802.20, long term evolution (“LTE”) (e.g., LTE/LTE-A), time division LTE (“TD-LTE”), global system for mobile communication (“GSM”), narrowband/frequency-division multiple access (“FDMA”), orthogonal frequency-division multiplexing (“OFDM”), analog cellular, cellular digital packet data (“CDPD”), satellite systems, millimeter wave or microwave systems, acoustic, infrared (e.g., infrared data association (“IrDA”)), and/or any other form of wireless data transmission.
Communications unit 116 may also be configurable to send/receive signals utilizing a transmission protocol over wired connections, such as any cable that has a signal line and ground. For example, such cables may include Ethernet cables, coaxial cables, Universal Serial Bus (“USB”), FireWire, and/or any connection known in the art. Such protocols may be used by communications unit 116 to communicate to external systems, such as computers, smart phones, tablets, data capture systems, mobile telecommunications networks, clouds, servers, or the like. Communications unit 116 may be configurable to send and receive signals comprising of numbers, letters, alphanumeric characters, and/or symbols. In some cases, signals may be encrypted, using algorithms such as 128-bit or 256-bit keys and/or other encryption algorithms complying with standards such as the Advanced Encryption Standard (“AES”), RSA, Data Encryption Standard (“DES”), Triple DES, and the like. Communications unit 116 may be configurable to send and receive statuses, commands, and other data/information. For example, communications unit 116 may communicate with a user operator to allow the user to control robot 102. Communications unit 116 may communicate with a server/network (e.g., a network) in order to allow robot 102 to send data, statuses, commands, and other communications to the server. The server may also be communicatively coupled to computer(s) and/or device(s) that may be used to monitor and/or control robot 102 remotely. Communications unit 116 may also receive updates (e.g., firmware or data updates), data, statuses, commands, and other communications from a server for robot 102.
In exemplary embodiments, operating system 110 may be configurable to manage memory 120, controller 118, power supply 122, modules in operative units 104, and/or any software, hardware, and/or features of robot 102. For example, and without limitation, operating system 110 may include device drivers to manage hardware recourses for robot 102.
In exemplary embodiments, power supply 122 may include one or more batteries, including, without limitation, lithium, lithium ion, nickel-cadmium, nickel-metal hydride, nickel-hydrogen, carbon-zinc, silver-oxide, zinc-carbon, zinc-air, mercury oxide, alkaline, or any other type of battery known in the art. Certain batteries may be rechargeable, such as wirelessly (e.g., by resonant circuit and/or a resonant tank circuit) and/or plugging into an external power source. Power supply 122 may also be any supplier of energy, including wall sockets and electronic devices that convert solar, wind, water, nuclear, hydrogen, gasoline, natural gas, fossil fuels, mechanical energy, steam, and/or any power source into electricity.
One or more of the units described with respect to
As used here on out, a robot 102, a controller 118, or any other controller, processing device, or robot performing a task illustrated in the figures below comprises a controller executing computer readable instructions stored on a non-transitory computer readable storage apparatus, such as memory 120, as would be appreciated by one skilled in the art.
Next referring to
The algorithms executed by the processing device 130 are discussed in further detail below. The receiver 126 as shown in
One of ordinary skill in the art would appreciate that the architecture illustrated in
The cloud server 202 may utilize the data received by the signal 218 from the robot 102-1 to perform a task, calculate a value, localize the object 210, update a persistent map, and/or any other function of which data from the signal 218 may be utilized. For example, a cloud server 202, communicatively coupled to N robots 102, may receive a signal 218 from a robot 102-1, the signal comprising localization data of an object 210 from a sensor 214. The cloud server 202 may utilize the localization data to localize the object 210 on a persistent map. The N robots 102 on the network may then receive the persistent map, comprising the location of the object 210, from the cloud server 202 wherein the N robots 102 may utilize the updated persistent map during future navigation near the object 210, during future route planning, task selection, etc.
A plurality of parameters of the object 210 may be communicated to the cloud server 202 from the robot 102-1, including, but not limited to, size of object 210, type of object 210, color of object 210, temperature of the object 210, or any other parameter detectable by the sensor 214 of the robot 102-1. Accordingly, the cloud server 202 may communicate these additional parameters to the “N” robots 102 on the network. The additional parameters may be useful to the other “N” robots 102 on the network for task determination. For example, a first robot 102-1 may determine object 210 comprises a pallet, localize the object 210, and communicate the determination to the cloud server 202. The cloud server 202 may then communicate the determination of the pallet and its location to a plurality of other robots 102 on a network communicatively coupled to the cloud server 202, wherein a second robot 102-2, comprising a robotic forklift, may be requested to retrieve the pallet. In the aforementioned example, the cloud server 202 may communicate the determination of the pallet to the N robots 102 by updating a persistent map of an environment of which the N robots 102 operate, as illustrated below in
According to at least one non-limiting exemplary embodiment, robots 102-1 through 102-N may comprise a plurality of the same robots or may comprise a plurality of different robots configurable to perform different tasks. One skilled in the art would appreciate that the object 210, illustrated by a box, may be illustrative of any object or feature detectable by a sensor 214 of a robot 102-1. For example, the object 210 may comprise a dirty portion of a floor (e.g., a feature of the floor where there is a spill), wherein a cloud server 202 may utilize the determination and location of the dirty portion of the floor to request a cleaning robot 102-2 to clean the dirty portion of the floor.
According to at least one non-limiting exemplary embodiment, the signal 310 received (i.e., the incoming signal) by the two robots 102-2 and 102-3 may comprise different signals if the two robots 102-2 and 102-3 comprise different robots. For example, the received signal 310 for robot 102-2 may comprise a task to be performed on the newly mapped object 312, such as retrieving the object 312 if the robot 102-2 is configurable or capable to do so, whereas the received signal 310 for the robot 102-3 may simply comprise a localization of the object 312 on the persistent map 300-2 if the robot 102-3 is not configurable to perform a task on the object 312. Thereby, making the robot 102-3 only aware of the location of the object 312 in the environment.
As illustrated in
According to at least one non-limiting exemplary embodiment, a robot 102 on the network may receive a different persistent map 300-3 (i.e., the updated persistent map) comprising a route 302 near object 312 for the robot 102 to follow in order to perform a task on the object. For example, if object 312 is a pallet, then robot 102-2 is a robotic forklift, for example. A persistent map 300-3 received by the robot 102-2 may comprise a unique route to follow to retrieve the pallet, wherein other robots 102-1 and 102-3 may receive a persistent map 300-3 not comprising the unique route near the pallet if the robots 102-1 and 102-3 are not configurable to perform a task on the pallet.
As illustrated in the above
For example, a robot 102-2, illustrated above in
The persistent mapping unit 204 may be configurable to combine the map data 402 from the N robots 102 on the network to generate a persistent map 408 of the environment. The persistent mapping unit 204 may be a portion of persistent mapping unit 204 or illustrative of a processing device 130 of a cloud network 202 executing instructions stored in a memory 132, as illustrated above in
According to at least one non-limiting exemplary embodiment, the N robots 102 on a network may comprise different robots with sensors at different heights. Accordingly, a persistent mapping unit may be further configurable to piece together a persistent map 408 in three dimensions (3D) based on the map data 402-N, received by the individual robots 102-n, comprising map data taken at different heights or elevations (e.g., different floors in a multi-story building), as illustrated below in
According to at least one non-limiting exemplary embodiment, map data 402 may comprise data to be used to update a preexisting persistent map in memory 130 of a cloud server 202. According to at least one non-limiting exemplary embodiment, each of the map data 402 blocks may be illustrative of data collected by one robot 102 at a plurality of different instances in time as the robot 102 navigates through an environment collecting the map data 402.
According to at least one non-limiting exemplary embodiment, the plurality of map data 402 blocks may be collected by a single robot 102 in a training mode, wherein the training mode may comprise a human operator navigating the robot 102 through an environment as the robot 102 collects data to be used to generate the map data 402.
Block 502 illustrates the persistent mapping unit 204 receiving data from at least one robot 102 on the network. The received data may comprise, for example, data relating to the localization of objects, route data, state parameter data, sensor data, and/or any other type of data of any parameter which may be measured by a robot 102 and communicated to a cloud server 202.
Block 504 illustrates the persistent mapping unit 204 determining discrepancies between a first persistent map of an environment and data collected by the at least one robot 102 on the network. The discrepancies may include, but are not limited to, localization of unmapped objects, changes within an environment not mapped on the first persistent map, and/or any other discrepancy between the received data from the robots 102 and the first persistent map. For example, a robot 102 may detect and localize an object along a route, as illustrated in
According to at least one non-limiting exemplary embodiment, a first persistent map of an environment may be blank prior to a robot 102 navigating the environment and collecting data from sensor units 114 of the robot 102, wherein discrepancies between the first (blank) persistent map and data collected by the robot 102 may comprise any data collected by the robot 102.
Block 506 illustrates the persistent mapping unit 204 generating a second persistent map based on the determined discrepancies in block 504. The second persistent map may comprise, for example, newly localized objects, changes in positions of objects, and/or changes in parameters of objects or an environment. The second persistent map may comprise a persistent map of the first persistent map at a second instance in time. The discrepancies may be used to determine static and dynamic objects as well as determine if a robot 102 requires calibration to its sensor units 114, as illustrated below in
Block 508 illustrates the persistent mapping unit 204 utilizing communications unit 206 of the cloud server 202, as illustrated in
Block 602 illustrates the controller 118 of the robot 102 receiving an instruction from the cloud server 202. The instruction may be transmitted from the cloud server 202 utilizing a transmitter 134 and received by the robot 102 by communications units 116, as illustrated above in
Block 604 illustrates the controller 118 of the robot 102 performing a task based on the received instruction. The task may comprise a robot 102 navigating to a location, collecting sensor data, detecting objects, and/or other tasks performable by a robot 102.
According to at least one non-limiting exemplary embodiment, the received instruction may comprise a high-level task, wherein the controller 118 of the robot 102 may abstract upon the high-level task to perform a plurality of lower level tasks to accomplish the high-level task of the received instruction. For example, an instruction from a cloud server 202 may include a robot 102 collecting object data of objects at a location on a persistent map of an environment. A controller 118 of the robot 102 may abstract upon the high-level task (e.g., collecting data of the objects) by first navigating the robot 102 to the location of the objects and then collecting the object data requested by the received instruction.
Block 606 illustrates the controller 118 of the robot 102 transmitting data collected during the performed task. The transmitted data may comprise data of which the received instruction requested or data comprising a completion of a task based on the received instruction (e.g., a binary output from the robot 102). The cloud server 202, upon receiving the transmitted data, may, for example, update a persistent map based on the transmitted data or perform operations based on the data (e.g., localization of an object) to respond to a user query, as illustrated below in
The operator input 704 may comprise, for example, an interface unit configurable to receive input from an operator and communicate the input to the cloud server 202. The operator input 704 may comprise a query for data of one or more persistent maps 706 stored in a memory 132 (not shown) of the cloud server 202. The operator input 704 may be abstracted into a plurality of functions to be performed by the cloud server 202 based on the operator input 704. The abstraction of the operator input may be performed by the processing device 130 of the cloud server 202 executing specialized instructions stored in memory 132 (not shown), as illustrated above in
By way of an illustrative example, an operator may input a request for a cloud server 202 to determine which air conditioning vents in an environment are operating efficiently. To determine which air conditioning vents are operating efficiently, the operator input 704 may be abstracted into a request for a persistent heat map of an environment (function 1), a persistent map of air conditioning vents within the environment (function 2), and a determination by the processing device 130 of the cloud server 202 of which air conditioning vents operate efficiently (function 3) based on data of the two persistent maps.
The robot network 708 may comprise N robots 102, index N being a non-zero integer number, wherein the N robots 102 on the network 708 may comprise a plurality of identical robots 102 or different robots 102 configurable to perform different tasks. The robots 102 on the robot network 708 may be configurable to receive an instruction from the processing device 130 of the cloud server 202 and distribute lower level tasks to the plurality of robots 102 to fulfill the instruction. The lower level tasks may require the robots 102 of the robot network 708 to collect data on a parameter of an environment. The parameters may include, but are not limited to, heat measurements, LTE (long term evolution) signal strength measurements, Wi-Fi signal strength measurement, and/or any other measurement to be collected by the distributed network of robots, wherein the collected measurement data may be used by the robot network 708 to fulfill the instruction from the cloud server 202. Stated another way, the operator input 704 is divided into plurality of functions 702-1 to 702-I, which are received by the processing device 130 in the cloud server 212. The processing device 130, upon receipt of these plurality of functions 702-1 to 702-I, transmits them, at least in part, to a robot network 708 comprising plurality of robots 102-1 to 102-N such that a respective one or more of the plurality of robots 102-1 to 102-N may perform or execute a respective function assigned to it, and accordingly transmit the data collected back to the processing device 130. Each robot 102-1 to 102-N of the network 708 may execute the same, similar, or different movements, measurements, or computer instructions as other robots 102 of the network 708 to acquire the necessary data, which, collectively, may be used to respond to the operator input 704. The processing device 130 thereafter compiles the data received and generates an operator output 710, which may be displayed, e.g., on a graphic user interface for the operator.
Following the above example, wherein a determination of which air conditioning vents are operating efficiently is requested by an operator input 704, the robot network 708 may distribute tasks of mapping and measuring heat distribution data and air conditioning vents designated locations to each of the plurality of robots 102 on the network. The robot network 708, upon fulfillment of the received instruction, may communicate with the processing device 130 of the cloud server 202 any data requested by the received instruction.
The functions of the robot network 708 block, as illustrated, may be performed by the processing device 130 of the cloud server 202, wherein the robot network 708 block as illustrated may be illustrative of the processing device 130 of the cloud server 202 executing computer readable instructions from a memory 132 (not shown) to distribute lower level tasks to a plurality of robots 102 to fulfill an instruction. In other words, the processing device 130 may delegate the lower level tasks to the individual robots 102 on the network 708 required to fulfill an instruction, the instruction being generated based on the plurality of functions 702 to be performed by the robot network 708 in response to the operator input 704.
The processing device 130 of the cloud server 202 may utilize data collected by the robot network 708 to generate or update a plurality of persistent maps 706. The persistent maps 706 may be stored in a memory 132 (not shown) of the cloud server 202, as illustrated above in
According to at least one non-limiting exemplary embodiment, an operator may comprise a robot 102 on a robot network 708 communicatively coupled to a cloud server 202. For example, a robot 102 may input a request for a persistent map of no-go zones, illustrated below in
According to at least one non-limiting exemplary embodiment, the plurality of persistent maps 706 illustrated in
The system 700 illustrates a distributed system of data gathering by a plurality of robots 102 on a robot network 708 based on an instruction received from a cloud server 202, the instruction may be generated based on an operator input 704. The distributed system of data gathering by the plurality of robots 102 on the robot network 708 may enhance the ability of the processing device 130 of the cloud server 202 to generate a plurality of persistent maps 706 simultaneously, rapidly, and in real-time based on the data from the distributed plurality of robots 102. The distributed network of robots 102 may generate the plurality of persistent maps 706 rapidly as mapping data from each individual robot 102 in the robot network 708 may be pieced together to form the plurality of persistent maps 706, as illustrated above in
Block 802 illustrates the processing device 130 receiving a query from an operator. The query may comprise a request for one or more persistent maps of one or more corresponding parameters (e.g., heat map, LTE signal strength map, etc.) or a request for data based on one or more persistent maps.
Block 804 illustrates the processing device 130 abstracting the query into individual functions, the functions may be lower level abstractions of operations required to respond to the query, as illustrated above in
Block 806 illustrates the processing device 130 determining if any of the individual functions, determined in block 804, require persistent map data from at least one robot 102 on a robot network comprising a plurality of robots 102. The cloud server 202 may comprise a plurality of persistent maps stored in a memory 132 generated previously due to, for example, prior queries. However, the query may require the use of a persistent map of a parameter not mapped prior to the query or use of a persistent map requiring updates based on new data collected by the plurality of robots 102.
If the memory 132 does not comprise enough persistent map data to respond to the query, the processing device 130 may move to block 808. In other words, if the processing device 130 determines that the individual functions do require persistent map data from at least one robot on a robot network which is not available to the processing device 130 (e.g., was not measured, is not temporally accurate, etc.), the processing device 130 then moves to block 808, which, in-turn, generates an instruction for the robot network.
If the memory 132 comprises enough persistent map data to respond to the query, the processing device 130 may move to block 812. In other words, if the processing device 130 determines that the individual functions do not require additional persistent map data, and inquiry of the individual functions can be satisfied based on the persistent map data already stored in memory 132, then the processing device 130 simply generates a response to the individual instruction based on the persistent map data present in the memory 132. Therefore, not requiring robot network to generate additional persistent map data as it would have under step 808.
Block 808 illustrates the processing device 130 generating an instruction for the robot network, the instruction may configure the robot network to gather persistent map data using sensor units 114 of one or more robots 102 on the network, the persistent map data may be gathered using the method 600 illustrated above in
Block 810 illustrates the processing device 130 receiving persistent map data from the robot network, as requested by the instruction generated in block 808. The received persistent map data may comprise updates to existing persistent maps of parameters stored in the memory 132 or may comprise data used to generate one or more new persistent maps of one or more corresponding parameters. The received persistent map data may further comprise persistent map data of one or more parameters at one or more new locations not previously mapped in existing persistent maps stored in memory 132. The processing device 130 may store the received persistent map data in memory 132.
Block 812 illustrates the processing device 130 generating a response to the query based on persistent map data. The response may comprise, for example, one or more persistent maps of one or more parameters, a correlation between two or more persistent maps (e.g., a correlation between a persistent heat map and a persistent air conditioning vent map for determining which air conditioning vent operates efficiently), and/or data from a persistent map of a parameter (e.g., locations of no-go zones for robots on a robot network).
Block 814 illustrates the processing device 130 outputting the response to the operator. The processing device 130 may output the response to a user interface communicatively coupled to the cloud server 202.
According to at least one non-limiting exemplary embodiment, an operator may include a robot 102 providing a query to a cloud server 202. For example, a cleaning robot may query a cloud server 202 to determine locations of floors to clean, wherein the cloud server 202 may utilize the method 800 to respond to the query of the cleaning robot.
According to at least one non-limiting exemplary embodiment, the robot 102 may navigate along routes mapped on a separate persistent route map, similar to the map illustrated above in
According to at least one non-limiting exemplary embodiment, heat zone 904-3 may be cooler than heat zone 904-2, and so forth. In other words, the heat map 900 may map zones of low temperature, such as, for example, due to air conditioning vents cooling the air within the respective heat zones 904.
According to at least one non-limiting exemplary embodiment, a plurality of robots 102 equipped with heat sensors 906 may be utilized by a cloud server 202 to collect heat distribution data to be communicated to the cloud server 202 to generate a persistent heat map 900 of an environment.
One skilled in the art would appreciate that the heat sensor 906 as illustrated may be replaced with a plurality of different sensors configurable to measure different parameters of the environment. For example, alternatively, the sensor 906 may be a Wi-Fi sensor configurable to measure Wi-Fi signal strength within the environment, wherein a cloud server 202 may utilize the Wi-Fi signal strength data collected by the sensor 906 to map regions of strong, medium, and weak WiFi signal strength zones.
A cloud server 202 may provide the robot 102 with the persistent no-go zone map 908 to enable the robot 102 to navigate around the no-go zones 916 while determining a route 914 from the start point 910 to the end point 912. According to at least one non-limiting exemplary embodiment, route 914 may be determined from the cloud server 202 and communicated to the robot 102.
One skilled in the art would appreciate that the zones 916 may be illustrative of different types of zones other than no-go zones. For example, zones 916 may be illustrative of surfaces of a floor for a cleaning robot 102 to navigate to and clean. These cleaning zones may be determined by the cloud server 202 based on data collected by one or more robots 102, other external devices (e.g., user interfaces, CCTV, etc.), and/or other similar methods.
Processing device 130 of a cloud server 202 may impose movement thresholds 1008 used to determine if the objects 1006 are dynamic or moving objects. The movement thresholds 1008 may be used by the processing device 130 to determine if a respective object is dynamic (i.e., moving object) or non-dynamic (i.e., stationary or static object). A dynamic or moving object may be determined if an object exceeds a movement threshold 1008 imposed around the object within a predetermined period of time, as illustrated next in
One skilled in the art would appreciate that the static objects 1002 may have been determined by a cloud server 202 to be static objects using substantially similar methods illustrated in
According to at least one non-limiting exemplary embodiment, robots 102 illustrated in
According to at least one non-limiting exemplary embodiment, a robot 102 may observe an object 1002, known to be a static object, at a different location than previously mapped on persistent map 1000 at prior instances in time. A cloud server 202, communicatively coupled to the robot 102, may determine one or more sensor units 114 of the robot 102 require further calibration as the cloud server 202 may determine, based on observing the object 1002 at the same location at a plurality of prior instances in time, data received by the robot 102 may be generated from uncalibrated sensors (e.g., uncalibrated distance measuring sensors). The cloud server 202 may determine the object 1002 comprises a static object based on their location remaining constant in time (e.g., within 2% error) as observed by a plurality of robots 102 or the same robot 102 at a plurality of prior instances in time. Determining sensor units 114 of a first robot 102 require calibration may further include a cloud server 202 utilizing a second robot 102 to verify the static objects are in the same location, thereby verifying the sensor units 114 of the first robot 102 require calibration.
Advantageously, mapping of dynamic or moving objects may further enhance the ability of a cloud server 202 to effectuate the control of robots 102 coupled to the cloud server 202 by, for example, navigating the robots 102 around or away from the moving objects. Additionally, designating objects as static objects may further enable the cloud server 202 to determine if sensor units 114 of a robot 102, coupled to the cloud server 202, require calibration based on the robot 102 observing a location of the known static object to be at a different location as previously mapped on a persistent map at prior instances in time.
The persistent map 1100 may comprise a plurality of layers 1102 at different heights. For example, one or more robots 102 may utilize one or more respective LiDAR sensors to localize surfaces of objects at different heights. Each of the layers 1102 may comprise an object intersection 1106 corresponding to a region occupied by an object at the height of the corresponding layer 1102. As illustrated by dashed lines 1104, the objects intersecting the layers 1102 may comprise a trapezoidal shape; however, any object with a non-zero height may intersect the layers 1102 differently. A cloud server 202 may store the 3D persistent map 1100 as a plurality of layers at set heights comprising object intersections 1106 or may store the 3D persistent map 1100 as a computer assisted design (CAD) model of an environment in memory 132 of the cloud server 202. That is, two dimensional measurements (e.g., from LiDAR sensors) collected by one or more sensor units 114 may be composited to generate a three dimensional model of an object.
According to at least one non-limiting exemplary embodiment, a 3D (three-dimension) persistent map 1100 may be a persistent map of a parameter other than the localization of objects as illustrated. For example, the persistent heat map 900 illustrated above in
Advantageously, generation of a 3D persistent map 1100 may enhance the ability for different robots 102 of different heights to operate within the same environment using the same 3D persistent map 1100. According to at least one non-limiting exemplary embodiment, a cloud server may distribute a 3D persistent map 1100 to a robot 102 which may be configurable to collect sensor data of objects below a certain height, wherein the 3D persistent map 1100 passed to the robot 102 may not comprise mapped objects above the height of which the robot 102 can observe with its sensor units 114. Passing a 3D persistent map 1100 cut off at a height may save space in memory 120 of the robot 102 as the robot 102 may not need 3D map data above the height of which the robot 102 can observe.
One skilled in the art would appreciate that any of the persistent maps illustrated in the above figures (e.g., persistent maps 300, 900, 908, and 1000) may comprise 3D persistent maps of a corresponding parameter, wherein the persistent maps illustrated may be illustrative of a single layer of the persistent maps.
According to example embodiments disclosed herein, they are directed to systems, methods and non-transitory computer readable media wherein at least one processing device is configurable to execute computer readable instructions to generate a map of a parameter corresponding to an environment based on data collected by a respective device of a plurality of devices, the map being generated based on measurements of the parameter using a sensor coupled to the respective device and a position of the respective device, the measurements occurring at a first time instance; determine whether to update the map based on data transmitted by the respective device during a second time instance; and update the map to incorporate the data transmitted during the second time instance if the data transmitted during the second time instance includes information not incorporated in the map during the first time instance.
Further, the at least one processing device is configurable to execute the computer readable instructions to determine at least one object in the environment to be either a dynamic object or a static object based on discrepancies between the map at the first time instance and the map at the second time instance, the dynamic object is determined based on a predetermined movement threshold; and update the map at a later time instance to include the dynamic and static objects. And, determine the at least one object is a dynamic object if the at least one object exceeds a movement threshold imposed around the at least one object within a predetermined period of time; and determine if at least one sensor on the respective device requires calibration based on the respective device detecting the static object at a location different from a location on the map at the second time instance.
The systems, methods, and non-transitory computer readable media of example embodiments according to this disclosure require at least one processing device configurable to execute the computer readable instructions to receive a query from an operator, the query comprising a request for the data received at the first and second time instances, and respond to the query based on the data collected by the plurality of devices during the first and second time instances, the plurality of devices corresponds to a network of plurality of robots. And, further receive at least one instruction from the operator for the plurality of robots, the instruction including individual tasks to be executed by each one of a respective robot in the network of the plurality of roots in the environment.
It will be recognized that, while certain aspects of the disclosure are described in terms of a specific sequence of steps of a method, these descriptions are only illustrative of the broader methods of the disclosure and may be modified as required by the particular application. Certain steps may be rendered unnecessary or optional under certain circumstances. Additionally, certain steps or functionality may be added to the disclosed embodiments, or the order of performance of two or more steps permuted. All such variations are considered to be encompassed within the disclosure disclosed and claimed herein.
While the above detailed description has shown, described, and pointed out novel features of the disclosure as applied to various exemplary embodiments, it will be understood that various omissions, substitutions, and changes in the form and details of the device or process illustrated may be made by those skilled in the art without departing from the disclosure. The foregoing description is of the best mode presently contemplated of carrying out the disclosure. This description is in no way meant to be limiting, but rather should be taken as illustrative of the general principles of the disclosure. The scope of the disclosure should be determined with reference to the claims.
While the disclosure has been illustrated and described in detail in the drawings and foregoing description, such illustration and description are to be considered illustrative or exemplary and not restrictive. The disclosure is not limited to the disclosed embodiments. Variations to the disclosed embodiments and/or implementations may be understood and effected by those skilled in the art in practicing the claimed disclosure, from a study of the drawings, the disclosure and the appended claims.
It should be noted that the use of particular terminology when describing certain features or aspects of the disclosure should not be taken to imply that the terminology is being re-defined herein to be restricted to include any specific characteristics of the features or aspects of the disclosure with which that terminology is associated. Terms and phrases used in this application, and variations thereof, especially in the appended claims, unless otherwise expressly stated, should be construed as open ended as opposed to limiting.
As examples of the foregoing, the term “including” should be read to mean “including, without limitation,” “including but not limited to,” or the like; the term “comprising” as used herein is synonymous with “including,” “containing,” or “characterized by,” and is inclusive or open-ended and does not exclude additional, unrecited elements or method steps; the term “having” should be interpreted as “having at least”; the term “such as” should be interpreted as “such as, without limitation”; the term ‘includes” should be interpreted as “includes but is not limited to”; the term “example” is used to provide exemplary instances of the item in discussion, not an exhaustive or limiting list thereof, and should be interpreted as “example, but without limitation”; adjectives such as “known,” “normal,” “standard,” and terms of similar meaning should not be construed as limiting the item described to a given time period or to an item available as of a given time, but instead should be read to encompass known, normal, or standard technologies that may be available or known now or at any time in the future; and use of terms like “preferably,” “preferred,” “desired,” or “desirable,” and words of similar meaning should not be understood as implying that certain features are critical, essential, or even important to the structure or function of the present disclosure, but instead as merely intended to highlight alternative or additional features that may or may not be utilized in a particular embodiment. Likewise, a group of items linked with the conjunction “and” should not be read as requiring that each and every one of those items be present in the grouping, but rather should be read as “and/or” unless expressly stated otherwise. Similarly, a group of items linked with the conjunction “or” should not be read as requiring mutual exclusivity among that group, but rather should be read as “and/or” unless expressly stated otherwise. The terms “about” or “approximate” and the like are synonymous and are used to indicate that the value modified by the term has an understood range associated with it, where the range may be ±20%, ±15%, ±10%, ±5%, or ±1%. The term “substantially” is used to indicate that a result (e.g., measurement value) is close to a targeted value, where close may mean, for example, the result is within 80% of the value, within 90% of the value, within 95% of the value, or within 99% of the value. Also, as used herein, “defined” or “determined” may include “predefined” or “predetermined” and/or otherwise determined values, conditions, thresholds, measurements, and the like.
This application is a continuation of International Patent Application No. PCT/US19/56476 filed Oct. 16, 2019 and claims the benefit of U.S. Provisional patent Application Ser. No. 62/746,390 filed on Oct. 16, 2018 under 35 U.S.C. § 119, the entire disclosure of each are incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
62746390 | Oct 2018 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/US19/56476 | Oct 2019 | US |
Child | 17231613 | US |