When performing autonomous takeoff and/or landing, an important piece of information is the altitude of the aircraft. Some types of altitude sensors, such as sensors which use radar to measure altitude, have a “dead zone” near the ground where the sensors produce unreliable, inaccurate, and/or erroneous altitude measurements. To compensate for this, some autonomous takeoff and/or landing systems use two types of altitude sensors: one for altitude measurements at lower altitudes and another for altitude measurements at higher altitudes. This adds to the weight and cost of the aircraft, which is undesirable. New techniques for performing autonomous takeoff and/or landing that can accommodate an altitude-measurement dead zone and which are lighter and/or less expensive would be desirable.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
Autonomous flight techniques, including landing and takeoff, are disclosed. Measurements made by altitude sensors can be passed on to a controller in one mode of operation, and prevented from being passed to the controller in another mode of operation (e.g., when the sensors are expected to be unreliable or erroneous). In an open loop mode of operation (over a first range of altitudes), a plurality of altitude-related data from a plurality of altitude-related sensors is ignored. In a closed loop mode of operation (over a second range of altitudes), the plurality of altitude-related data from the plurality of altitude-related sensors is used. The first range of altitudes is a non-overlapping, lower range of altitudes compared to the second range of altitudes. In one aspect, this allows a single type of altitude sensor to be provided in an aircraft instead of needing multiple types of sensors, which reduces the weight and cost of the aircraft.
The invention can be implemented in numerous ways, including as a process; an apparatus; a system; a composition of matter; a computer program product embodied on a computer readable storage medium; and/or a processor, such as a processor configured to execute instructions stored on and/or provided by a memory coupled to the processor. In this specification, these implementations, or any other form that the invention may take, may be referred to as techniques. In general, the order of the steps of disclosed processes may be altered within the scope of the invention. Unless stated otherwise, a component such as a processor or a memory described as being configured to perform a task may be implemented as a general component that is temporarily configured to perform the task at a given time or a specific component that is manufactured to perform the task. As used herein, the term ‘processor’ refers to one or more devices, circuits, and/or processing cores configured to process data, such as computer program instructions.
A detailed description of one or more embodiments of the invention is provided below along with accompanying figures that illustrate the principles of the invention. The invention is described in connection with such embodiments, but the invention is not limited to any embodiment. The scope of the invention is limited only by the claims and the invention encompasses numerous alternatives, modifications and equivalents. Numerous specific details are set forth in the following description in order to provide a thorough understanding of the invention. These details are provided for the purpose of example and the invention may be practiced according to the claims without some or all of these specific details. For the purpose of clarity, technical material that is known in the technical fields related to the invention has not been described in detail so that the invention is not unnecessarily obscured.
Various embodiments of a technique to perform autonomous flight (e.g., an autonomous takeoff or an autonomous landing) are described herein. First, an embodiment of an autonomous flight process which operates in an open loop mode and a closed loop mode over a first range of altitudes and a second range of altitudes, respectively, is described. As will be described in more detail below, this technique ignores altitude-related data during a dead zone (and possibly some margin above that) and incorporates or otherwise uses the altitude-related data when (e.g., safely) outside of the dead zone.
At 100, autonomous flight is performed in an open loop mode over a first range of altitudes, wherein a plurality of altitude-related data from a plurality of altitude-related sensors is ignored while performing the autonomous flight in the open loop mode. As used herein, the term “altitude-related data” may include altitude values themselves or signals or values from which altitudes are subsequently determined (e.g., if the altitude measurement technique is radar based, the altitude-related data may be the received radar signal or some value or property related to it (e.g., a phase associated with the received radar signal)).
In open loop mode, instead of using the altitude-related data (or, more generally, measured data or a measured signal) to adjust some desired value or desired signal using a feedback loop, the desired value or desired signal is passed directly to the control surfaces (e.g., rotors in a multicopter) without adjustment or modification based on the measured data (i.e., the altitude-related data).
Operating in an open loop mode at step 100 is to address the unreliable and/or erroneous nature of the altitude-related data at lower altitudes. At lower altitudes, some types of altitude-related sensors are unreliable and/or report incorrect altitudes. For convenience and brevity, this region or airspace associated with unreliable and/or incorrect altitudes is sometimes referred to herein as a dead zone. To deal with the unreliable and/or incorrect altitude-related data in the dead zone, the potentially incorrect altitude-related data is ignored at step 100, specifically by performing autonomous flight in an open loop mode (e.g., where the altitude-related data is not used in a feedback loop). In some embodiments, the autonomous flight which is performed at step 100 is an autonomous takeoff. Alternatively, the autonomous flight at step 100 may be an autonomous landing.
At 102, autonomous flight is performed in a closed loop mode over a second range of altitudes, wherein: the plurality of altitude-related data from the plurality of altitude-related sensors is used while performing the autonomous flight in the closed loop mode; and the first range of altitudes is a non-overlapping, lower range of altitudes compared to the second range of altitudes.
In some embodiments, depending upon whether the aircraft is performing an autonomous takeoff or landing, different techniques are used to switch between the open loop mode in step 100 and the closed loop mode in step 102. In some embodiments, if an autonomous takeoff is being performed (e.g., where step 100 occurs first and then step 102 is subsequently performed), the altitude-related data and/or some related metadata (e.g., a reliability or confidence value) is/are analyzed to determine when the altitude-related data may be trusted and thus the system can switch to the closed loop mode in step 102. Alternatively, if an autonomous landing is being performed (e.g., where step 102 occurs first and then step 100 occurs), in some embodiments the switch between the two modes occurs once a certain altitude threshold is reached (e.g., which is safely above the dead zone).
To deal with the dead zone, some other types of autonomous flight systems use two types of sensors: one for lower altitudes and one for higher altitudes. Naturally, this adds weight to the aircraft since two types of sensors are included. For (ultra) lightweight aircraft, the additional weight is very unattractive. In contrast, the technique described herein is much lighter since a new (e.g., dead zone) altitude measuring system does not need to be added.
The following figure shows an example of how the altitude-related data is ignored and used while in the open loop mode and closed loop mode, respectively.
The combined altitude is passed to a controller (204) which in this example (for simplicity and ease of explanation) converts the combined altitude into a corresponding throttle value. For example, the throttle value may correspond to a torque value or a rotations per minute (RPM) value.
The throttle value is passed to one or more rotors (206) (e.g., which are part of a multicopter). The rotors cause a change in the aircraft's state (e.g., the aircraft's in-air position, including altitude) and those changes are measured by the altitude-related sensors (208) which output one or measured altitudes. For simplicity and convenience, the output of the sensors is simply referred to as “altitudes” but more generally may be any type of altitude-related data. As described above, since the aircraft is at relatively low altitudes where there is low confidence in the measured altitude(s), the open switch (200a) prevents that unreliable and/or erroneous information from being used by the rest of the system.
Referring back to
The following figure shows one example of an aircraft which uses the autonomous flight technique shown in
One benefit to using such a multicopter is that it has a relatively high disc area (e.g., relative to the overall size). The relatively high disc area, combined with the relatively light weight of the multicopter, makes the multicopter more forgiving and/or tolerant when autonomously flying, in particular, during open loop mode at step 100 in
The dead zone is shown here as a dotted region corresponding to altitudes less than or equal to altitudedeadzone (302). In this region, the altitude-related sensors are unreliable and the altitude-related data which is produced cannot be trusted. To handle this, when the multicopter is at an altitude below altitudeOL↔CL (304), shown here as a shaded region, the multicopter will perform autonomous takeoffs and/or landings in an open loop mode (e.g., where the altitude-related data is ignored). See, for example, step 100 in
When the multicopter is at an altitude between altitudeOL↔CL (304) and altitudepilot↔auto (306), shown here with a grid pattern, the multicopter operates in a closed loop mode (e.g. where the altitude-related data is used). This corresponds to the closed loop mode at step 102 in
At altitudes above altitudepilot↔auto (306), the aircraft operates in a pilot-guided flight mode. In other words, the autonomous flight system is turned off in favor of (at least partially) manual flight where the pilot guides the aircraft. For example, during an autonomous takeoff, multicopter 300 may ascend to some desired altitude, at which point the autonomous flight system is turned off and the multicopter hovers midair until the pilot starts guiding the multicopter using the joystick or some other input device. This is one example of altitudepilot↔auto (306). Or, an autonomous landing may be triggered by an instruction from the pilot to begin an autonomous landing procedure. The altitude of the multicopter at that point (e.g., when the autonomous landing instruction is issued) would then be altitudepilot↔auto (306).
Referring back to
It is noted that the exemplary altitude ranges shown here are relatively simplistic for ease of explanation. As will be described in more detail below, in some embodiments, the altitude at which a switch is made between an open loop mode and a closed loop mode is not necessarily a predefined altitude or some altitude threshold, but rather at some point when one or more criteria (e.g., associated with ensuring that altitude-related data is reliable) have been satisfied.
In some embodiments, multicopter 300 has ten rotors with the following directions of rotation (where the rotor's position is relative to the pilot and the direction of rotation is when viewed from above).
This alternation of rotational direction may enable the multicopter to fly more efficiently. A rotor creates lift when the blade is traveling against the direction of wind and does not create lift when it spins in the direction of wind. By stacking up alternating rotors one behind the next in the direction of flight (e.g., typically forwards), the multicopter may experience a consistent amount of lift and/or decrease intervals of decreased lift.
In some embodiments, the rotors of multicopter 300 are connected or otherwise mounted (e.g., to the rest of the multicopter) at the following roll angles and pitch angles. It is noted that opposite rotors (e.g., where the fuselage acts as an axis of symmetry) have roll angles of the same magnitude but opposite signs and the same pitch angle. Generally speaking, the roll angles and pitch angles have magnitudes within the range of 0 degrees and 10 degrees.
There are a number of benefits associated with the tilt positions shown in this example. First, all of the rotors have a slight (e.g., ˜5 degrees) forward bias so that when the aircraft is flying forwards, the body of the aircraft remains level. Also, the tilt positions of the rotor angles are selected to maximize the aircraft's ability to yaw while minimizing the impact of losing any single rotor. The more a rotor is tilted, the more it contributes to yawing the vehicle when it is sped up or down.
The rotors are mounted to the multicopter (e.g., more specifically, to the floats for the inner rotors and to the arms for the outer rotors) in a fixed manner at the roll angles and pitch angles shown in a fixed manner. In other words, the rotors cannot change their tilt positions from the positions shown. To maneuver, each rotor is independently controllable (e.g., different amounts of torque can be applied to each rotor), such that each rotor can rotate at a different speed or output a different amount of thrust.
The various tilt positions shown here enable the multicopter to maneuver more efficiently compared to some other multicopter designs. For example, consider another multicopter where the rotors only tilt forward or backward to some degree (i.e., all of the rotors have a roll angle of 0°). To move sideways (e.g., left or right), such a multicopter may have to expend more power because none of the rotors have a non-zero roll angle which would help to move the multicopter laterally to the left or right. In contrast, the multicopter shown here can move sideways in a more efficient manner because the rotors have non-zero roll angles.
The following figure shows an example of a state machine which includes autonomous takeoff and autonomous landing.
During state 400, the system continuously assesses whether it is sufficiently confident about the altitude-relative. In various embodiments, a variety of information can be analyzed in making this determination. In some embodiments, an altitude-related sensor outputs both an altitude (or, more generally, altitude-related data) as well as a confidence metric (or, more generally, metadata) associated with the altitude. For example, the confidence metric may range from 0% (e.g., where the altitude-related sensor knows for sure that the altitude being output is erroneous) to 100% (e.g., where the altitude-related sensor knows for sure that the altitude being output is accurate). In some embodiments, when all of the sensors have confidence metrics that are greater than some confidence threshold, the sensor data may be used.
Alternatively, an altitude-related sensor may output just altitudes without any context or metadata indicating when those values are trustworthy and/or accurate. In some such embodiments, there are multiple altitude-related sensors (e.g., each of which employs a different technique to measure altitude, such as GPS, radar-based, etc.). In some embodiments, when all of the altitudes are in agreement about the altitude to within some predefined degree or tolerance, the system decides to switch from state 400 to state 402.
In state 402, the aircraft operates in a closed loop autonomous takeoff mode. For example, this corresponds to altitudes between altitudeOL↔CL (304) and altitudepilot↔auto (306) in
In this example, the autonomous takeoff procedure is configured to bring the aircraft to some desired altitude, at which point the aircraft will switch over from closed loop autonomous takeoff state 402 to pilot-guided flight state 404. Since the aircraft is definitely out of the dead zone, the altitude-related data may be used to determine when the desired altitude is reached.
In pilot-guided flight state 404, the aircraft will be steered or otherwise guided by the pilot. Once the pilot is ready to land, the pilot may have the aircraft hover midair at some point (e.g., over some desired landing point). The pilot may then send an instruction to the aircraft to autonomously land, for example using some button or control in a user interface.
In closed loop autonomous landing state 406, the aircraft descends autonomously where the altitude-related data is used in a feedback loop. Since this region is above the dead zone, the altitude-related data can be used. For example, this state corresponds to operating in a closed loop mode at step 102 in
Once a specified or predetermined altitude is reached (e.g., above the dead zone with some margin), the system switches to open loop autonomous landing state 408. In this state, the aircraft will continue to land, but in open loop mode and without using the altitude-related data. The state machine ends when the aircraft touches down on the ground and the aircraft is turned off.
For simplicity and ease of explanation, it is assumed in this example that all of the pilot-guided flight (404) occurs outside of the dead zone. In some embodiments, during pilot-guided flight state 404, checks are continuously performed to ensure that the aircraft does not descend into the dead zone. If the aircraft were in or near the dead zone when the pilot issued the instruction to autonomously land, then the state machine would transition from pilot-guided flight state 404 to open loop autonomous landing state 408, bypassing closed loop autonomous landing state 406. Alternatively, in some embodiments, the pilot is prevented from flying too low (i.e., into the dead zone).
These examples of how to detect when to switch between an open loop mode and a closed loop mode are described more generally and/or formally in the following flowcharts.
At 500, a confidence value associated with the plurality of altitude-related data is determined. As described above, some altitude-related sensors output some reliability or confidence value (more generally referred to as metadata) associated with the altitude-related data itself and in some such embodiments the metadata is used to determine the confidence value (e.g., select the lowest or worst confidence value). In some embodiments, the confidence value is determined from the altitude-related data, for example by determining some deviation between the various altitude measurements.
At 502, the confidence value is compared against a confidence threshold. Naturally, the confidence threshold may be tuned or otherwise set to whatever value is desired in order to safely switch over from open loop mode to closed loop mode.
At 504, in response to the confidence value exceeding the confidence threshold, there is a switch from performing the autonomous takeoff in the open loop mode, wherein the plurality of altitude-related data is ignored, to performing the autonomous takeoff in the closed loop mode, wherein the plurality of altitude-related data is used. For example, the system would switch from the state shown in
This process may be repeated as the aircraft ascends during an autonomous takeoff. For example, multicopter 300 in
At 600, an altitude is obtained from the plurality of altitude-related data. For example, if the altitude-related data comprises altitude measurements, then one of the altitudes may be selected. If the altitude-related data comprises some raw data (e.g., a phase or time delay associated with a received radar signal) from which the altitude is calculated, then the appropriate calculation and selection (e.g., of one of the calculated altitudes) is performed.
At 602, the obtained altitude is compared against an altitude threshold. See, for example
At 604, in response to the obtained altitude no longer exceeding the altitude threshold, there is a switch from performing the autonomous landing in the closed loop mode, wherein the plurality of altitude-related data is used, to performing the autonomous landing in the open loop mode, wherein the plurality of altitude-related data is ignored.
This process may be repeated as the aircraft descends during an autonomous landing. For example, once multicopter 300 in
In some embodiments, the ceiling of a dead zone depends upon the relevant surface beneath the aircraft. For example, a dead zone above water may have a different ceiling compared to a dead zone above solid ground. In some embodiments, the altitude threshold used at step 602 is selected based at least in part on the landing surface (e.g., land or water). For example, this may include first determining whether the aircraft is above land or water using a variety of techniques (e.g., sensor-based or location-based). Then, either a water altitude threshold or a land altitude threshold is selected accordingly.
In some embodiments where performing autonomous flight in a closed loop mode (see, e.g., step 102 in
The throttle signal (700) generally decreases over time so that the corresponding multicopter gradually descends. Data point 702 corresponds to an instruction from the pilot to begin an autonomous landing procedure. This triggers a transition from a pilot-guided state or mode to a closed loop autonomous landing mode or state. Note that throttle signal 700 is “noisy” or “wiggly” between data points 702 and 704 because this is the period during which closed loop feedback occurs and the closed feedback loop injects or otherwise introduces small adjustments or corrections.
The altitude (710) of the multicopter gradually decreases in
Returning to
Returning to
The following figure illustrates another example of a ground detection criterion where the criterion is associated with a yaw injection.
Naturally, an injection of a rotation about some other axis (e.g., besides the yaw or vertical axis) may be used to perform ground detection (e.g., pitch injection, roll injection, etc.). The general technique is referred to herein as rotation injection. In this example (where the 10 rotor multicopter described above is used), yaw injection may be attractive because this type of multicopter has good yaw control and/or good yaw responsiveness. Naturally, other types of aircraft with different performance characteristics may use some other rotation injection technique appropriate for those types of aircraft during ground detection.
These ground detection criteria examples are described more generally and/or formally in the flowcharts below.
At 900, a rotation about an axis of rotation is injected. For example, in
At 902, a measured amount of rotation about the axis of rotation is obtained. Appropriate sensors such as accelerometers, gyroscopes and such may be used to measure the degree or amount of rotation, if any.
At 904, the measured amount of rotation is compared against a rotational threshold. For example, as is shown in
At 906, in response to the measured amount of rotation not exceeding the rotational threshold, it is decided that a landing surface has been reached. In some embodiments, this decision triggers some action (e.g., the autonomous landing procedure turns off the rotors and ends).
At 1000, a rotation about an axis of rotation is injected. At 1002, a measured amount of rotation about the axis of rotation is obtained. At 1004, the measured amount of rotation is compared against a rotational threshold.
At 1006, a throttle value is obtained. For example, if there are 10 throttle signals going to 10 rotors in a multicopter, then a representative value may be obtained by selecting one of the throttle values or combining all of the throttle values into a single throttle value (e.g., median, average, etc.).
At 1008, the throttle value is compared against a throttle threshold. See, for example,
At 1010, in response to the measured amount of rotation not exceeding the rotational threshold and the throttle value not exceeding the throttle threshold, it is decided that a landing surface has been reached. To put it another way, the throttle must be less than the throttle threshold and the measured amount of rotation must be less than the rotational threshold in order for the process to declare that the aircraft has touched down.
It is noted that some other ground detection techniques rely upon pins or buttons on the bottom of the aircraft which are pushed in when the aircraft touches down. For the exemplary multicopter described above (which is capable of landing both on water and solid ground), this pin-based ground detection technique is not attractive because it will not work when landing on water. It is noted that the above ground detection techniques work across a variety of landing surfaces, including water.
As described above, in some embodiments, the aircraft which performs the autonomous flight technique(s) described herein is a (ultra) lightweight aircraft. When the weight of the aircraft is very light, the responsiveness of the aircraft is substantially affected by the weight of the pilot since the pilot's weight is a fairly large percentage of the total weight. The following figures describe some examples where a parameter update process and/or a parameter selection process takes a pilot's weight into account.
Initially, the aircraft is in the dead zone and so no altitude signal is shown below altitudeOL→CL when the system determines that the altitude-related data can be trusted and switches from open loop mode to closed loop mode. At data point 1102, the aircraft with the light pilot reaches altitudeOL→CL and reliable altitude measurements are available. This data point (i.e., 1102) occurs at time t0. Due to the lighter weight of this pilot, the aircraft will be able to ascend more quickly than when the heavier pilot is flying the aircraft (e.g., given the same throttle signal and same aircraft).
At a second, later point in time (i.e., t1), the aircraft with the heavy pilot reaches an altitude of altitudeOL→CL. For simplicity and ease of explanation, the same altitudeOL→CL is shown for both the light pilot and the heavy pilot. This second altitude response is shown as line 1112 and it is noted that the slope of the altitude response with the lighter pilot (1110) is steeper than the slope of the altitude response with the heavier pilot (1112).
In
As shown here, with a (ultra) lightweight aircraft, the weight of the pilot is a relatively large percentage of the total weight and so the pilot's weight affects the aircraft's responsiveness to a noticeable and/or measurable degree. In some embodiments, various properties or characteristics of a throttle signal (e.g., 1100 in
In some embodiments, a qualitative estimate of a pilot's weight is determined, as opposed to a quantitative estimate. For example, there could be a classification scheme where each pilot is classified as light, medium, or heavy. Alternatively, in some embodiments a quantitative estimate of a pilot's weight is determined.
The pilot's estimated weight or mass (referred to herein as {circumflex over (m)}pilot) may be used in a variety of ways. In some embodiments, the pilot's estimated weight is used during one or more of the following states in
In addition to using the pilot's estimated weight in the manner above, the pilot's estimated weight may be used during training to update parameters associated with the autonomous takeoff (i.e., {right arrow over (θ)}TO). For example,
Although not shown here, there may be a similar throttle function associated with generating throttle values for an autonomous landing: throttle=ƒL({circumflex over (m)}pilot, {right arrow over (θ)}L). The autonomous landing parameters (i.e., {right arrow over (θ)}L) may similarly be updated while taking the pilot's estimated weight (i.e., {circumflex over (m)}pilot) into account. Also, since it is assumed that the pilot will not change between takeoff and landing, the pilot's weight (e.g., estimated during takeoff) may be used during landing (e.g., to generate throttle values for autonomous landing that are appropriate for a pilot of that weight). In some embodiments, the parameters {right arrow over (θ)}L and {right arrow over (θ)}TO have known relationships and the parameters {right arrow over (θ)}L can be updated using the {right arrow over (θ)}TO parameters, or vice versa so that only one training process is performed. Alternatively, there may be a separate takeoff training process and landing training process (e.g., if {right arrow over (θ)}L and {right arrow over (θ)}TO are independent of each other).
These examples are described more generally and/or formally in flowcharts below.
At 1200, a signal associated with autonomous takeoff is obtained. For example, throttle signal 1100 in
At 1202, a pilot weight is estimated, including by analyzing the signal associated with autonomous takeoff. For example, as shown in
At 1204, the pilot weight is used to generate a value which is used to control an aircraft that is performing the autonomous takeoff. For example, during pilot-guided flight state 404 in
At 1300, a signal associated with autonomous takeoff is obtained. See, for example, the signals shown in
At 1302, a pilot weight is estimated, including by analyzing the signal associated with autonomous takeoff. For example, in
At 1304, the pilot weight is used to update a parameter associated with one or more of the following: autonomous takeoff or autonomous landing. In one simplistic example, there are different sets of parameters associated with different weight categories. For example, the takeoff parameters may include {right arrow over (θ)}TO,light, {right arrow over (θ)}TO,medium, and {right arrow over (θ)}TO,heavy and the landing parameters may include {right arrow over (θ)}L,light, {right arrow over (θ)}L,medium, and {right arrow over (θ)}L,heavy. Depending upon the classified weight (e.g., light, medium, or heavy), the appropriate set of parameters is selected and updated, leaving the unselected parameters untouched (at least during this iteration of training and/or updating with this particular pilot). In other words, updating the parameter includes using the pilot weight to select the parameter from a plurality of parameters associated with different pilot weights.
Although the foregoing embodiments have been described in some detail for purposes of clarity of understanding, the invention is not limited to the details provided. There are many alternative ways of implementing the invention. The disclosed embodiments are illustrative and not restrictive.
This application claims priority to U.S. Provisional Patent Application No. 62/596,445 entitled AUTONOMOUS TAKEOFF AND LANDING WITH OPEN LOOP MODE AND CLOSED LOOP MODE filed Dec. 8, 2017 which is incorporated herein by reference for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
3678256 | Harenberg, Jr. | Jul 1972 | A |
4821981 | Gangsaas | Apr 1989 | A |
4953098 | Fischer, Jr. | Aug 1990 | A |
6122572 | Yavnai | Sep 2000 | A |
6539290 | Vos | Mar 2003 | B1 |
8458715 | Khosla | Jun 2013 | B1 |
9643722 | Myslinski | May 2017 | B1 |
20040093130 | Osder | May 2004 | A1 |
20050134496 | Trainor | Jun 2005 | A1 |
20050231422 | Etnyre | Oct 2005 | A1 |
20070032921 | Allen | Feb 2007 | A1 |
20110046823 | Ezerzere | Feb 2011 | A1 |
20110084162 | Goossen | Apr 2011 | A1 |
20120298796 | Carreker | Nov 2012 | A1 |
20130046422 | Cabos | Feb 2013 | A1 |
20140018980 | Bollapragada | Jan 2014 | A1 |
20150012154 | Senkel | Jan 2015 | A1 |
20160062364 | Foinet | Mar 2016 | A1 |
20160140729 | Soatto | May 2016 | A1 |
20160335898 | Caplan | Nov 2016 | A1 |
20170076616 | Kanade | Mar 2017 | A1 |
20170357808 | Arroyo | Dec 2017 | A1 |
Number | Date | Country | |
---|---|---|---|
62596445 | Dec 2017 | US |