NON-DESTRUCTIVE KIT MOUNTING SYSTEM FOR DRIVERLESS INDUSTRIAL VEHICLES

Information

  • Patent Application
  • 20210247493
  • Publication Number
    20210247493
  • Date Filed
    February 22, 2021
    3 years ago
  • Date Published
    August 12, 2021
    3 years ago
Abstract
A system comprising a sensor, a protective enclosure configured to enclose the sensor, a mounting pad configured to be attached to a location of a vehicle, the mounting pad having a contact area as a function of a weight of the sensor and the protective enclosure, a processor coupled to the sensor, the processor configured to associate the sensor with the location of the vehicle and wherein the sensor and the protective enclosure are attached to the mounting pad, and the mounting pad is attached to the surface of the vehicle using an adhesive layer.
Description
TECHNICAL FIELD

The present disclosure relates generally to vehicle control, and more specifically to non-destructive kit mounting system for driverless industrial vehicles.


BACKGROUND OF THE INVENTION

Driverless vehicles are becoming more and more common in everyday life.


SUMMARY OF THE INVENTION

A system comprising a sensor, a protective enclosure configured to enclose the sensor, a mounting pad configured to be attached to a location of a vehicle is disclosed. The mounting pad has a contact area as a function of a weight of the sensor and the protective enclosure. A processor coupled to the sensor is configured to associate the sensor with the location of the vehicle. The sensor and the protective enclosure are attached to the mounting pad, and the mounting pad is attached to the surface of the vehicle using an adhesive layer


Other systems, methods, features, and advantages of the present disclosure will be or become apparent to one with skill in the art upon examination of the following drawings and detailed description. It is intended that all such additional systems, methods, features, and advantages be included within this description, be within the scope of the present disclosure, and be protected by the accompanying claims.





BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS

All sensors and vehicles mentioned and shown in the following paragraphs and diagrams are specific examples shown to explain concept and design. The idea and design of the following enclosures, pads, and mounts are able to span across all sensors and industrial vehicles, not just specifically the ones mentioned.


Aspects of the disclosure can be better understood with reference to the following drawings. The components in the drawings may be to scale, but emphasis is placed upon clearly illustrating the principles of the present disclosure. Moreover, in the drawings, like reference numerals designate corresponding parts throughout the several views, and in which:



FIG. 1 is a diagram of an isometric view of the universal front sensor enclosure, in accordance with an example embodiment of the present disclosure;



FIG. 2 is a diagram of an isometric view of the universal side sensor enclosure, in accordance with an example embodiment of the present disclosure;



FIG. 3 is a diagram of an isometric view of the front mounting pad, in accordance with an example embodiment of the present disclosure;



FIG. 4 is a diagram of an isometric view of the side mounting pad, in accordance with an example embodiment of the present disclosure;



FIG. 5 is a diagram of an isometric view of the front mounting pad, in accordance with an example embodiment of the present disclosure;



FIG. 6 is a diagram of an isometric view of the side mounting pad, in accordance with an example embodiment of the present disclosure;



FIG. 7 is a diagram of an isometric view of the Crown PC4500 bumper assembly with all sensors mounted using their corresponding enclosures and mounting pads, in accordance with an example embodiment of the present disclosure;



FIG. 8 is a diagram of an isometric view of the Raymond 8510 bumper assembly with all sensors mounted using their corresponding enclosures and mounting pads, in accordance with an example embodiment of the present disclosure;



FIG. 9 is a diagram of an isometric view of a simple universal adhesive mounting system assembly, in accordance with an example embodiment of the present disclosure;



FIG. 10 is a diagram of a side view of a simple universal adhesive mounting system assembly, in accordance with an example embodiment of the present disclosure;



FIG. 11 is a diagram of various lift truck types, in accordance with an example embodiment of the present disclosure;



FIG. 12 shows a block diagram of exemplary retrofit kit components and how they are interconnected for the purposes of sharing data;



FIG. 13 is a diagram of an example embodiment of retrofit kit components as mounted on a center rider pallet jack type lift truck;



FIG. 14 is a flow chart of an algorithm of a mapping process, in accordance with an example embodiment of the present disclosure;



FIG. 15 is a diagram of a system that uploads sensor data to a remote server to train artificial intelligence models in one exemplary embodiment;



FIG. 16 is a flow chart of an algorithm for automatic docking process for charging, in accordance with an example embodiment of the present disclosure;



FIG. 17 is a diagram of an exemplary obstacle zone detection system;



FIG. 18 is a diagram of a system for allowing a remote operator can control a lift truck via a wireless link;



FIG. 19 is a diagram of an algorithm for controlling a vehicle, in accordance with an example embodiment of the present disclosure;



FIG. 20 is a diagram of an algorithm for controlling a vehicle, in accordance with an example embodiment of the present disclosure;



FIG. 21 is a diagram of a system, in accordance with an example embodiment of the present disclosure;



FIG. 22 is a diagram of a garment, which includes one or more unique patterns on the front and one or more unique patterns on the rear;



FIG. 23 is a diagram of a flow chart of an example algorithm that can be implemented in hardware and/or software for system control and operation;



FIG. 24 is a diagram of a flow chart of an example algorithm that can be implemented in hardware and/or software for the visual training process;



FIG. 25 is a diagram of a lift truck following an order picker and maintaining a set distance from the order picker;



FIG. 26 is a diagram of a lift truck following an order picker and avoiding an obstacle on the way; and



FIG. 27 is a flow chart of an example algorithm that can be implemented in hardware and/or software for the replanning process when an obstacle is detected.





DETAILED DESCRIPTION OF THE INVENTION

In the description that follows, like parts are marked throughout the specification and drawings with the same reference numerals. The drawing figures may be to scale and certain components can be shown in generalized or schematic form and identified by commercial designations in the interest of clarity and conciseness.


There has been a push for autonomous vehicles in the industrial setting to reduce human error and to increase productivity. These vehicles can range from pallet trucks, forklifts and tuggers to industrial cleaners and more. In order for these autonomous vehicles to navigate their surroundings they must be equipped with various pieces of equipment, from sensors to computer hardware. This equipment should be mounted securely to and accurately located on the vehicle they are serving. The mounting process can be destructive to the vehicle when classic forms of fasteners are used, such as nuts and bolts, and it can be difficult to scale the mounting method across a large variety of vehicles with different body styles and sizes.


When using such traditional forms of fasteners, the mounting hardware typically needs to be custom made for the particular vehicle it is on. Customization increases the time and money required to design and manufacture the vehicles. These traditional fasteners can also require large holes to be drilled into the body of the vehicle. In addition to the time and energy it takes to drill these holes, doing so can be risky. For example, if a hole is not drilled correctly the first time, the vehicle can be rendered useless until the hole is repaired or the damaged part is replaced.


Old forms of fasteners can also make a retrofitting process complicated and time consuming, if an existing vehicle is retrofitted to install automation controls. When retrofitting a vehicles with such equipment, it is desirable for the hardware to be mounted quickly, accurately and with ease. The present disclosure provides a quick, easy and accurate way to mount hardware to a wide variety of vehicles without causing damage to those vehicles.


A universal non-destructive adhesive based mounting system is disclosed for the purpose of retrofitting existing industrial vehicles with driverless technology. By using a strong industrial adhesive tape and a universalized mounting system, the autonomous kit can be mounted to any suitable industrial vehicle with ease, accuracy, and without damaging the vehicle, unlike traditional methods. In one example embodiment, the mounting system can include a mounting pad, a protective enclosure and industrial adhesive tape, and can utilize off the shelf sensors, autonomous driving equipment (such as sensors, computers and so forth) and their accompanying mounting hardware. The disclosed mounting process can be installed in the field or in a shop setting or in other suitable manners.



FIG. 1 is a diagram of an isometric view of universal front sensor enclosure 100, in accordance with an example embodiment of the present disclosure. Enclosure 100 includes mounting tabs 101, access holes 102 and viewing window 103, and can be used to house a safety laser sensor, such as a SICK Microscan 3 Sensor, available from SICK, Inc. of Houston Tex., or other suitable sensors.


Enclosure 100 can be configured to allow the corresponding sensor to be mounted to a suitable industrial vehicle when paired with a mounting pad, such as mounting 300 or mounting pad 500 shown herein below. Enclosure 100 can be made from a suitable type of sheet metal, such as aluminum or steel, or other suitable materials. The sheet metal can be easily cut and bent into shape using various manufacturing methods. Enclosure 100 can fit around the sensor and protect it on three sides, front, left, and right. Enclosure 100 can be mounted to a front mounting pad, in the two cases given: mounting pad 300 and mounting pad 500. Enclosure 100 can be mounted to the mounting pad using the mounting tabs 101. Tabs 101 can align with threaded holes located on the front mounting pad 300 or 500. Screws can be used to attach the enclosure 100 to the mounting pad 300 or 500. The sensor sits inside the front enclosure 100 and is then mounted to the front mounting pad using the manufacturer's mounting brackets. These mounting brackets can be adjusted using screws to manipulate the tilt of the sensor. In order to access these adjustment screws, access holes 102 can be provided to the front enclosure 100 to allow the necessary tools to reach the adjustment screws. In order for a user to have a clear view of the sensor, a viewing window 103 can be added to the front enclosure 100. This viewing window 103 is slightly larger than the vision window of the sensor to allow sufficient clearance of the laser.



FIG. 2 is a diagram of an isometric view of the universal side sensor enclosure 200, in accordance with an example embodiment of the present disclosure. Enclosure 200 can be configured to house a laser sensor, such as a SICK TIM Sensor or other suitable sensors, when paired with a mounting pad, such as 400 or 600. Enclosure 200 can be made from a suitable type of sheet metal, such as aluminum or steel, or other suitable materials. The sheet metal can be easily cut and bent into shape using various manufacturing methods. Enclosure 200 can fit around the sensor and protects it on three sides, front, left, and right. Enclosure 200 can be mounted to the side mounting pad, in the two cases given: pads 400 and 600. Enclosure 200 can be mounted to the mounting pad using the mounting tabs 201 or in other suitable manners. Tabs 201 can align with threaded holes located on the side mounting pad 400 or 600. Screws can then be used to attach the enclosure 200 to the mounting pad 400 or 600. The sensor can sit inside the side enclosure 200 and can then mounted to the side mounting pad using the manufacturer's mounting brackets. These mounting brackets can be adjusted using screws to manipulate the tilt of the sensor. In order to access these adjustment screws, access holes 202 can be added to the side enclosure 200 to allow the necessary tools to reach the adjustment screws. In order to provide a clear view of the sensor, a viewing window 203 can be added to the side enclosure 200. This viewing window 203 can be slightly larger than the vision window of the sensor to allow sufficient clearance of the laser.



FIG. 3 is a diagram of an isometric view of the front mounting pad 300, in accordance with an example embodiment of the present disclosure. Mounting pad 300 can be configured to mount the front sensor enclosure 100 and corresponding sensor to the front of a suitable industrial vehicle, such as a Crown PC4500 pallet truck or other suitable vehicles.


Mounting pad 300 can be used as an adapter to mount the front sensor, such as a SICK Microscan 3, to the front bumper 701 of the lift truck. This mounting pad can be machined from a suitable material, such as plastics or metals, depending on the sensor and application it is configured for. The curved side 301 of the mounting pad 300 can be configured for the shape of the front bumper 701 of the Crown PC4500 lift truck or in other suitable manners. In this example embodiment, the contour can fit snuggly against the bumper with the adhesive tape between the two surfaces. In order to fit the contour of mounting pad 300 to front bumper 701, measurements of the specific point on the bumper where mounting pad 300 will be installed can be taken with a 3D scanner accompanied with a contour gauge, such as a such as a General Tools 833 Plastic Contour Gauge available from General Tools & Instruments, 75 Seaview Drive, Secaucus, N.J. 07094. From these measurements, a 3D CAD model can be made to reflect the measured contour, or other suitable processes can also or alternatively be used. A prototype can then be created and modified, if needed. Once the proper contour is found, a 3D CAD model of the mounting pad can be generated and the curved surface of the final mounting pad can be manufactured created using computer numerical control machining or other suitable processes.


The threaded mounting holes 302 can be used to attach the protective sensor enclosure 100 and the sensor mounting brackets to the mounting pad using screws. The thickness of the mounting pad can be configured so that the screws being used have a proper thread depth for strength. Other suitable embodiments can also or alternatively be used. Mounting pad 300 can include a planar outer surface having the plurality of threaded mounting holes 302 and a curved inner surface having the curved side, so as to allow the sensor and sensor housing to be attached to a planar surface while allowing the mounting pad 300 to be attached to a non-planar surface.


In one example, mounting pad 300 can be configured to have a contact surface area that corresponds to a weight of a sensor and housing that will be attached to mounting pad 300. In this example embodiment, the weight of the sensor and housing can be used to determine the contact area as a function of the properties of the adhesive material that is used to secure mounting pad 300 to the surface of the vehicle. In this example, mounting pad 300 can have an associated weight rating, where the sensor and housing that are to be used with mounting pad 300 can be matched, to allow the sensor and housing to be secured to mounting pad 300 without damaging the surface of the vehicle while avoiding an excessive loading on mounting pad 300 that could cause the adhesive to fail.



FIG. 4 is a diagram of an isometric view of the side mounting pad 400, in accordance with an example embodiment of the present disclosure. Side mounting pad 400 can be configured to mount the side sensor enclosure 200 and corresponding sensor to the front of a suitable industrial vehicle, such as a Crown PC4500 pallet truck or other suitable vehicles.


Side mounting pad 400 can be used to mount the side sensor, such as a SICK TIM series sensor, to a front bumper 701 of the lift truck or to other suitable vehicle parts or other suitable vehicles. Side mounting pad 400 can be machined from a suitable material, such as plastics and metals, depending on the sensor and application it is configured for. The curved side 401 of the mounting pad 400 can be configured specifically for the shape of the side of the front bumper 701 of the Crown PC4500 lift truck. The contour can be adapted so that it fits against the bumper with the adhesive tape between the two surfaces. The threaded mounting holes 402 can be used to attach the protective sensor enclosure 200, the mounting arms 702, and the sensor mounting brackets to the mounting pad using screws. The thickness of the mounting pad can be configured so that the screws being used have a proper thread depth for strength. Mounting pad 400 can include a planar outer surface having the plurality of threaded mounting holes 402 and a curved inner surface having the curved side, so as to allow the sensor and sensor housing to be attached to a planar surface while allowing the mounting pad 400 to be attached to a non-planar surface.


In one example, mounting pad 400 can be configured to have a contact surface area that corresponds to a weight of a sensor and housing that will be attached to mounting pad 400. In this example embodiment, the weight of the sensor and housing can be used to determine the contact area as a function of the properties of the adhesive material that is used to secure mounting pad 400 to the surface of the vehicle. In this example, mounting pad 400 can have an associated weight rating, where the sensor and housing that are to be used with mounting pad 400 can be matched, to allow the sensor and housing to be secured to mounting pad 400 without damaging the surface of the vehicle while avoiding an excessive loading on mounting pad 400 that could cause the adhesive to fail.



FIG. 5 is a diagram of an isometric view of the front mounting pad 500, in accordance with an example embodiment of the present disclosure. Front mounting pad 500 can be configured to mount the front sensor enclosure 100 and corresponding sensor to the front of a suitable industrial vehicle, such as a Raymond 8510 pallet truck.


The front mounting pad 500 can be used to be the adapter to mount the front sensor, in this case a SICK Microscan 3, to the front bumper 801 of the lift truck. The mounting pad can be machined from a suitable material, including plastics or metals, depending on the sensor and application it is configured for. The curved side 501 of the mounting pad 500 can be configured specifically for the shape of the front bumper 801 of the Raymond 8510 lift truck or other suitable vehicles or components. The contour can fit against the bumper with the adhesive tape between the two surfaces. The threaded mounting holes 502 can be used to attach the protective sensor enclosure 100 and the sensor mounting brackets to the mounting pad using screws. The thickness of the mounting pad can be configured so that the screws being used have a proper thread depth for strength, and can be associated with different sensor and sensor housings that have an acceptable weight. Mounting pad 500 can include a planar outer surface having the plurality of threaded mounting holes 502 and a curved inner surface having the curved side, so as to allow the sensor and sensor housing to be attached to a planar surface while allowing the mounting pad 500 to be attached to a non-planar surface.


In one example, mounting pad 500 can be configured to have a contact surface area that corresponds to a weight of a sensor and housing that will be attached to mounting pad 500. In this example embodiment, the weight of the sensor and housing can be used to determine the contact area as a function of the properties of the adhesive material that is used to secure mounting pad 500 to the surface of the vehicle. In this example, mounting pad 500 can have an associated weight rating, where the sensor and housing that are to be used with mounting pad 500 can be matched, to allow the sensor and housing to be secured to mounting pad 500 without damaging the surface of the vehicle while avoiding an excessive loading on mounting pad 500 that could cause the adhesive to fail.



FIG. 6 is a diagram of an isometric view of the side mounting pad 600, in accordance with an example embodiment of the present disclosure. Side mounting pad 600 can be configured to mount the side sensor enclosure 200 and corresponding sensor to the front of a suitable industrial vehicle, such as a Raymond 8510 pallet truck.


Side mounting pad 600 can used as an to mount the side sensor, such as a SICK TIM 5XX series or other suitable sensors, to the side of the front bumper 801 of the lift truck. Side mounting pad 600 can be machined from a suitable material, such as plastics or metals, depending on the sensor and application it is configured for. The curved side 601 of the mounting pad 600 can configured for the shape of the side of the front bumper 801 of the Raymond 8510 lift truck or other suitable vehicles or structures. The contour can fit against the bumper with the adhesive tape between the two surfaces, or other suitable surfaces. The threaded mounting holes 602 can be used to attach the protective sensor enclosure 200, and the sensor mounting brackets to the mounting pad using screws. The thickness of the mounting pad can be configured so that the screws being used have a proper thread depth for strength or in other suitable manners. Side mounting pad 600 can include a planar outer surface having the plurality of threaded mounting holes 602 and a curved inner surface having the curved side, with a space between the outer surface and the inner surface defined by two side supports that are disposed at an angle to the planar outer surface and the curved inner surface, such as to allow the planar outer surface to be large enough to support a sensor and sensor housing, and to allow the curved inner surface to be large enough to provide sufficient contact area in conjunction with an adhesive to prevent the assembly from becoming detached.


In one example, mounting pad 600 can be configured to have a contact surface area that corresponds to a weight of a sensor and housing that will be attached to mounting pad 600. In this example embodiment, the weight of the sensor and housing can be used to determine the contact area as a function of the properties of the adhesive material that is used to secure mounting pad 600 to the surface of the vehicle. In this example, mounting pad 600 can have an associated weight rating, where the sensor and housing that are to be used with mounting pad 600 can be matched, to allow the sensor and housing to be secured to mounting pad 600 without damaging the surface of the vehicle while avoiding an excessive loading on mounting pad 600 that could cause the adhesive to fail.



FIG. 7 is a diagram of an isometric view of the Crown PC4500 bumper assembly with all sensors mounted using their corresponding enclosures and mounting pads, in accordance with an example embodiment of the present disclosure. The assembly of the Crown PC4500 lift truck includes sensors, mounting pads and enclosures that are mounted to the front bumper 701. The side sensors can be mounted to the side of the bumper using two side mounting pads 400 on each side. These mounting pads 400 can be adhered to the bumper using industrial adhesive tape. In order to attach the sensor and sensor enclosure 200 to the mounting pads 400, two mounting arms 702 can be used. These mounting arms 702 add clearance for the sensor vision around the bumper.


The side sensor enclosure 200 can be mounted to the mounting arms. The sensor and manufactures hardware can be mounted inside the enclosure 200. The front of the vehicle can be equipped with another sensor, in this case a SICK Microscan 3. Side sensor enclosure 200 can be mounted using the front mounting pad 300 which is adhered to the bumper using industrial adhesive tape or in other suitable manners. The sensor mounting brackets and sensor enclosure 100 can be mounted to the mounting pad 300 using screws and threaded holes or in other suitable manners.



FIG. 8 is a diagram of an isometric view of the Raymond 8510 bumper assembly with all sensors mounted using their corresponding enclosures and mounting pads, in accordance with an example embodiment of the present disclosure. The assembly of the Raymond 8510 lift truck after all sensors, mounting pads and enclosures are mounted to the front bumper 801 is shown. The side sensors can be mounted to the side of the bumper using a mounting pad 600 on each side or in other suitable manners, such as by adhering mounting pads 600 to the bumper using industrial adhesive tape. The side sensor enclosure 200 can then be mounted to the mounting pads 600. The sensor and manufactures hardware can be mounted inside the enclosure 200, and the front of the vehicle can be equipped with another sensor, such as a SICK Microscan 3 or other suitable sensors. The sensor can be mounted using the front mounting pad 500, adhered to the bumper using industrial adhesive tape or in other suitable manners. The sensor mounting brackets and sensor enclosure 100 can be mounted to the mounting pad 500 using screws and threaded holes.



FIG. 9 is a diagram of an isometric view of a simple universal adhesive mounting system assembly, in accordance with an example embodiment of the present disclosure. FIGURE A includes vehicle bumper or body 1, industrial adhesive tape 2, mounting pad 3, manufacturer mounting bracket(s) 4, sensor 5, protective enclosure 6 and screws 7.


The vehicle bumper or body 1 can be a rigid and sturdy part of the vehicle. This area can be located where the mounting pad 3 will be adhered using a thin layer of industrial adhesive tape 2. The mounting surface of the mounting pad 3 can be configured to match the contour of the vehicle area it is adhered to, to ensure a better fit and therefore a stronger bond to the vehicle. The back of the mounting pad 3 can be curved concave to fit flush against the convex curve of the vehicle bumper 1. The mounting pad 3 can be modified to ensure proper fit, while all other parts can stay the same. The sensor 5 can be mounted to the mounting pad 3 via its manufacturers mounting bracket(s) 4. The manufactures mounting bracket 4 can then be mounted to the mounting pad 3 using screws 7 fastened into threaded holes in the mounting pad 3. The manufacturer's mounting bracket 4 can be used for simplicity and to lower manufacturing costs, and can also offer sensor adjustment settings that can be useful for accurate calibration. The protective enclosure 6 can fit around the sensor assembly, to protect it from debris and mild impact. The protective enclosure 6 can mount directly to the mounting pad 3 via screws 7 fastened into threaded holes on the mounting pad. The entire assembly can be used to provide a secure non-destructive sensor mount on the surface of a suitable vehicle bumper or body 1.



FIG. 10 is a diagram of a side view of a simple universal adhesive mounting system assembly, in accordance with an example embodiment of the present disclosure. The parts shown in FIGURE B are not configured for any specific vehicle or sensor, rather they are simplified versions to illustrate more clearly the assembly and how parts relate to each other.



FIG. 11 is a diagram 1100 of various lift truck types, in accordance with an example embodiment of the present disclosure. Material handling vehicles also known as lift trucks are used to move goods, e.g., pallets from one location to another. These vehicles are typically driven or controlled by a human operator such as a warehouse or factory employee, and in accordance with the teachings of the present disclosure can each include a retrofit controller 1102 that interfaces with an enterprise vehicle management system 1104. A typical use case for a lift truck is to pick up a pallet using the forks of the lift truck from the ground or from a storage rack, and then transport the pallet to another location and deposit it on the floor, to move it vertically and position it into a rack, or to perform other suitable actions. Other use cases include loading and unloading trailers, or any pallet move required as part of a material handling operation. It is quite common for such moves to be repeated throughout a work shift, either between the same two physical locations or between various combinations of physical locations. In addition, while a retrofit controller 1102 is discussed in the present disclosure, the disclosed algorithmic functionality can be implemented in one or more vehicles that have suitable built in controllers, such as to coordinate the functionality of a fleet of vehicles.


In general, the algorithmic functionality described herein is provided in the form of the identification of one or more peripheral systems that are controlled by a controller or that generate data that is received by a controller, where the controller is configured by the algorithm to operate in response to controls or data. For example, various sensors and user interface devices are shown in the associated figures of the pending disclosure and discussed in the description of the figures, and associated controlled devices are also shown and discussed. The manner in which such devices generate data and are controlled is typically known, but the specific interactions between those devices, surrounding objects and terrain, and the operators are the subject of the present disclosure. These specific algorithmic interactions improve the functionality of the disclosed systems by allowing them to be used in a manner that would otherwise not be capable, such as to allow a vehicle to be remotely or automatically controlled that would otherwise not be capable of such control, to allow a fleet of vehicles in an enterprise to be centrally controlled and for other suitable purposes that provide substantially more than prior art vehicles that cannot be automatically or remotely controlled, or enterprise systems that require all vehicles to be from a single source and which do not allow for existing vehicles to be retrofitted. The ability to allow vehicles to be retrofitted alone is a substantial improvement, as it allows existing fleets of hundreds of different vehicles to be controlled without the need and expense of replacing those vehicles.


The method and system of the present disclosure includes a retrofit kit that allows lift trucks to operate autonomously without a human operator physically present on-board the vehicle. In other words, a lift truck is transformed into a driverless vehicle.


A retrofit kit in accordance with the present disclosure can include sensors, computers, communication devices, electrical circuits and mechanical actuators which allow lift trucks or other devices to operate autonomously without a human operator or via a remote tele-operator. In addition, the following aspects of the present disclosure are provided and claimed.


Sensors, processors, communication devices, electrical circuits and mechanical actuators are retrofitted to a lift truck and are configured with software that causes the processor to receive sensor information and to process the sensor information in order to drive the lift truck via electrical interfaces or through mechanical actuation.


Using a combination of processors with algorithmic structure, sensors and controllable actuators, the lift truck is adapted to generate data that is used to create a map of the physical layout of the environment, such as to generate a map of the operational environment as the lift truck is used, with additional contextual information and then use that map and contextual information to navigate autonomously. The map that is generated can be shared to other lift trucks in a fleet or to a remote server, such as via a wireless link. In addition, multiple maps can be generated by multiple lift trucks, and a centralized processor can receive the maps, identify differences and obtain additional data to resolve the difference.


The lift truck can be adapted to be operated in manual and autonomous mode via operator selection through a touch screen interface or a physical switch. In autonomous mode, missions can be defined via a web-based dashboard, a touch screen interface or in other suitable manners.


The processor of the lift truck can be configured to execute one or more algorithms that cause it to store sensor data and upload the sensor data to a remote server, to allow the sensor data to be received by a second processor that is configured to execute machine learning and artificial intelligence algorithms that allow the second processor to learn and improve autonomy capability.


The on-board sensors of retrofit controller 1102 are used in conjunction with a user interface device and a processor that has been configured to generate real-time user controls for identifying proximity to obstacles and appropriate actions that can be taken by the lift truck that is using retrofit controller 102, such as to stop, reverse, turn left, turn right, or to take other actions to avoid injuries and damage. In the situations where an accident is detected by retrofit controller 102 or the associated operator, the processor of retrofit controller 102 can be configured to recognize predetermined sensor inputs (inability to move, non-linear movement over linear surfaces, increased torque, variations in torque and so forth) or to generate and detect a user control actuation for an emergency notification control, and to generate a notification message and send the notification message out via a wireless link to enterprise vehicle management system 104. Accident-related data (video, audio, machine operating parameters, operator controller entries) can then be stored in a suitable event log, such as to determine the cause of the accident and to take corrective action.


In manual mode, the onboard sensors of retrofit controller 102 are used by a processor that has been configured by one or more algorithms to receive the sensor data and to evaluate operator behavior. In one example embodiment, the algorithms can evaluate predetermined indicators of operator error, such as emergency stops, impacts with objects after operator warnings have been generated, erratic direction control, frequent extended stops that indicate operator inactivity, and so forth. The processor of retrofit controller 1102 can include algorithms that alert managers of such indicators, such as at a centralized controller associated with enterprise vehicle management system 1104, a handheld device user interface of the manager, text alerts, screen alerts or other suitable indications, to provide an alert to management of violations such as distracted or reckless operation.


On board systems of retrofit controller 1102 such as the processor as configured with the algorithms disclosed herein operating in conjunction with sensors are configured to log positions of the associated vehicle (such as from GPS coordinates, the position of lift forks, range-bearing measurements to physical objects, vehicle direction, relative operator position and so forth), vehicle speed, vehicle diagnostic data and other suitable data in real-time and relay it to enterprise vehicle management system 104. Enterprise vehicle management system 1104 can include a processor with one or more associated algorithms to allow a remote human manager receive the logged positions and associated data, such as over a wireless communications media, to schedule preventative maintenance, to monitor vehicle operator compliance with safe operation guidelines and for other suitable purposes.


The processor of retrofit controller 1102 can include one or more algorithms that are used to request software updates or to receive notifications of software updates, such as from enterprise vehicle management system 1104 over a wireless communications media, and to install the software updates, such as by temporarily inactivating the vehicle in response to receipt of an operator control, so that additional functional capabilities can be safely added over time without the need to take the equipment out of service at an inappropriate time or for an extended period of time.


The processor of retrofit controller 1102 can include one or more algorithms that are used to detect a low fuel level, such as a battery level, and to perform corrective actions. In one example embodiment, an operator can be notified of the low battery condition and a control can be generated to allow the operator to authorize the vehicle to autonomously dock with a physical charging station until batteries are fully charged, charged sufficiently to allow completion of a current task, or in other suitable manners. Due to variations in power usage caused by operator control, a vehicle can require recharging or refueling prior to the end of a scheduled shift, or at other suitable times, such as to optimize the usage of vehicles.


The processor of retrofit controller 1102 can include one or more algorithms that are used to operate the associated vehicle remotely via a wireless communications link, to provide a remote operator with the sensor data and to await control inputs from the remote operator from one or more control inputs at a physical interface, such as a computer, a head mounted display, joysticks, physical buttons, other suitable devices or a suitable combination of such device. In this manner, a remote operator can process sensor data and operate the vehicle associated with retrofit controller 1102, such as to pick up pallets or other objects that are configured to be manipulated by a fork lift or other suitable manipulators, and to relocate the objects to a different location.


The processor of retrofit controller 1102 can include one or more algorithms that are used to generate an alert to a remote operator and associated user controls to allow the remote operator to take control of the vehicle that retrofit controller 1102 is being used with, such as to control the vehicle to perform tasks for which an associated algorithm has not been provided. The algorithms for providing the combination of alerts and operator controls allow operators to be selectively used where needed for complex or unusual tasks. In one example embodiment, enterprise vehicle management system 1104 can be used to coordinate a fleet of vehicles that each have a retrofit controller 102 with a single operator or a group of operators, and the algorithm of retrofit controllers 102 can be further configured to stop operations in a safe condition if an operator is not immediately available to assist.


The processor of retrofit controller 1102 can include one or more algorithms that are used to detect a physical obstruction or unexpected anomaly based on sensor input. If the algorithms of retrofit controller 1102 are not able to create a safe action, they can be configured to stop operation of the vehicle, place the vehicle in a safe state and generate an alert to an operator for assistance. In one example embodiment, a single operator can be responsible for operations of two or more vehicles that are using retrofit controller 1102, multiple operators can be responsible for those vehicles and a closest operator can be determined for the purpose of generating an alert, or other suitable processes can also or alternatively be used.


The sensor of retrofit controller 1102 can include a bar code scanner that it is adapted to scan the item being moved and communicate that information to a warehouse or inventory management system through a direct or indirect link, such as by using a software Application Programming Interface (API).


The following exemplary components can be used to comprise a retrofit controller 1102 that is mounted on-board a lift truck, in accordance with exemplary embodiments of the present disclosure, as discussed herein. These components are discussed here but are generally applicable to the various FIGURES that accompany the present disclosure:


E-Stop (emergency stop) buttons or controls can be mounted in various easy to reach places or generated on a touch screen user interface of a user device, so that the vehicle can be stopped in the event of an emergency. Unlike emergency stop buttons on conventional equipment that are located near the operator's console, the present disclosure includes emergency stop buttons external to the equipment, or remote emergency stop controls.


Imaging sensors, such as cameras or stereo camera pairs mounted in a suitable location such as a front, side, rear, top or bottom surface of a vehicle, a mast, on a manipulator device, on a fork lift mechanism, in one or more of the forward direction, side direction, rear direction, top direction, bottom direction or other suitable directions, and can be used to generate data that is algorithmically processed using known algorithms to identify objects, perceive depth and detect obstacles. An imaging sensor, such as a camera or stereo camera pair, a radar device, a light detection and ranging (LiDAR) device or other suitable devices, can be mounted in one or more of the reverse direction or other suitable directions, to perceive depth and detect obstacles.


One or more ultrasonic range finders can be mounted on the body of the vehicle and facing in a front direction, a side direction, a rear direction, an upwards direction or in other suitable locations and configured to detect obstacles in the vicinity of a vehicle that retrofit controller 1102 is installed on.


The imaging sensors can include a stereo camera pair or other suitable camera sensors mounted on the front, sides, rear, top, or bottom of the vehicle body, on a mast or in other suitable locations, and can further include one or more algorithms operating on a processor that are configured to detect objects within sets of image data. A LiDAR device, laser range measurement device or other suitable devices can also generate image data, and can be mounted on the front, sides, rear, top, or bottom of the vehicle body, on a mast, a fork mechanism or in other suitable locations, and can further include one or more algorithms operating on a processor that are configured to detect objects within sets of image data and to measure a range to the objects, or other suitable data.


An Inertial Measurement Unit or other suitable devices can be rigidly mounted on the vehicle or in other suitable locations, and can be used to generate direction data. A primary computer or other suitable data processor can be provided with one or more algorithms that can be loaded onto the processor, such as in an executable file that has been compiled to allow the processor to implement the algorithms in conjunction with one or more peripheral devices such as sensor, to allow the processor to receive sensor data and generate suitable control actions in response. A secondary computer or other suitable data processor can be provided with one or more algorithms that can be loaded onto the processor, such as in an executable file that has been compiled to allow the processor to implement the algorithms in conjunction with the primary computer, sensors, actuators and the lift truck's electrical control systems or other suitable devices and systems.


Mechanical actuators or other suitable devices with digital control interfaces can be used to apply torque to the steering wheel if the steering wheel is not electrically actuated in the existing form prior to retrofit. Likewise, mechanical actuators or other suitable devices with digital control interfaces can also be used to actuate accelerators, brakes or other vehicle control devices, such as if acceleration and braking is not electrically actuated in the existing form prior to retrofit. Linear mechanical actuators or other suitable devices with digital control interfaces can be used to control hydraulic interfaces to operate forks and mast in the case that these are not electrically actuated in the existing form prior to retrofit.


Printed circuit boards can be provided that distribute power to sensors, computers and actuators and communicate data between different components of the machine. A circuit board that interfaces with an onboard CAN bus (if present) can be provided to send control signals and extract diagnostics information. Bar code scanners or other suitable devices to read bar codes, NFC tags, RFID tags or other identification tags on pallets and goods.


Weight sensors can be disposed on fork lift devices, manipulators in other suitable locations to detect a load, whether a pallet of goods has been loaded, or other suitable conditions. Ceiling facing cameras can be provided to capture structural or artificially installed feature points on the ceiling and track them in order to increase positioning accuracy. A camera can be provided for monitoring the driver's cabin to determine a driver presence or behavior.



FIG. 12 shows a block diagram 1200 of exemplary retrofit kit components and how they are interconnected for the purposes of sharing data. As discussed above, the retrofit kit can include one or more of a primary computer 1202, a human interface such as a touch enabled device 1204 (including but not limited to a touch screen interface, a capacitive interface, a tactile interface, a haptic interface or other suitable devices), a secondary computer 1206, one or more mechanical actuators 1208, one or more control interface circuit boards 210, a lift truck system 1212 that includes a controller 1214 and lift truck CAN bus 1216, one or more imaging sensors 1218, one or more bar code scanners, one or more LiDAR sensors 1222, one or more inertial sensors 1224, one or more sonar sensors 1226 and other suitable devices. Each of these systems can have associated algorithmic controls that are implemented using primary computer 1202, secondary computer 1206, control 1214 or other suitable devices, and can provide data to and receive controls and data from remote systems, such as through an enterprise vehicle management system or in other suitable manners. The components and associated algorithmic controls can be coordinated to ensure interoperability prior to installation, so as to facilitate installation in the field.



FIG. 13 is a diagram 1300 of an example embodiment of retrofit kit components as mounted on a center rider pallet jack type lift truck. Diagram 1300 includes LiDAR, inertial measurement unit and ceiling camera unit 1302, which can be mast mounted for deployment on a lift truck. Touch interface 1304 is provided for operator control, and bar code scanner 1306 can be disposed at a location that will scan bar codes that are installed on a predetermined location of an object.


Rear imaging sensor and LiDAR unit 1308 are used to generate image and ranging data for objects to the rear of the vehicle, and weight sensors 1310 are used to determine the weight of an object that has been loaded on the lift mechanism, such as fork devices. Sonar sensors 1312 and imaging sensors 1314 can be disposed on the sides of the vehicle. A front imaging sensor and LiDAR unit can likewise be disposed in the front of the vehicle, and a lift truck control system interface 1318 and primary and secondary computers with communication devices can be disposed internal to the vehicle.


In one exemplary embodiment, the facility mapping process can be implemented by an algorithm that includes the following steps. After a human operator switches on the vehicle, the processor executes an algorithm that generates a control on a user interface, to allow the user to select the mapping mode using a touch enabled interface. The user can then drive the vehicle around the facility where it needs to operate, to allow the vehicle sensors to gather and store sensor data. One or more algorithms implemented by the processor cause the processor to interface with the sensors on a periodic basis, to receive the sensor data and to process and store the sensor data.


Once the data gathering process is complete, the operator selects the build map mode and the vehicle processes the data on its onboard computer to formulate a map. Once the processing is complete, the data and processed map is uploaded to a remote server via a wireless link.


The algorithm can generate a map of the facility as it is being created on the user interface, to allow the human operator to review the map and to determine whether there are any errors that need to be corrected. Because errors can be generated due to sensor interference, such as obstacles or other vehicles, the errors mat require a new facility scan, a partial facility scan, a manual correction or other suitable corrections. Once the map is approved, all other retrofitted lift trucks in a fleet are adapted to download and use the map via a wireless link.


Once the map is constructed, different areas of the map can be labelled manually, such as to reflect keep-out zones where the lift truck should not operate, charger locations, pallet drop off zones, aisle numbers and so forth. These labels can allow material handling tasks to be defined as missions through user selection of appropriate pick and drop off points for each mission.



FIG. 14 is a flow chart of an algorithm 1400 of a mapping process, in accordance with an example embodiment of the present disclosure. Algorithm 1400 can be implemented in hardware or a suitable combination of hardware and software, and can include one or more commands operating on one or more processors. While algorithm 400 and other example algorithms disclosed herein can be shown or described in flow chart form, they can also or alternatively be implemented using state machines, object-oriented programming or in other suitable manners.


Algorithm 1400 begins at 1402, where a lift truck or other suitable vehicle is turned on, and controller detects the actuation of the system, such as by reading a predetermined register, receiving a data message or in other suitable manners. The algorithm then proceeds to 1404, where a mapping mode is enabled. In one example embodiment, the mapping mode can configure one or more sensors to send data at a predetermined frequency or other suitable processes can be used. The algorithm then proceeds to 1406.


At 1406, the algorithm enables the vehicle to be driven around the facility, either automatically, by a local user, by a remote user or in other suitable manners. The algorithm then proceeds to 1408 where a build map mode is enabled, such as to generate a map as a function of inertial measurements and range-bearing measurements in the front, sides and rear of the vehicle by sensors, or in other suitable manners. GPS measurements can also be used in the map generation process, if GPS signals are available. The algorithm then proceeds to 1410, where one or more algorithms operating on a local computer process the data, and then to 1412, where the processed data and map are transmitted to a remote computer. The algorithm then proceeds to 1414.


At 1414, the map is reviewed and any errors are corrected. The algorithm then proceeds to 1416 where the finalized map is downloaded to all lift trucks in the fleet.


Reference [1] develops a method to compute map information from laser range scan data, which can be used to implement various aspects of the present disclosure, and which is hereby incorporated by reference as if set forth herein in its entirety.


Switching between manual and autonomous operation can be implemented using a touch enabled interface that is integrated in an easy to reach position for a human operator. A human operator can choose between manual operation and autonomous operation. A human operator can also use a physical switch to disengage software control. Multiple physical e-stop switches can also be provided, which if activated, immediately bring the vehicle to a halt and disengages software control.


In autonomous mode, algorithmic controls can be defined for the lift truck including 1) point to point navigation, 2) dropping off a pallet at a chosen destination on the map, 3) pick up of a pallet from a location defined on the map, and 4) storing, communicating and processing of Data for Learning


The sensors and integrated circuits in the retrofit kit are configured to be used with one or more algorithms operating on the processor to gather images, laser scan data, vehicle diagnostics, position and inventory information. This information can be stored and uploaded to a remote server or other suitable systems or devices. Machine learning and artificial intelligence algorithms can be trained on the captured data to improve object recognition capability. Once a new artificial intelligence model is trained, its parameters can be sent back to all lift trucks in the fleet to improve their ability to process data that defines the environment.



FIG. 15 is a diagram 1500 of a system that uploads sensor data to a remote server to train artificial intelligence models in one exemplary embodiment. Diagram 1500 includes primary computer 1502, secondary computer 1504, transmitter 1506, imaging sensors 1508, barcode scanner 1510, LiDAR sensors 1512, inertial sensors 1514 and sonar sensors 1516. An Internet connected remote computer 1518 provides data to a machine learning and artificial intelligence model 1520.


Camera feed, range information to obstacles and inertial measurement unit data can be processed on-board to detect and warn human operators of an impending accident. In case an accident occurs, all sensor data prior to and just after the accident can be stored on the lift truck and uploaded to a remote server via a wireless link or in other suitable locations. This configuration allows a human operator to determine the root cause of the accident.


For a lift truck in manual mode, the method of accident warning and detection works as follows: 1) an early warning distance zone can be defined around the lift truck virtually in software; 2) a danger warning distance zone can be defined around the lift truck virtually in software; 3) if an obstacle is detected via range measurements to be within the early warning zone, the operator can be alerted via audio-visual cues or in other suitable manners; 4) if an obstacle is detected within the danger zone around the lift truck through obstacle detection sensor measurements (such as sonar, cameras, Lidar etc.), the driver can be notified with repetitive visual and auditory cues and the forklift speed is limited to a maximum pre-set value or in other suitable manners; 5) if an accident is detected from the inertial sensor measurements, i.e., the rate of change of acceleration exceeds a pre-set threshold, an incident is reported to a remote server via a wireless link or in other suitable manners.


For a lift truck in autonomous mode, the method of accident warning and detection can work as follows, in one exemplary embodiment: 1) an early warning distance zone is defined around the lift truck virtually in software; 2) a danger warning distance zone is defined around the lift truck virtually in software which is smaller than the early warning danger zone; 3) if an obstacle is detected via range measurements to be within the early warning zone, the vehicle starts slowing down; 4) if an obstacle is detected to be within the danger zone then the vehicle immediately comes to a stop.


A camera pointed towards the driver's cabin captures images of driver behavior and compares that in-built safe operation behavior. If an anomaly is detected, the driver is warned with an audio-visual cue and this information is logged in a safety report and sent to a remote computer via a wireless link.


On board sensors and integrated circuits are configured to read vehicle diagnostic messages and process sensor information to compute vehicle speed and position within the facility or in other suitable locations. This information can be relayed in real-time to a remote computer where a human operator can be notified of a maintenance issue or violation of safe driving rules by a human operator, e.g., if the operator exceeds a speed or turn rate limit.


The vehicle diagnostics information is available through a CAN bus interface or other suitable interfaces. An integrated circuit is plugged into the CAN bus to read diagnostics information, or other suitable devices can also or alternatively be used. The position of the vehicle can be calculated by comparing the measurements from a range sensing device to the pre-built map. Vehicle velocity is estimated by reading speed information from the CAN bus or in other suitable manners through measurement of sensor data.


Software capabilities can be developed at a different site than where the robot operates. If a new software capability is developed that is to be sent to retrofitted lift trucks operating in the physical world, the following exemplary process or other suitable processes can be followed: 1) the software update is sent to a remote server via an internet link; 2) the remote server then contacts the primary computer mounted on lift truck through a wireless link and informs it that a software update is available; 3) the primary computer mounted on the lift truck downloads the software update and stores it in memory; 4) when the lift truck is stationary and charging, the software update is applied and the computers are automatically rebooted; 5) if an issue is detected during reboot, the secondary computer alerts nearby human operators with an audio-visual warning.


The secondary computer connects to the CAN bus interface of the lift truck, directly to the battery gauge if a CAN bus is not available, or in other suitable manners, to read the battery voltage and for other suitable purposes. If the battery voltage is detected to be lower than a pre-set threshold, the processors of the vehicle can detect that it needs to return to its charging station. If a vehicle is in the middle of a mission, the processors of the vehicle or other suitable systems or devices can estimate the energy it will take to complete the mission, and if sufficient battery energy is available to complete the mission, the lift truck can first complete the mission and return to the charging location as defined on the map. If there is insufficient power to complete the mission, the vehicle can navigates to the closest safe zone and stops, or can take other suitable actions. The vehicle processor can then alert nearby human operators with audio-visual cues or in other suitable manners to return the lift truck to charging manually. The vehicle can also alert a remote operator via a wireless link.


Before starting every mission, the on-board computer computes the battery power required to complete the mission and the battery power available. If the battery power available is less than what is required, it can reject the mission and return the lift truck to the charging station.



FIG. 16 is a flow chart of an algorithm 1600 for automatic docking process for charging, in accordance with an example embodiment of the present disclosure. Algorithm 1600 can be implemented in hardware or a suitable combination of hardware and software, and can include one or more commands operating on one or more processors. While algorithm 1600 and other example algorithms disclosed herein can be shown or described in flow chart form, they can also or alternatively be implemented using state machines, object-oriented programming or in other suitable manners.


Algorithm 1600 begins at 1602, where it is determined whether the battery power is less than a minimum threshold. If not, the algorithm proceeds to 1608, otherwise the algorithm proceeds to 1604.


At 1604, it is determined whether the battery power is less than needed for mission requirements. If so, the algorithm proceeds to 1610 where the vehicle proceeds to a safe zone and an operator is alerted. Otherwise, the algorithm proceeds to 1606 where the mission is completed and the vehicle proceeds to charging.


Camera sensors and range measurement devices such as LiDAR, sonar or other suitable devices or systems enable the on-board computer to detect obstacles in the path of vehicle. If an obstacle is detected near the vehicle, the camera feed can be used to compare the obstacle to a known database of objects. Objects can be classified in two categories; (i) safe to travel around, (ii) not safe to travel around, or other suitable categories can also or alternatively be used.


If the object is identified to be not safe to travel around, the lift truck can be commanded to stop by the computer till the path becomes clear, or other suitable instructions can be generated and implemented. If the software operating on the processor is not able to match the obstacle to a known class of objects with a high confidence (>95%) then the vehicle can be instructed to stop and to wait until the object clears the path. In other cases, the on-board computer can compute a new path to its destination and command the lift truck to follow the new path and avoid the obstacle.



FIG. 17 is a diagram 1700 of an exemplary obstacle zone detection system. Diagram 1700 includes early warning zone 1704, which has an associated 15 foot radius, and danger zone 1702, which has an associated 5 foot radius.


The algorithms operating on the primary computer and/or the secondary computer can include learning algorithms that are configured to allow an operator to program a vehicle that has a retrofit controller 102 to perform the following tasks: 1) pick up a pallet from the ground, based on machine learning algorithms that are used to store the relevant dimensions, spacing and arrangement of pallets used in the facility; 2) drop off a pallet on the ground or onto a rack, based on machine learning algorithms that are used to store the relevant dimensions, spacing and arrangement of pallets and racks used in the facility; 3) retrieval of a pallet from a rack, based on machine learning algorithms that are used to store the relevant dimensions, spacing and arrangement of pallets and racks used in the facility; 4) load and unload trailers, based on machine learning algorithms that are used to store the relevant dimensions, spacing and arrangement of pallets and trailers used in the facility; 5) plan a new path around an unknown obstacle; and 6) other suitable repeated tasks. Such algorithmic tasks can also or alternatively be pre-programmed with operator prompts to enter relevant dimensions of pallets, racks, trailers and so forth.


If a lift truck is presented with data that defines a task that it is not pre-programmed for, such as image data that establishes that a pallet exceeds predetermined dimensions and may require restacking, the retrofit controller 1102 can execute one or more algorithms that contact a processor associated with a remote operator via a wireless communications media or other suitable media. The remote processor can include one or more algorithms that generate a combined real-time sensor feed using one or more screens, a wearable head mounted device or other suitable devices to allow the remote operator to survey the environment and to use joystick controls, a touch enabled interface, a physical interface that duplicates the control system on the lift truck or other suitable control devices. In this manner, the remote operator can control the lift truck, including driving and lifting mechanisms. The operator can drive the lift truck for an entire mission, complete the complex task and hand over driving control back to the autonomous driving software, or other suitable processes can also or alternatively be performed.



FIG. 18 is a diagram of a system 1800 for allowing a remote operator can control a lift truck via a wireless link. System 1800 includes lift truck 1802, which further includes primary computer 1804 and transmitter 1806. Sensor data is streamed to an operator, and control commands are received from the operator. A remote Internet connected computer 1808 includes one or more algorithms that are configured to receive the sensor data and control commands, and to generate additional control commands, such as if a local operator is not available and a remote operator needs to take over control of the vehicle. A human-machine interface 1810 is used to allow human operator 1812 to receive the sensor data and enter control commands.


A bar code, NFC, RFID or other suitable device scanner or other suitable device can be mounted on the mast or fork assembly or in other suitable locations such that it can scan bar code labels attached to goods that will be moved. In either manual or autonomous mode, once the lift truck starts approaching a pallet to be picked up, the on-board computer uses range sensing from LiDAR or sonar and camera based systems to detect that an item is to be picked up. When an item is being picked up, the primary computer, secondary computer or other suitable device implements one or more algorithmic controls to allow the vehicle to enter a “pick-up state.” If in manual operation mode, the algorithmic controls can generate a user interface control to allow the operator to confirm the “pick-up state” with a visual cue on a touch enabled device.


In the pick-up state, the bar code scanner can be operated by algorithmic control to make repeated scans until a bar code is detected. The weight sensor on the forks can be operated by algorithmic controls to alert the on-board computer that the pallet has been picked up. Once the pallet is picked up, the on-board computer can implement an algorithmic control to relay the bar code of the picked-up item along with the location where it was picked up to the inventory management system. If a lift truck is in autonomous mode, one or more algorithmic controls operating on an associated local or remote processor can use bar code data to decide where to drop off pallet. Once the goods are dropped off to another location, the algorithmic controls can cause the weight sensor to detect that the goods are no longer present, and to transmit the bar code data of the object that has been dropped off along with the drop location to the inventory management system, which can include one or more algorithmic controls that causes it to update its records.



FIG. 19 is a diagram of an algorithm 1900 for controlling a vehicle, in accordance with an example embodiment of the present disclosure. Algorithm 1900 can be implemented in hardware or a suitable combination of hardware and software, and can include one or more commands operating on one or more processors. While algorithm 1900 and other example algorithms disclosed herein can be shown or described in flow chart form, they can also or alternatively be implemented using state machines, object-oriented programming or in other suitable manners.


Algorithm 1900 begins at 1902, where it is determined whether a lift truck is in pick-up mode, such as by receiving a mode change command or in other suitable manners. If it is determined that the lift truck is not in pick-up mode, the algorithm returns to 1902, otherwise the algorithm proceeds to 904.


At 1904, a bar code scanner is operated to detect the present of a bar code. The algorithm then proceeds to 1906, where it is determined whether a bar code has been detected. In one example embodiment, image data analysis algorithms can process the image data generated by the bar code scanner to determine whether a bar code is present, or other suitable techniques can also or alternatively be used. If it is determined that a bar code is not present, the algorithm returns to 1904, otherwise the algorithm proceeds to 1908.


At 1908, it is determined whether a load has been detected on the forks. If it is determined that no load has been detected, the algorithm returns to 1908, otherwise the algorithm proceeds to 1910.


At 1910, the pick-up location and bar code are determined and stored. The algorithm then proceeds to 1912 where the pick-up location and bar code are reported to a management system processor, in addition to other suitable data.



FIG. 20 is a diagram of an algorithm 2000 for controlling a vehicle, in accordance with an example embodiment of the present disclosure. Algorithm 2000 can be implemented in hardware or a suitable combination of hardware and software, and can include one or more commands operating on one or more processors. While algorithm 2000 and other example algorithms disclosed herein can be shown or described in flow chart form, they can also or alternatively be implemented using state machines, object-oriented programming or in other suitable manners.


Algorithm 2000 begins at 2002, where it is determined whether the lift truck is in drop-off mode. If it is determined that the lift truck is not in drop off mode, the algorithm returns to 2002, otherwise it proceeds to 2004 where the drop location and bar code are stored. The algorithm then proceeds to 2006 where the drop-off location and bar code are reported to a management system processor, in addition to other suitable data.


The system and method for a material handling vehicle of the present disclosure can be implemented on a vehicle that is commonly known as a lift truck or other suitable vehicles, to implement one or more algorithms that enable the vehicle to autonomously follow a human order picker under processor control, for order picking or other suitable functions (which are referred to herein generally as “order picking,” but which are not limited to order picking). The order picker can be detected, recognized and tracked by one or more algorithms that control, interface with and utilize sensors mounted on the lift truck to generate sensor data that is processed by the algorithms. The sensors mounted on the lift truck allow the lift truck to automatically detect and avoid obstacles in its path while it follows the order picker at a safe distance.


In many warehouses and distribution centers, low-level order picking is a major component of day-to-day operations. In this process, a human order picker drives or rides a lift truck across a warehouse facility to pick up items required for a particular order and place said items on a pallet loaded on to the lift truck. This is a repetitive process in which the order picker typically has to jump on and off the truck multiple times to pick up goods and then drive to the next goods pick location. Many times, order pickers walk along-side the lift truck and use the lift truck controls the advance the vehicle to the next pick location while walking along side it.


Significant labor time is expended in reaching for the vehicle controls, climbing on board the vehicle and de-boarding it during the order pick process. This time waste adversely affects the productivity of warehouse operations. The present disclosure improves order picker throughput by eliminating time spent by a human operator to advance the vehicle to the next pick location. The present disclosure also enables a lift truck operating under control of the disclosed algorithms to detect, recognize and follow a human order picker autonomously in a low level order picking operation.


The present disclosure includes a hand held or wearable device that is coupled with a voice activated system that a human operator, such as an order picker, can use to pair with a control system on the lift truck and to give motion commands to the control system. The algorithmic controls can use voice activation, physical inputs to the wearable device or other suitable inputs, and the control system can be algorithmically configured to cause the lift truck to follow the operator in a leader-follower manner by responding to the motion commands.


A computer vision software enabled system is installed in the lift truck and configured to interoperate with the controller of the lift truck. The computer vision software enabled system is configured to learn the appearance of a human order picker that is in possession of the hand held or wearable device, and is further configured to allow the controller of the lift truck to track the operator's location with respect to the lift truck. A wearable garment can also or alternatively be utilized, such as a shirt or jacket with recognizable visual markers on it that may be worn by order pickers that makes a human operator easily and uniquely identifiable and trackable by the computer vision software enabled system of the lift truck. A motion control system of the controller of the lift truck operates under control of one or more algorithms that are configured to use the relative position of the order picker with respect to the lift truck to follow the order picker.


The order picking control algorithm starts when a warehouse operation and control system receives order data for a set of goods, such as goods that need be shipped out from the warehouse. Once the order is received, a human order picker may need to visit multiple locations in the warehouse to pick up the required items and place them on a lift truck (e.g., pallet jack, fork lift etc.). During this picking process, the order picker has to rapidly and repetitively bend to pick up items and then walk to the lift truck and place the items. Once the items are placed on the lift truck, the lift truck advances to the next pick location, such as by using algorithmic or manual controls. This process is repeated until all of the items in the order have either been located or otherwise accounted for (such as by receiving an out of stock status). Once all the required items have been obtained, the full order can be taken to a designated location in the warehouse for packaging and shipping.


The disclosed retrofit kit can include one or more sensors, computers, communication devices, electrical circuits and mechanical actuators which allows lift trucks to operate autonomously without a human operator or via a remote tele-operator. In addition, the retrofit kit can include a wristband or wearable device worn by a human order picker and enabled by Bluetooth LE or any such short range wireless communication system. A Bluetooth LE transceiver can be included on the lift truck, that is configured to communicate with the lift truck software control system. A wearable garment with identifiable visual patterns on it can also or alternatively be used.


In one example embodiment, a method can be algorithmically implemented on a processor that includes 1) pairing the order picker's wearable device to the lift truck. 2) Training the lift truck to recognize the appearance of the order picker. 3) Carrying out the order picking task. Other suitable steps are readily apparent to a person of skill upon reading this disclosure.



FIG. 21 is a diagram of a system 2100, in accordance with an example embodiment of the present disclosure. System 2100 includes wristband device 2102, screen 2104, advance button 2106, stop button 2108, honk button 2110 and pairing button 2112. The wristband device is pre-coded with a unique ID and is enabled with short range wireless communications an example of which is Bluetooth LE.



FIG. 22 is a diagram of a garment 2200, which includes one or more unique patterns 2202 on the front and one or more unique patterns 2204 on the rear.


The human order picker approaches a stationary lift truck and presses a pairing button on the lift truck to pair it with the hand held device. The pairing button is operably coupled to a controller and causes the controller to enter a state wherein it will receive inputs to allow it to operably interact with an optical recognition system or other suitable systems to identify the operator and to allow the controller to respond to controls received from the operator.


The operator presses the pairing button on his wristband device, which is configured to send a predetermined control signal to the controller to configure the controller to recognize the operator.


The lift truck scans using its wireless radio (e.g., Bluetooth LE) to scan its vicinity and detects all available wristband control devices in pairing mode. It prompts the operator to input the unique ID of the wristband device on the lift truck interface.


The lift truck pairs with the wristband device. Once the wearable device is paired, the order picker proceeds to train the lift truck to recognize himself or herself visually.


Training the computer vision software enabled system and controller of the lift truck to recognize the order picker visually allows the controller of the lift truck to uniquely identify and follow an order picker inside a warehouse or other type of facility.


Once the above pairing process is complete, the lift truck controller user interface instructs the operator to stand in front of the lift truck. The lift truck controller uses the imaging sensors and the computer vision software enabled system to obtain image data and detect unique identifying information from the image data of the order picker's visual appearance.


Once the controller of the lift truck identifies the recognizable visual patterns of the order picker's appearance from the image data, in conjunction with the computer vision software enabled system, it stores the pattern identification by creating a computer model in memory and creates an audio-visual cue to alert the operator.


The controller of the lift truck can also or alternatively send haptic feedback or other suitable user interface outputs to the wristband or other user interface device, which alerts the operator that the lift truck is paired. Z. Kalal, K. Mikolajczyk, and J. Matas, “Tracking-Learning-Detection,” Pattern Analysis and Machine Intelligence 2011 and S. Garrido-Jurado, R. Munoz-Salinas, F. J. Madrid-Cuevas, M. J. Marin-Jimenez, Automatic generation and detection of highly reliable fiducial markers under occlusion, In Pattern Recognition, Volume 47, Issue 6, 2014, Pages 2280-2292, ISSN 0031-3203 can be used to detect, identify and track unique visual patterns and appearance, and are hereby incorporated by reference for all purposes as if set forth herein in their entireties.



FIG. 23 is a diagram 2300 of a flow chart of an example algorithm that can be implemented in hardware and/or software for system control and operation. Algorithm 2300 can be implemented in hardware or a suitable combination of hardware and software, and can include one or more commands operating on one or more processors. While algorithm 2300 and other example algorithms disclosed herein can be shown or described in flow chart form, they can also or alternatively be implemented using state machines, object-oriented programming or in other suitable manners.


An order picker wears a wristband at 2302. Pairing mode is activated on the lift truck at 2304. Pairing mode is activated on the wristband device at 2306. The lift truck scans nearby Bluetooth LE handheld devices at 2308. The operator enters an ID of a wristband device into the lift truck at 2310. The lift truck pairs with the wrist band at 2312.



FIG. 24 is a diagram 2400 of a flow chart of an example algorithm that can be implemented in hardware and/or software for the visual training process. Algorithm 2400 can be implemented in hardware or a suitable combination of hardware and software, and can include one or more commands operating on one or more processors. While algorithm 2400 and other example algorithms disclosed herein can be shown or described in flow chart form, they can also or alternatively be implemented using state machines, object-oriented programming or in other suitable manners.


Algorithm 2400 begins at 2402 where a lift truck enters a learning mode. At 2404 the operator stands in front of the lift truck cameras. At 2406 the lift truck captures images. At 2408 the software recognizes visual patterns and builds a virtual model. At 2410 the lift truck alerts the operators that the process is complete.


In an autonomously following the order picking task, the order picker presses a follow-me button on the wristband device, which generates a suitable control that causes the controller of the lift truck to enter an operational state where it follows the operator, using image data or other suitable data. The operator can also or alternatively speak coded voice commands into the wrist band device such as “lift truck follow” to activate the leader-follower behavior in the lift truck. The operator carries out the order picking process and walks through the facility. The controller of the lift truck uses its imaging sensors and associated computer vision software to track visual patterns of the order pickers appearance based on a model it has learned.


The controller of the lift truck estimates the position of the order picker relative to itself. Then using data defining its own position from a location and mapping system (e.g. GPS or other suitable systems), it utilizes the two sets of image data to estimate the position of the order picker in the warehouse.


The controller of the lift truck then uses its control system to move forward, backward or stop and always maintains a set safe distance behind the order picker.


If the controller of the lift truck detects an obstacle in the way by processing image data generated by the computer vision software enabled system as the lift truck is being operated, it creates an audio alert such as a honk and plans a new route to bypass the obstacle (such as if the obstacle is not human or in other suitable manners).


If the controller of the lift truck determines that it is not able to safely bypass the obstacle, it generates and sends an alert to the order picker via audio visual cues and haptic cues through the wristband, e.g., vibration alert or in other suitable manners.


At any time if the operator needs to override the automatic behavior, the operator can use a physical button on the wristband or other suitable controls to stop the vehicle. The order picker can also speak into the hand held device to give voice commands. Examples of such commands are: 1) “Lift truck stop”—the vehicle stops immediately; 2) “Lift truck follow”—the vehicle switches to following mode and moves forward to follow operator but stays behind the human operator at all times.



FIG. 25 is a diagram 2500 of a lift truck 2504 following an order picker 2502 and maintaining a set distance from the order picker. In one example embodiment, lift truck 2504 can include a processor operating under algorithmic control, where the algorithms are configured to receive image data of order picker 2502, either alone or in combination with a vest or other item of clothing having predetermined markings, a handheld controller or other device with a radio beacon or other suitable devices. The algorithmic controls can be configured to determine a distance from lift truck 2504 to order picker 2502, such as by using a sonar, LiDAR, radar or other suitable devices, wireless media transmission time data or other suitable data, and can execute one or more predetermined routines for maintaining a safe distance between lift truck 2504 and order picker 2502, such as by using one or more predetermined zones. The size of the zones can be adjusted based on whether the zone is used to maintain a safe distance between lift truck 2504 and order picker 2502, between lift truck 2504 and pallet racks, between lift truck 2504 and unknown obstacles and so forth.



FIG. 26 is a diagram 2600 of a lift truck 2604 following an order picker 2602 and avoiding an obstacle 2606 on the way. In one example embodiment, lift truck 2604 can include a processor operating under algorithmic control, where the algorithms are configured to receive image data of order picker 1602, either alone or in combination with a vest or other item of clothing having predetermined markings, a handheld controller or other device with a radio beacon or other suitable devices. The algorithmic controls can be configured to determine a distance from lift truck 2604 to order picker 2602, such as by using a sonar, LiDAR, radar or other suitable devices, wireless media transmission time data or other suitable data, and can execute one or more predetermined routines for maintaining a safe distance between lift truck 2604 and order picker 2602, such as by using one or more predetermined zones. The size of the zones can be adjusted based on whether the zone is used to maintain a safe distance between lift truck 2604 and order picker 2602, between lift truck 2604 and pallet racks, between lift truck 2604 and unknown obstacles 2606 and so forth.



FIG. 27 is a flow chart 2700 of an example algorithm that can be implemented in hardware and/or software for the replanning process when an obstacle is detected. Algorithm 1700 can be implemented in hardware or a suitable combination of hardware and software, and can include one or more commands operating on one or more processors. While algorithm 2700 and other example algorithms disclosed herein can be shown or described in flow chart form, they can also or alternatively be implemented using state machines, object-oriented programming or in other suitable manners.


Algorithm 2700 begins at 2702, where a processor of a vehicle that is operating under algorithmic control causes direction bearing sensors, object detection sensors and other sensors such as cameras or LiDAR to generate data and processes the generated data detect environmental barriers, objects and other potential obstacles. If an obstacle is detected, the algorithm proceeds to 2704, where the algorithms determine the obstacle position with respect to the lift truck. In one example embodiment, the algorithms of the lift truck controller can use data defining a current position of the lift truck relative to a map of the facility, and evaluates whether the obstacle is a known environmental barrier or object, or if it is an unknown obstacle. The algorithm then proceeds to 2706.


At 2706, the algorithmic controls determine a course to either navigate around the environmental barrier or object (either by extracting a previously calculated course or calculating a new course if a course has not previously been calculated), or generates an operator alert of a course cannot be determined. The algorithm then proceeds to 2708, where the course is implemented, such as by controlling one or more actuators to cause the vehicle to advance, reverse, turn left, turn right, to perform a predetermined sequence of motions or to take other suitable actions. Algorithms disclosed in S. Karaman AND E. Frazzoli, Incremental Sampling-based Algorithms for Optimal Motion Planning, In Proceedings of Robotics: Science and Systems, June 2010, Zaragoza, Spain, which is hereby incorporated by reference for all purposes as if set forth herein in its entirety, can be used to plan paths in the physical dimension.


As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. It will be further understood that the terms “comprises” and/or “comprising,” when used in this specification, specify the presence of stated features, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, integers, steps, operations, elements, components, and/or groups thereof. As used herein, the term “and/or” includes any and all combinations of one or more of the associated listed items. As used herein, phrases such as “between X and Y” and “between about X and Y” should be interpreted to include X and Y. As used herein, phrases such as “between about X and Y” mean “between about X and about Y.” As used herein, phrases such as “from about X to Y” mean “from about X to about Y.”


As used herein, “hardware” can include a combination of discrete components, an integrated circuit, an application-specific integrated circuit, a field programmable gate array, or other suitable hardware. As used herein, “software” can include one or more objects, agents, threads, lines of code, subroutines, separate software applications, two or more lines of code or other suitable software structures operating in two or more software applications, on one or more processors (where a processor includes one or more microcomputers or other suitable data processing units, memory devices, input-output devices, displays, data input devices such as a keyboard or a mouse, peripherals such as printers and speakers, associated drivers, control cards, power sources, network devices, docking station devices, or other suitable devices operating under control of software systems in conjunction with the processor or other devices), or other suitable software structures. In one exemplary embodiment, software can include one or more lines of code or other suitable software structures operating in a general purpose software application, such as an operating system, and one or more lines of code or other suitable software structures operating in a specific purpose software application. As used herein, the term “couple” and its cognate terms, such as “couples” and “coupled,” can include a physical connection (such as a copper conductor), a virtual connection (such as through randomly assigned memory locations of a data memory device), a logical connection (such as through logical gates of a semiconducting device), other suitable connections, or a suitable combination of such connections. The term “data” can refer to a suitable structure for using, conveying or storing data, such as a data field, a data buffer, a data message having the data value and sender/receiver address data, a control message having the data value and one or more operators that cause the receiving system or component to perform a function using the data, or other suitable hardware or software components for the electronic processing of data.


In general, a software system is a system that operates on a processor to perform predetermined functions in response to predetermined data fields. For example, a system can be defined by the function it performs and the data fields that it performs the function on. As used herein, a NAME system, where NAME is typically the name of the general function that is performed by the system, refers to a software system that is configured to operate on a processor and to perform the disclosed function on the disclosed data fields. Unless a specific algorithm is disclosed, then any suitable algorithm that would be known to one of skill in the art for performing the function using the associated data fields is contemplated as falling within the scope of the disclosure. For example, a message system that generates a message that includes a sender address field, a recipient address field and a message field would encompass software operating on a processor that can obtain the sender address field, recipient address field and message field from a suitable system or device of the processor, such as a buffer device or buffer system, can assemble the sender address field, recipient address field and message field into a suitable electronic message format (such as an electronic mail message, a TCP/IP message or any other suitable message format that has a sender address field, a recipient address field and message field), and can transmit the electronic message using electronic messaging systems and devices of the processor over a communications medium, such as a network. One of ordinary skill in the art would be able to provide the specific coding for a specific application based on the foregoing disclosure, which is intended to set forth exemplary embodiments of the present disclosure, and not to provide a tutorial for someone having less than ordinary skill in the art, such as someone who is unfamiliar with programming or processors in a suitable programming language. A specific algorithm for performing a function can be provided in a flow chart form or in other suitable formats, where the data fields and associated functions can be set forth in an exemplary order of operations, where the order can be rearranged as suitable and is not intended to be limiting unless explicitly stated to be limiting.


It should be emphasized that the above-described embodiments are merely examples of possible implementations. Many variations and modifications may be made to the above-described embodiments without departing from the principles of the present disclosure. All such modifications and variations are intended to be included herein within the scope of this disclosure and protected by the following claims.

Claims
  • 1. A system comprising: a sensor;a protective enclosure configured to enclose the sensor;a mounting pad configured to be attached to a location of a vehicle, the mounting pad having a contact area as a function of a weight of the sensor and the protective enclosure;a processor coupled to the sensor, the processor configured to associate the sensor with the location of the vehicle; andwherein the sensor and the protective enclosure are attached to the mounting pad, and the mounting pad is attached to the surface of the vehicle using an adhesive layer.
  • 2. The system of claim 1 wherein the sensor comprises a laser sensor emitting a laser signal and the protective enclosure comprises a window configured to allow the laser signal to be emitted.
  • 3. The system of claim 1 wherein the sensor comprises a laser sensor emitting a laser signal and the protective enclosure comprises a window configured to allow the laser sensor to be adjusted.
  • 4. The system of claim 1 wherein the mounting pad comprises a plurality of screw threads configured to accept the sensor and the protective enclosure if they have a weight that is less than a maximum acceptable weight for the mounting pad.
  • 5. The system of claim 1 wherein the mounting pad comprises a planar outer surface and a curved inner surface.
  • 6. The system of claim 1 wherein the mounting pad comprises a planar outer surface and a curved inner surface, the planar outer surface forming an internal cavity with the curved inner surface and two side walls.
  • 7. The system of claim 1 wherein the mounting pad comprises a planar outer surface and a curved inner surface, the planar outer surface forming an internal cavity with the curved inner surface and two side walls, wherein the two side walls are disposed at an angle of greater than 90 degrees from the planar outer surface and less than 90 degree from the curved inner surface to allow the curved inner surface to be larger than the planar outer surface.
  • 8. The system of claim 1 further comprising: a plurality of additional sensors, each located at an associated location of the vehicle; andthe processor coupled to the plurality of additional sensors and configured to associate each of the plurality of additional sensors with the associated location of the vehicle for that sensor.
  • 9. The system of claim 1 further comprising: a plurality of additional sensors, each located at an associated location of the vehicle; andthe processor coupled to the plurality of additional sensors and configured to associate each of the plurality of additional sensors with the associated location of the vehicle for that sensor and to generate a user control associated with the sensor and the plurality of additional sensors.
  • 10. The system of claim 1 further comprising the processor configured to generate a user control associated with the sensor.
  • 11. A method for retrofitting a vehicle comprising: selecting a mounting pad as a function of a vehicle design and a weight limit;securing the mounting pad to the vehicle with an adhesive;selecting a sensor and sensor housing as a function of the selected mounting pad;coupling the sensor to a processor;configuring the processor to associate a location on the vehicle with the sensor; andsecuring the sensor and the sensor housing to the mounting pad using a plurality of threaded connectors.
  • 12. The method of claim 11 wherein selecting the mounting pad as a function of the vehicle design further comprises selecting the mounting pad as a function of the sensor and the sensor housing.
  • 13. The method of claim 11 wherein selecting the mounting pad as a function of the vehicle design further comprises scanning a mounting surface contour with a three dimensional scanner to generate a contour data file.
  • 14. The method of claim 11 wherein selecting the mounting pad as a function of the vehicle design further comprises using a computer numerical control machining process to fabricate the mounting pad contour using the contour data file.
  • 15. The method of claim 11 further comprising associating a function of the processor with a signal generated by the sensor.
  • 16. The method of claim 11 further comprising associating a function of the processor with a signal generated by the sensor and a second sensor.
  • 17. The method of claim 11 further comprising associating a first function of the processor with a signal generated by the sensor and a second function of the processor with the signal generated by the sensor and a signal generated by a second sensor.
  • 18. The method of claim 11 further comprising associating a first function of the processor with a first signal generated by the sensor and a second function of the processor with a second signal generated by the sensor.
  • 19. The method of claim 11 further comprising associating a first function of the processor with a first signal generated by the sensor and a second function of the processor with a second signal generated by the sensor and a signal generated by a second sensor.
RELATED APPLICATIONS

The present application is a continuation-in-part of U.S. patent application Ser. No. 16/597,723 filed Oct. 9, 2019, which claims benefit of and priority to U.S. Provisional Application Ser. No. 62/743,584 filed Oct. 10, 2018, the present application is also a continuation-in-part of U.S. patent application Ser. No. 16/198,579 filed Nov. 21, 2018, which is a continuation-in-part of U.S. patent application Ser. No. 16/183,592 filed Nov. 7, 2018, which claims benefit of and priority to U.S. Provisional Application Ser. No. 62/582,739 filed Nov. 7, 2017, U.S. application Ser. No. 16/198,579 also claims benefit of and priority to U.S. Provisional Application No. 62/589,900 filed on Nov. 22, 2017, the present application is also a continuation-in-part of U.S. patent application Ser. No. 16/183,592 filed Nov. 7, 2018, which claims benefit of and priority to U.S. Provisional Application Ser. No. 62/582,739 filed Nov. 7, 2017, each of which are hereby incorporated by reference for all purposes, as if presented herein in their entireties.

Provisional Applications (4)
Number Date Country
62743584 Oct 2018 US
62582739 Nov 2017 US
62589900 Nov 2017 US
62582739 Nov 2017 US
Continuation in Parts (4)
Number Date Country
Parent 16597723 Oct 2019 US
Child 17181343 US
Parent 16198579 Nov 2018 US
Child 16597723 US
Parent 16183592 Nov 2018 US
Child 16198579 US
Parent 16183592 Nov 2018 US
Child 16183592 US