Various embodiments relate generally to a drive system for an endless track.
Track locomotion is used on many pieces of heavy equipment. Bulldozers, backhoes, and front-end loaders are examples of machines that can be configured with continuous or endless track systems of vehicle propulsion. Snowmobiles use an endless track drive system to engage a snow surface and provide locomotion to the snowmobile. Some military vehicles use an endless track propulsion system. Sometimes the term tank-tread locomotion is used, especially when referring to military tanks.
Endless track locomotion is sometimes used for off-road vehicle travel. Endless tracks can navigate terrain that is not flat or smooth. Vehicles designed for operation in such terrains may have endless track locomotion. Vehicles operating in off-road conditions may be susceptible to encountering off-road hazards, such as sharp objects or hard rocks. Endless track drive systems may not be as susceptible to locomotion failure when encountering such off-road hazards as would pneumatic tire systems.
Apparatus and associated methods relate to an endless-track drive wheel having axially-projecting roller cogs circumferentially distributed, the cogs configured to engage a lugged inner surface of an endless track at a radial distance from a wheel axis greater than a wheel radius. In an illustrative embodiment, an exemplary drive wheel may have cogs axially projecting from two opposing faces of the drive wheel. In some embodiments, each cog may include a roller bearing or bushing annularly coupled to a center post. In some embodiments, the cogs on each face may be periodically distributed at a radial distance from the axis of the drive wheel. The endless track may have a series of track lugs projecting from an interior surface. In some embodiments, the track lugs may be periodically arranged along the track to have a pitch corresponding to the pitch of the drive-wheel cogs. In some embodiments, the roller bearings may advantageously provide low-resistance drive coupling to the track.
Various embodiments may achieve one or more advantages. For example, some embodiments, low-resistance slip driven tracks may be tolerant of variations in track length. For example, tracks may expand or contract in response to environmental conditions. A track may contract in size due to cold weather, for example. A track drive system that permits slip may provide low-friction operation over a wide domain of track dimensions. In some examples, track life may be prolonged because of low-friction operation. In some embodiments, tracks may continue to be operable even if damaged and/or worn. For example, a track that has received shrapnel may remain operable even though the track may have a local abnormal dimension. In some embodiments, the track drive system may be more tolerant of dirty environments. For example, in a sandy and/or muddy environment sand and/or mud may get between the drive wheel and the endless track. The sand and/or dirt may effectively change the dimension of the endless track and/or the drive wheel. Roller cogs may permit accommodation of these modified dimensions.
Apparatus and associated methods may relate to a modular drone having a self-diagnostic system that monitors a heartbeat of each of a set of connected modules and identifies, in response to an abnormal heartbeat, a failing module. In various embodiments, the diagnostic system may, for example, determine the remaining functional capability of the drone absent the failing module, graphically display a needed replacement procedure, or report a remaining functional capability absent the failing module. In various embodiments, a user may toollessly replace the failing module and then re-employ the drone. In some embodiments, the drone may perform a diagnostic routine associated with the module whose heart beat is abnormal. The self-diagnostic system may advantageously simplify the in-field maintenance for operators with minimal training.
Various embodiments may achieve one or more advantages. For example, some embodiments may increase the uptime of drones in the field. For example, by providing graphical replacement instructions, in-field replacement by personnel with minimum training may be successfully performed. In some examples, the percentage of working drones may be maximized by scavenging the self-diagnosed working modules from otherwise non-working drones. Various embodiments may provide a user the Graphical User Interface (GUI) depicting only the drone's capabilities. This display of only working aspects of the drone may facilitate efficient drone operation by the user. For example, the user may not waste time by attempting to operate non-functional modules. By knowing what modules are operable, a user may better decide how the drone may be best deployed. In an illustrative embodiment, if the user determines that the drone's capability is not sufficient to the task at hand, the user may issue a return to home command. In some embodiments, the user may then be freed to perform another task, as the drone autonomously returns home without the need of operator input.
In various embodiments, the drone may automatically perform a reboot sequence for a module whose heart beat is abnormal. This reboot sequence may be performed in parallel with a report to the operator of the module's failure. In some embodiments, this parallel reboot may minimize the time to return to full operational capability. In some embodiments, the cost of maintenance may be minimized due to the interchangeability of modular components. For example, if a drone has one or more failing components, the entire drone need not be sent to a repair facility, but only the failing modular component(s). In some embodiments, the pulse rate of the heart beats of the components may be slowed to improve battery lifetime. For example, if a drone is in a reconnaissance mission, perhaps only a few of the modules, such as the camera and the transmitter/receiver may need to be functional, once the drone is in its destined location. The drone may turn off the unneeded modules and even periodically put to sleep the camera module, if frames need not be taken in real time.
In an exemplary embodiment, a payload may transmit its capabilities to the drone's base power unit when first connected. The base power unit may then transmit the payload capability and GUI interface to the controller in response to a new payload. The controller may then execute the GUI for controlling the newly connected payload. By using such a payload interface, the drones may need not be upgraded as new payloads are created.
The details of various embodiments are set forth in the accompanying drawings and the description below. Other features and advantages will be apparent from The description and drawings, and from the claims.
Like reference symbols in the various drawings indicate like elements.
To aid understanding, this document is organized as follows. First, an exemplary low-resistance slip drive system for an endless track is briefly introduced with reference to
An exposition of various exemplary aspects of robot modulatiry will then follow, with reference to
To aid understanding, this document is organized as follows. First, with reference to
In some embodiments, a track lug pitch 170 may correspond to an arc length 175 between adjacent roller shafts 115. For example, in some embodiments, the track lug pitch 170 may be substantially equal to the arc length 175 between adjacent roller shafts 115. In an exemplary embodiment, the track lug pitch 170 may be slightly larger than the arc length 175 between adjacent roller shafts 115, for example. When the track lug pitch 170 is slightly larger than the arc length 175 between adjacent roller shafts 115, the endless track 110 may slip with regard to the drive wheel 100. For example, the
In some embodiments, the guide wheels 320 may provide additional vehicle support and/or may assist in guiding the track. Such guide wheels 320 may be located between the idler wheel 315 and the drive wheel 310 along a bottom portion of the endless track 300. These guide wheels 320 may ensure that the endless track 300 has a large surface area that engages a ground surface. The guide wheels 320 may help the endless track 300 maintain ground contact beneath the guide wheels 320.
In some embodiment, the debris blocking members 325, 330 may have surface features that may direct the debris laterally away from a wheel/track interface. For example, the wheel-facing surface 330 may have groves to direct any debris caught between a wheel and the wheel facing surface 330 in a lateral direction (e.g. away from the wheel/track interface. In some embodiments, the track-facing surface 335 may have features for directing debris away from the wheel/track interface. In some embodiments, a brush may be positioned to brush debris away from the wheel/track interface, for example. In some embodiments, the track may have features on the inside surface that direction debris laterally away from the wheel/track interface.
In some embodiments, each roller bushing 405 may engage a track along a cylindrical exterior surface 440 of the roller bushings 405. A portion of the exterior cylindrical surface may contact an interior surface of the engaged track, for example. The portion of the exterior cylindrical surface that engages the track may be the portion that is most distal from the axis 430 of the drive wheel. For example a radial distance 445 from the drive wheel axis 430 to the distal portion of the exterior cylindrical surface 440 may be greater than a radial distance 450 from the drive wheel axis 430 to an exterior cylindrical surface of the drive wheel 400. In this way, the track may engage only the roller bushings 405 and not the drive wheel 400, in some embodiments.
In some embodiments, the each roller bushing 405 is configured to engage a drive feature on an inside surface of an endless track. Various embodiments may have various configurations of roller bushings. Each configuration of roller bushings, however, may correspond to a configuration of track drive features. In the
In some embodiments, the pitch 435 of the roller bushings 405 may be approximately equal to the pitch of corresponding track engagement features. When the pitch 435 of the roller bearings 405 is approximately equal to the pitch of the corresponding track engagement features, a plurality of roller bushings 405 may simultaneously engage a corresponding plurality of track engagement features. In some embodiments, the pitch 435 of the roller bushings 405 may be less than or greater than the pitch of the corresponding track engagement features. When the pitch 435 of the roller bushings 405 is less than or greater than the pitch of the corresponding track drive features, only one roller bearing (or two if axially aligned) may engage a track engagement feature during an engagement period.
In the
Although various embodiments have been described with reference to the Figures, other embodiments are possible. For example, in some embodiments, an endless track may circumscribe two or more roller being drive wheels. For example a roller bearing drive wheel may be both located at a front vehicle location and a rear vehicle location. In some embodiments, sealed bearings may be used to prevent debris contamination. In some embodiments, a roller bearing wheel may be used as an idler wheel to provide more lateral track engagement, for example.
At one of a front end 930 or a back end 935 of the substantially planar surface is an interface bar 940. The interface 940 bar has electrical connectors configured to receive complementary electrical connectors of the payload unit 910 aligned and longitudinally mated thereto. The interface bar 940 presents a vertical locking feature which mates with a complementary vertical locking feature on a received payload unit 910. The vertical locking features, when mated to one another, vertically couple the payload unit 910 to the base unit 905.
The payload unit 910 has a width 945 that is substantially equal to a separation distance between the two connecting rails 920. In practice, the width 945 of the payload unit 910 is a predetermined amount smaller than the distance separating the two parallel connecting rails 920 so as to permit the payload unit 910 to be able to longitudinally slide therebetween. When the payload unit 910 is set upon the substantially parallel surface 915 between the two connecting rails 920, the payload unit 910 may be slidably restricted by the connecting rails 920 to movement substantially only in the longitudinal direction. The payload unit 910 has an electrical connector configured to align with the electrical connector of the interface bar 940. The payload unit 910 has a vertical locking feature (e.g. a projecting member) that is configured to longitudinally align to the complementary vertical locking feature (e.g. aperture sized to receive a projecting member) when the payload unit 910 is upon the substantially planar surface 915 and between the parallel connecting rails 920.
The electrical connector and the vertical locking feature of the payload unit 910 may simultaneously mate with the complementary vertical locking feature and the electrical connector of the interface bar 940, when the payload unit 910 is longitudinally slid into a mating position with respect to the interface bar 940. The payload unit 910 is secured to the base unit 905 by securing a coupling member 950 of the payload unit 910 to a connecting rail 920 of the base unit 905. The coupling member 945 may be securing to the connecting rail 910 by use of a bolt, for example. Note that the coupling member 950 is configured to align to an anchor point 925 when the payload unit 910 is in the mating position with respect to the interface bar 940.
In the
In some embodiments, the interface bar 940 may be intended to face backwards and/or toward an operator. In an exemplary embodiment, an LED display may provide user feedback. For example, an LED display may indicate an error code indicative of a subsystem failure, for example. In some embodiments, a back-up camera may be on the interface bar. The interface bar may have a key interlock system to prevent unauthorized robot operations. In an exemplary embodiment, an interface bar may have a battery charge connector. In some embodiments, a transmitting antenna and a separate receiving antenna may be used for operator/robot communications. The robot may have a separate transmitter and receiver, each configured to select a portion of the spectrum for use in RF communications with an operator. Simultaneous transmissions and receptions may be performed using independent transmitters and receivers, for example.
After the endless track 1200 has been removed, the drive wheel 1235 can be removed from a drive axel 1240. Then the drive motor 1205 can be removed from the base unit 905. In the depicted embodiment, the drive motor 1205 is secured to the frame 1225 via fasteners connecting a flange 1245 of the drive motor 1205 to the frame 1225. The fasteners may be operated with a tool (e.g. a socket wrench). The fasteners may configured to use the same tool as that needed for the screw drive, for example. The motor can then be slid out of a motor cavity 1250 in the base unit 905. The motor cavity 1250 and the drive motor 1205 are keyed such that the drive motor 1205 can be slid into the motor cavity 1250 in only one axial orientation. The keyed axial orientation may align an electrical connector of the drive motor 1205 to a complementary connector of the base unit 905.
The power module 1225 has a cross-sectional profile that is commensurate to the cavity geometry of the power bay 1215. When the power module 1225 is received into the power bay 1215, vertical and longitudinal movement of the power module 1225 may be substantially restricted. Complementary electrical connectors of the power module 1225 and the modular subsystem assembly 1200 are configured to horizontally align with one another when the power module 1225 is inserted into the power bay 1215 of the hardware cabinet 1205.
The supervisors 2005, 2010 may perform a system capability inventory beginning with a system startup procedure. A supervisor 2005 may sequentially turn on each of the subsystems. To do this, the supervisor 2005 may send a turn-on command signal to a subsystems. The subsystems may then initiate a turn-on sequence in response to the received turn-on command signal. The module then has a hardware heartbeat signal that is communicated to supervisor on a dedicated communications channel (not depicted). If the supervisor does not receive the hardware heartbeat signal, the supervisor may determine that the subsystems is functionally compromised. The supervisor may then reevaluate a resource allocation to determine if the mission can still be completed using the available resources. If the supervisor determines that the mission can still be completed, the supervisor may reschedule the planned operations of the available subsystems.
After each module has been awakened and have reported a hardware heartbeat, the modules periodically will report a software heartbeat on a shared system bus 2025. Each software heartbeat may contain detailed information as to the status of various modules of the subsystem. A motor controller, for example, may report, in a software heartbeat package, the voltage applied and the current drawn by a drive motor. Such a status may indicate to the supervisor that the motor is laboring (e.g. perhaps driving up a grade). Other examples may include a heartbeat reporting a temperature of a component and/or a speed of rotation. Each subsystem may also perform some analyses of the subsystem health based upon these and/or other subsystem metrics. For example, the subsystem may report, in a software heartbeat package, that the subsystem is healthy. Or perhaps the subsystem may report a health grade based upon various subsystem metrics.
Each subsystem may have a set of health codes that are specific to the particular subsystem. The supervisors 2005, 2010 then, after receiving software heartbeats from multiple subsystems, may perform higher level analyses based on the reported metrics. For example, a supervisor 2005, 2010 may receive a power consumption metric of a motor from a motor controller along with an attitude metric from an attitude sensor. The supervisor 2005, 2010 may determine from a high power consumption report combined with an inclined attitude report, that the power consumed by the motors is appropriate for the inclined attitude climb.
Based upon the reported metrics from the various subsystems, the supervisor 2005, 2010 may create one or more system states reflective of one or more combinations of subsystem states. Some of the system states may be associated with predetermined robot conditions. These predetermined robot conditions may have operating procedures associated with them. In some cases, the system state may be a new combination of subsystem metrics. The robot may then associate the measured metrics with this new system state. In this way, the robot may “learn” its own operating capabilities that are achievable in the new state.
An exemplary robot may perform a mission that includes a sequence of tasks. Each task may include an ordered set of goals. For each task, the robot may periodically calculate a probability of completing the current set of goals. The goal-achievement probability metric may be calculated using Bayesian statistical methods, for example. The probability of successfully completing the task may be expressed as a confidence measure.
During operation, an exemplary robot may monitor the current state of the robot's various subsystems. For example, the robot may determine an overall health-condition metric for the robot based upon a series of health metrics for the various systems. The overall health-condition metric may, for example, be calculated using a weighted sum of the health metrics of each of the systems, sub-systems, and/or sub-sub-systems. The state of each component may be a numerical representation of the probability that the component accurately will deliver the capability that is designed to deliver. An exemplary robot may calculate the overall health-condition metric using conditional probability mathematics, for example.
In an exemplary scenario, a robot may be tasked to navigate to a destination. The robot may be given a sequence of intermediate waypoints as a path for ultimately reaching the destination. The exemplary navigation process may proceed in the following manner, for example. The robot may first identify whether the current system configuration supports navigation. Then, the robot may determine its current location and calculate a confidence metric associated with the calculated current location. The robot may then compare the calculated confidence metric with a predetermined confidence threshold. If the calculated confidence metric is greater than the predetermined threshold, the robot may calculate a bearing and a distance from the robot's determined current position and a location of the next waypoint.
The robot may then determine if the calculated distance is less than a predetermined threshold, so that the robot can be considered as having achieved that waypoint position. If the robot has not achieved the waypoint position, the robot will then calculate a bearing direction to the waypoint. The robot then may calculate drive speed that will optimally complete the task based on predetermined completion metrics. The robot may then return to the waypoint distance calculation and repeat the subsequent steps until the waypoint position has been achieved.
To determine whether the robot's current system configuration supports navigation, the robot may evaluate whether a requisite set of subsystems is available and operational. For example, an exemplary robot may require a Global Positioning System (GPS) system, a compass, and a motor driver, in order for navigation operations. The GPS system may provide current Universal Transverse Mercator (UTM) coordinates and a current heading, for example. The compass may prove a bearing, and the motor drive may provide locomotion.
In addition to these subsystems, optional subsystems may provide increased navigation abilities. For example, a robot may be equipped with a Light Detection and Ranging (LIDAR) system that provides complex proximity information. Such information may be used in object avoidance tactics during a navigation operation. A robot may be equipped with an ultrasonic array that provides simple proximity information, for example.
A numerical state may be calculated for each of the navigation related subsystems. The numerical state may represent a probability that the subsystem can accurately deliver a capability associated with the subsystem. These numerical states for the various navigation related components may be combined to determine a numerical state for the entire navigation system. The determined numerical state for the entire navigation system may represent a probability that the navigation system can accurately perform a navigation operation.
Prior to each navigation task, the robot may determine this numerical state of the navigation system and compare with a predetermined threshold. And then, only if the numerical state compares favorably with the predetermined threshold will the robot perform the navigation operation, for example. In some embodiments an overall system capability state may be calculated using a weighted sum of numerical states for the requisite individual tasks. In an exemplary embodiment an overall system capability state may be calculated using a product of all the numerical states for the requisite individual tasks.
In some embodiments, a posterior probabilities may be calculated to determine a numerical state of a subsystem. For example, if one assumes a hypothetical scenario that includes the following events: A) the GPS obtains a lock and begins providing location and heading data; and B) the location and heading data of the robot is accurate. If then one assumes that P(A)=0.95, P(B|A)=0.9, and P(B|˜A)=0.1, one can calculate the posterior probability that the GPS has obtained lock given that the robot's bearing and heading data is accurate −P(A|B):
Using the above assumptions, this expressions results in P(A|B)=0.994. Thus the probability that the GPS obtains lock is very high if the robots bearing and location are accurate. Such calculations can be used to evaluate the numerical state of other subsystems as well.
In the same way that the system monitors and updates the probabilities associated with a component, the system also may monitor the effectiveness of the weighting factor for each component and/or may adjust the weighting depending on the outcome of the subsequent task and its associated goals. In this way the system may learn to find the most appropriate weightings for each component capability state, their effect on the system capability state and/or the outcome of the planned task.
For example if the system capability state is marginally less than that required to proceed to the next step the system may arbitrarily adjust probabilities or weightings to achieve the threshold for continuing to the next step. At the completion of the current task the system may then evaluate whether the changes improved the delivery associated goals and the successful completion of the current task. If so the new probabilities or weightings may be stored and re-used the next time the UGV attempts to complete the same type of goal. If not the changes may be discarded.
In some embodiments, a robot may require a precise calculation of a current robot location. The navigation system may use a single sensor to provide location data. The accuracy of the GPS fix may vary over time, and so the quality of a single measurement may be suspect in certain circumstances. These measurement-quality variation may be accounted for using Bayesian Inference, wherein each previous GPS fix is represented within a set of “Prior Classes” or Priors. Using a conjugate prior approach a number of the latest GPS fixes can be used in conjunction with the current fix to increase the systems confidence in its current location. This may be accomplished when the robot is stationary and each GPS fix is not varying due to changes in the position of the UGV.
The prior distribution consisting of historical GPS fixes, associated weighting and/or Likelihood, and the current GPS fix may be evaluated using a Differential Evolution-Markov chain Monte Carlo sampling algorithm to generate a confidence in the current location being within a predetermined location-error distance of the current measured location.
In some embodiments, a robot may calculate bearing and distance of a waypoint form UTM coordinates. As the earth can be represented as a flattened sphere, the distance and bearing between two points depends on the location of the points within the co-ordinate system (e.g. the location on the earth where the two points are). The bearing and distance can be estimated over short distances without taking the co-ordinate system into account. While this may provide adequate navigation parameters in most circumstances, for accuracy an exemplary robot may calculate the distance and bearing between the points using the “Haversine” formula:
In the above calculations, λ is a latitude coordinate and φ is a longitude coordinate.
The modular nature of various exemplary robots may allow new components and capabilities to be added to the robot at any time. If, for example, the navigation task described above uses ultrasonic sensors to provide obstacle vision to facilitate robot navigation around obstacles, a system capability state may be set at an appropriate level. If a LIDAR is added to the system, both a system capability state and a confidence of successfully completing the current task may be increased allowing for successful completion of the navigation task.
Each parameter used to achieve each goal making up a task may be continually monitored and adjusted by a robot numerical state. This may facilitate the robot to “learn” the best parameters for each goal. Numerical state, weighting, and more basic parameters may be adjusted and evaluated once each of the tasks are completed. Over time each individual robot subsystem may store a large number of learned data structures consisting of, for example: 1) the robot configuration; 2) a set of system/component parameters, which may include probabilities and weightings; and 3) a set of task/goal parameters, which may include probabilities and weightings.
Each time two or more UGVs encounter each other, the UGVs will negotiate a quorum and communicate what they have learned between the quorum members. This communication, achieved over IP, RF or Bluetooth 4.0 (BTLe) networks identifies the best parameters for a task or goal and allows each quorum member to try those parameters the next time they complete the described task. Each quorum member then has the option of retaining or discarding the new parameters depending on its experience of task completion.
In some embodiments, numerical states may be determined for each navigation operation. For example, in some embodiments, separate numerical states may be determined for one or more of the following navigation operations: i) identifying a current location; ii) knowing a location of the next waypoint in UTM coordinates; iii) having the ability to calculate the required bearing to the next waypoint; iv) having the ability to calculate the required distance to the next waypoint; v) having the ability to accurately measure the current heading of the robot; vi) having the ability to turn the robot to the required bearing; and vii) having the ability to move the robot towards the next waypoint.
Each of the calculated numerical states may represent a probability that the robot can successfully perform the associated operation. In some embodiments, the robot may embark on the operation if, for example, the minimum calculated numerical state is greater than a predetermined threshold.
The depicted modular drone 2605 may have various modules deployed. In the depicted embodiment, the modular drone 2605 has two motor drives 2630, 2635. Each of the motor drives 2630, 2635 may be toollessly replaceable. Each of the motor drives 2630, 2635 may be controlled by a motor controller 2640, 2645, for example. Each of the motor controllers 2640, 2645 may be toollessly replaceable, for example. Each motor 2630, 2635 may be independently controlled. In some embodiments, each motor 2630, 2635 may provide locomotive drive to one side of the modular drone 2605, for example. In the depicted embodiment, two top wheels 2650, 2655 may be coupled via a toothed track, for example. The top motor drive 2635 may drive the top wheel 2655, which may in turn drive the top wheel 2650 via the toothed track (not depicted). Similarly, two bottom wheels 2660, 2665 may be coupled together via a toothed track. The bottom motor 2630 may drive the bottom wheel 2660, which may in turn drive the bottom wheel 2665 via the toothed track (not depicted). Each motor drive 2630, 2635 may be identical, which may reduce the number of different replacement parts needed. In an exemplary embodiment, a replaceable drive module may include both a motor drive 2630 and the wheel 2660 driven by the motor drive 2630, for example.
The depicted modular drone 2605 may have a toollessly removable power supply 2670. The power supply may be a battery, for example. Various battery technologies may be used to supply power to the modular drone 2605. In some embodiments, the battery may be a lithium ion battery. In some embodiments, lead-acid batteries may be used. In some embodiments, silver-zinc battery chemistry may be used in the power supply 2670. Nickel-metal hydride batteries may be used in an exemplary embodiment. Nickel-zinc batteries may be used. Other battery technologies may also be employed as power sources, for example according to electrical payload and/or modular drone loading specifications, alone or in combination with, for example, mission duration, environmental exposure, and/or cost, for example.
The modular drone 2605 may have one or more modular payloads 2675 attached. The payload 2675 may be toollessly replaceable. Each payload may be mechanically attached in a toolless manner, for example. Each payload may be electrically attached in a toolless manner. In some embodiments, electrical communication between the payload 2675 and an electronic bay 2680 may be wireless. In some embodiments, electrical communication between the payload 2675 and an electronic bay 2680 may be wired. In some embodiments, the payload 2675 may communicate directly with the controller 2600. A payload 2675 may have its own power source. In some embodiments, the payload 2675 may draw operating power from the modular drone's power supply 2670. The electronics bay 2680 may have toollessly removable components. In some embodiments, a micro-processing component 2685 may be toollessly replaceable, for example. In the depicted embodiment, a payload interface component 2690 may be toollessly replaceable. An image capture component 2695 is also depicted in the
In the
In various embodiments, a self-diagnostic system may monitor the status of various modules. In some embodiments, the self-diagnostic system may be performed by the processor 2685 of the modular drone 2605. In some embodiments, the self-diagnostic system may be performed by the processor 2602 of the drone controller 2600. In some embodiments, each module may perform its own self-diagnostic evaluation. In such an embodiment, each module may report its status to the processor 2685 of the modular drone 2605, for example. In some embodiments, a combination of the above described self-diagnostic methods may be employed. In some embodiments, the processor 2685 may periodically poll a module, requesting status information of the polled module. In some embodiments, the processor 2685 may periodically perform a diagnostic test of a module, for example. In an exemplary embodiment, a module may perform its own self-diagnostic test. In some embodiments, a module may periodically report its status to the processor 2685. The periodic reporting of status may be termed a heart-beat, for example. In some embodiments, the polling of a module may be termed a heart-beat.
The processor 2602 of the drone controller 2600 may perform instructions retrieved from a memory bank 2617. In some embodiments, the memory bank 2617 may have a program region 2627. In some embodiments, the memory bank 2617 may have a data region 2632. The processor may store information received from the drone to a non-volatile storage bank 2622. Various man-machine interface elements may be used to facilitate a user's control of the modular drone 2605. For example, a keyboard 2637 may provide key entry capability between a user and the processor 2602. In some embodiments, a game-type of controller 2642 may receive control instructions from a user and generate electronic signals in response to the control instructions. In some embodiments, the game controller 2642 may have one or more buttons for the user to press. In an exemplary embodiment, the game controller 2642 may have a joystick to receive directional instructions from a user. In an exemplary embodiment, the game controller 2642 may have orientation detectors that convert the controller's orientation into electronic signals. In some embodiments, the controller 2642 may have inertia or motion detectors which convert the game controller movements to electronic signals. In an illustrative embodiment, the game controller 2642 may detect the magnetic field and convert the detected field into an electronic signal.
Various other man-machine interface components may be included in the drone controller 2600. For example, a touch screen display 2647 may permit a user to touch the screen to provide information to the processor 2602. For example, the user may touch a power control to increase the drive power to the modular drone 2605. The user may direct a camera on the drone, for example, by touching a camera elevation grid displayed on the screen. In some embodiments, when a user touches a graphical representation of one of the modules, the processor will send status information for display on the screen.
The first payload region 2710 in the depicted embodiment shows real-time imagery 2740 as captured by a payload camera. The first payload region 2710 may also display camera angle. In some embodiments, elevation 2745 and azimuth 2750 camera angles may be displayed. In some embodiments camera angles may be graphically depicted and referenced to a silhouette of the modular drone. For example, the camera azimuth 2750 may be shown as a graphical camera turning about the graphical outline of a modular drone. Various payloads may provide various types of information to the payload region 2710 of the display screen 2700. The GUI associated with each payload may be stored in memory in the payload itself, in some examples. This GUI information may be transmitted to a drone controller shortly after power-up of the payload, for example. The GUI information may also be stored in an electronics module associated with the payload. GUI information may also be loaded into the controller in a variety of ways. The controller may download GUI information from the internet, for example. In some embodiments, the GUI information may be preloaded into the controller.
The second payload region 2715 in the depicted embodiment controls a throw-bot launcher. In some scenarios, it may be desirable to infiltrate a facility with a small autonomous mobile robot. In such a scenario, a throw-bot module may be attached to the modular drone. The throw-bot module may be controlled by an associated throw-bot GUI, for example. In the depicted exemplary throw-bot GUI, a launching tube, which projects a throw-bot therefrom may be controlled. The payload may have a range detector and report the range 2755 to the drone controller for display. The payload may have a wind speed detector. The wind speed 2760 may be transmitted to the controller for display. The GUI may use the received range and wind speed to calculate an azimuth angle and an altitude angle for launching the throw-bot. The GUI may calculate, for example, a muzzle velocity 2765 for launch. In some embodiments, a launch button 2770 may be pressed by a user to initiate launch of the throw-bot.
In the depicted embodiment, an information payload interface system is shown to include an information connection port 2840. The information connection port may include electrical connectors, for example. In some embodiments, the information connection port may include optical connectors. In some embodiments, the information payload interface system may include wireless communication between a payload and the power base 2800. A short range wireless communications system may use Bluetooth protocols for example. Some embodiments may use near field communications standards, for example. In some embodiments can bus communications standards may be used. In an exemplary embodiment, non-standard communications protocols may be used.
Although various embodiments have been described with reference to the Figures, other embodiments are possible. For example, various embodiments may provide various methods of locomotion. In some embodiments, locomotion may be performed using wheels. In some embodiments, four wheels may be used. In an exemplary embodiment, eight wheels may contact the ground and provide locomotion. In some embodiments, two wheels may provide drive to the modular drone. In some embodiments, four drive wheels may provide motion to a drone. In some embodiments, a single drive motor may drive two wheels. In an exemplary embodiment, motion may be supplied by moving legs. In some embodiments, a drone may be moved using hovercraft technology. In an illustrative example, the type of locomotion may be changed by exchanging the modular drive mechanism with a new drive mechanism. This exchange of drive mechanism may be toollessly performed in some embodiments.
In an illustrative embodiment, the self-diagnostics may be performed at multiple levels. For example, in some embodiments, each module may perform periodic self-diagnosis. A power base, may periodically diagnose each module independently, for example. In some examples, both diagnoses may be transmitted to a remote drone controller. A drone controller may use the self-diagnostic information to provide a user with a recommended strategy. For example, if one of the motors is inoperable, the recommendation may be to suggest the user actuate a linking member between both sides of the drone locomotion assembly. When the two sides are linked, for example, the drone may be capable of forward and reverse travel. If turning is desired, unlinking may provide a turning mechanism for a drone having one drive side capability.
In some embodiments, a GPS system may provide the return path to the drone. In an exemplary embodiment, the time sequence of the motor actuation that was used during deployment may be used to recreate a return path motor activation sequence. In some embodiments, a user may send a return to home command, to which the drone may respond by backwards tracing the route taken to the deployed location, for example.
Drones may be used as a surrogate for a person in dangerous situations. For example, flying drones may be used by the military to perform reconnaissance operations in enemy territories. Specialized drones may be equipped with specialized equipment to perform mission unique functions. Some military drones may collect battlefield imagery. Some military drones may be equipped with weapons. Flying drones may come in different sizes for performing different mission operations. Some large drones may have long range capabilities, while small drones may be employed for local operations, for example.
Drones also may be used in non-military applications. For example, drones may be used to explore caves within the earth. Drones may be used to assist law enforcement personnel, for example. Drones or robots also may be used recreationally as battling entities. Various organizations may establish battling rules for different classes of robots. People then may program and enter their robots into the battling tournament.
Some aspects of embodiments may be implemented as a computer system. For example, various implementations may include digital and/or analog circuitry, computer hardware, other sensors (e.g. temperature sensors), firmware, software, or combinations thereof. Apparatus elements can be implemented in a computer program product tangibly embodied in an information carrier, e.g., in a machine-readable storage device, for execution by a programmable processor; and methods can be performed by a programmable processor executing a program of instructions to perform functions of various embodiments by operating on input data and generating an output. Some embodiments can be implemented advantageously in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and/or at least one output device. A computer program is a set of instructions that can be used, directly or indirectly, in a computer to perform a certain activity or bring about a certain result. A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
Suitable processors for the execution of a program of instructions include, by way of example and not limitation, both general and special purpose microprocessors, which may include a single processor or one of multiple processors of any kind of computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for executing instructions and one or more memories for storing instructions and data. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including, by way of example, semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and, CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits). In some embodiments, the processor and the member can be supplemented by, or incorporated in hardware programmable devices, such as FPGAs, for example.
In some implementations, each system may be programmed with the same or similar information and/or initialized with substantially identical information stored in volatile and/or non-volatile memory. For example, one data interface may be configured to perform auto configuration, auto download, and/or auto update functions when coupled to an appropriate host device, such as a desktop computer or a server.
In some implementations, one or more user-interface features may be custom configured to perform specific functions. An exemplary embodiment may be implemented in a computer system that includes a graphical user interface and/or an Internet browser. To provide for interaction with a user, some implementations may be implemented on a computer having a display device, such as an LCD (liquid crystal display) monitor for displaying information to the user, a keyboard, and a pointing device, such as a mouse or a trackball by which the user can provide input to the computer. For example, wearable devices, such as Google Glasses or other technologies may facilitate input and/or output operations between a user and a system.
In various implementations, the system may communicate using suitable communication methods, equipment, and techniques. For example, the system may communicate with compatible devices (e.g., devices capable of transferring data to and/or from the system) using point-to-point communication in which a message is transported directly from the source to the receiver over a dedicated physical link (e.g., fiber optic link, point-to-point wiring, daisy-chain). The components of the system may exchange information by any form or medium of analog or digital data communication, including packet-based messages on a communication network. Examples of communication networks include, e.g., a LAN (local area network), a WAN (wide area network), MAN (metropolitan area network), wireless and/or optical networks, and the computers and networks forming the Internet. Other implementations may transport messages by broadcasting to all or substantially all devices that are coupled together by a communication network, for example, by using omni-directional radio frequency (RF) signals. Still other implementations may transport messages characterized by high directivity, such as RF signals transmitted using directional (i.e., narrow beam) antennas or infrared signals that may optionally be used with focusing optics. Still other implementations are possible using appropriate interfaces and protocols such as, by way of example and not intended to be limiting, USB 2.0, Firewire, ATA/IDE, RS-232, RS-422, RS-485, 802.11 a/b/g/n, Wi-Fi, Ethernet, IrDA, FDDI (fiber distributed data interface), token-ring networks, or multiplexing techniques based on frequency, time, or code division. Some implementations may optionally incorporate features such as error checking and correction (ECC) for data integrity, or security measures, such as encryption (e.g., WEP) and password protection.
A number of implementations have been described. Nevertheless, it will be understood that various modification may be made. For example, advantageous results may be achieved if the steps of the disclosed techniques were performed in a different sequence, or if components of the disclosed systems were combined in a different manner, or if the components were supplemented with other components. Accordingly, other implementations are contemplated.
This application claims the benefit of U.S. Provisional Application Ser. No. 61/900,256, titled “Modular Drone with Self-Diagnostic Performance Maximization,” filed by Norm Domholt et al., on Nov. 5, 2013, U.S. Provisional Application Ser. No. 62/046,264, titled “Low-Resistance Slip Drive of Endless Track,” filed by Michael Thoreson et al., on Sep. 5, 2014, and U.S. Provisional Application Ser. No. 62/050,582, titled “Low-Resistance Slip Drive of Endless Track,” filed by Michael Thoreson et al., on Sep. 15, 2014. The entirety of each of the foregoing applications is hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
61900256 | Nov 2013 | US | |
62046264 | Sep 2014 | US | |
62050582 | Sep 2014 | US |