User interfaces for mutually exclusive three dimensional flying spaces
Boundary information associated with a three-dimensional (3D) flying space is obtained, including a boundary of the 3D flying space. Location information associated with an aircraft is obtained, including a location of the aircraft. Information is presented based at least in part on the boundary information associated with the 3D flying space and the location information associated with the aircraft, including by presenting, in a display, the boundary of the 3D flying space and an avatar representing the aircraft at the location of the aircraft.
Latest Kitty Hawk Corporation Patents:
This application is a continuation of U.S. patent application Ser. No. 16/110,928, now U.S. Pat. No. 10,446,041, entitled USER INTERFACES FOR MUTUALLY EXCLUSIVE THREE DIMENSIONAL FLYING SPACES filed Aug. 23, 2018 which is incorporated herein by reference for all purposes.
BACKGROUND OF THE INVENTIONNew types of aircraft are being developed for use by relatively inexperienced pilots (e.g., without a pilot's license and/or without extensive flight training). New user interfaces to provide information to such inexperienced pilots during flight would be desirable, for example, because the aircraft is operating in a new and/or different manner compared to existing aircraft for the ease and/or benefit of relatively inexperienced pilots. The user interface may provide or otherwise present information which helps the pilot to better understand how the aircraft operates (e.g., in the new and/or different ways) and have a better and/or more informed flight experience.
Various embodiments of the invention are disclosed in the following detailed description and the accompanying drawings.
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 user interfaces and/or techniques to present information associated with a three-dimensional (3D) flying space and/or position or location information associated with the aircraft (e.g., where the aircraft is automatically constrained or otherwise configured to stay within its 3D flying space, even if the pilot attempts to leave the 3D flying space) are described herein. First, some examples of 3D flying spaces are described. Then, various embodiments of user interfaces and/or techniques to present information associated with such 3D flying spaces are described.
In the example shown, a person can get on an aircraft and take a tour of sights on the San Francisco Bay and along the San Francisco waterfront. For example, the person may first watch a safety video which includes instructions on how to fly the aircraft and is then permitted to rent an aircraft. In one example, the aircraft has floats (e.g., so that the aircraft is buoyant on water) and the pilot performs a vertical takeoff from water.
The pilot guides their plane so that it enters the first 3D flying space (100) at the entrance (102) to that permitted route. Using the controls and/or input devices of the aircraft (e.g., a joystick), the pilot is permitted to fly their aircraft within the three-dimensional space defined by 3D flying space 100 as desired but is not permitted to deviate from the permitted path or route shown. For example, some types of aircraft can hover in place and the pilot may (if desired) stop along the route or path (e.g., with the aircraft hovering in-air) to take pictures of iconic and/or scenic San Francisco landmarks. Alternatively, they can fly along the first 3D flying space (100) as fast or as slow as they want without stopping.
A more formal way of describing this type of 3D flying space is to say that it includes at least one entrance and exit and that the length (i.e., the distance measured from the entrance to the exit) is the largest dimension compared to a height or a width (e.g., associated with a cross-sectional area).
As an example of how the pilot is not permitted to steer or otherwise guide the aircraft outside of a 3D flying space, suppose that the pilot is in straight section 104 of 3D flying space 100. To fly through this straight section 104, the pilot will push their joystick forward (e.g., assuming the input device is a joystick). If the pilot is not paying attention and keeps pushing the joystick forward when the straight section ends and 3D flying space 100 begins to turn to the pilot's right at bend 108, the aircraft will not permit the pilot to steer or otherwise guide the aircraft outside of the permitted path or route corresponding to 3D flying space 100 shown here. In this example, the pilot's instruction (in this example, to fly straight forward even though the permitted route turns) would be interpreted or handled by the aircraft in the following manner. Since the pilot's desired direction of flight (e.g., corresponding to path or trajectory 106) is not completely orthogonal to bend 108, the aircraft will continue to move (e.g., as opposed to stopping and hovering midair), but will turn so that the aircraft follows bend 108 and will not fly along forward path or trajectory 106, even though the pilot is holding the joystick forward. In contrast, other types of aircraft (e.g., which have no understanding of a 3D flying space and/or which are not configured to respect the boundaries defined by a 3D flying space) would obey the pilot's input and those aircraft would continue on the forward path or trajectory (106) which deviates from the bend (108) in 3D flying space 100.
In 3D flying space 100 shown here, the selected route or path may be helpful in preventing pilots from flying into more dangerous and/or restricted areas. For example, the winds west of the Golden Gate Bridge may be significantly stronger than the winds east of the bridge, making flying much more difficult in that area. In this example, the pilots may be relatively inexperienced and/or tourists unfamiliar with the area and so a 3D flying space or permitted path which keeps an aircraft east of the Golden Gate Bridge (as shown here) will prevent the pilot and aircraft from entering more dangerous areas. Similarly, the exemplary 3D flying space shown here keeps the pilot and aircraft from entering protected airspaces associated with the Oakland or San Francisco airports.
A 3D flying space also helps to prevent collisions between two aircraft. For example, suppose a second pilot came along and wanted to take the same tour as the first pilot. The second pilot and their aircraft would be assigned to the second 3D flying space (110). Accordingly, they would enter the second entrance (112) associated with the second 3D flying space (110). Even if the first pilot is very slow (e.g., making many stops along the way), the second pilot will not run into the first pilot's aircraft because the first 3D flying space (100) and the second 3D flying space (110) do not intersect or otherwise overlap. Rather, the two permitted paths run parallel to each other from the entrances (102 and 112) all the way to the exits (114 and 116).
The following figure shows some exemplary cross-sectional areas associated with 3D flying space 100 and 110.
Cross-sectional area 200 shows an example where a 3D flying space has an elliptical cross-sectional area. Aircraft 202 shows an example of an aircraft which is constrained or otherwise configured to remain within the boundaries of a 3D flying space, including cross-sectional area 200, even if the pilot indicates, via the controls or input devices, that they want to fly outside of cross-sectional area 200. The pilot is permitted to steer or otherwise move the aircraft within cross-sectional area 200, so long as the plane does not move or otherwise fly beyond the boundary associated with cross-sectional area 200. For example, if the pilot was hovering and wanted to move upwards, that would be permitted so long as aircraft 202 does not move beyond the boundary associated with cross-sectional area 200. Otherwise, the pilot's input would be ignored (e.g., as the aircraft got closer to a top boundary, the aircraft would slow to a stop, even if/while an up-down thumbwheel used to control attitude were still being pushed up).
Generally speaking, user interfaces and/or techniques to present information (e.g., to show the boundaries of the 3D flying space, the aircraft's position within the 3D flying space, etc.) are independent of the aircraft's (e.g., automated) response and/or intervention to keep the aircraft within the 3D flying space. For example, a user interface may present a warning that the aircraft is getting too close to the boundary of the 3D flying space at a first distance from the boundary, but may not actually take action in response to the aircraft's proximity to the boundary until the aircraft is closer (e.g., by automatically slowing down and stopping the aircraft before it crosses the boundary of the 3D flying space, by automatically turning the aircraft to follow a turn in a path, etc.). To put it another way, the distance (e.g., from the boundary of a 3D flying space) at which a warning message or notification is displayed by a user interface is not necessarily the same as the distance (e.g., again from the boundary of a 3D flying space) at which the aircraft intervenes and/or ignores a pilot's input in order to keep the aircraft within the 3D flying space. For example, by displaying or issuing a warning sooner before any intervention is performed may give the pilot an opportunity to correct the aircraft's path or trajectory before the aircraft begins to ignore the pilot's instruction(s) and/or otherwise intervene to keep the aircraft in the 3D flying space.
Cross-sectional area 204 shows an example where a 3D flying space has a rectangular cross-sectional area. As before, aircraft 206 is permitted to move about within cross-sectional area 204 per the input of the pilot (e.g., via a joystick, control, or other input device), so long as those instructions would not cause aircraft 206 to move beyond the boundaries of cross-sectional area 204. Elliptical cross section 200 and rectangular cross section 204 are merely two examples and any type of cross-sectional area or 3D flying space in general may be used.
In some embodiments, a cross-sectional dimension of a 3D flying space (e.g., radius, height, width, etc.) is based at least in part on the potential obstacles a pilot may encounter and would like to avoid. For example, on the San Francisco Bay where there are many different types of ships, a 3D flying space (e.g., 200 or 204) could be wide enough to avoid large tanker vessels or cargo containers and/or high enough to avoid sailboat masts. Naturally, whatever the dimensions, the 3D flying space would still be mutually exclusive and constructed to avoid areas of danger and/or concern.
In some embodiments, a 3D flying space is expressed in an efficient manner which reduces an amount of storage used (e.g., on an aircraft which stores the 3D flying space) and/or bandwidth consumed (e.g., if the 3D flying space is sent from and/or assigned by an assignor and the information is exchanged over some (e.g., wireless) network). In one example, a 3D flying space is broken up into one or more segments (i.e., the 3D flying space is defined piecewise) and each segment is expressed or otherwise represented using: (1) a center path (e.g., an imaginary line in the center of the cross section of the 3D flying space) and (2) a cross section about the center path.
In one example of the center path, suppose that the 3D flying space includes different segment types (e.g., some combination of linear segments and curved segments). A first segment may have a center path defined as a line from (e.g., GPS) coordinates (a, b) to (e.g., GPS) coordinates (c, d). Then, the next segment has a center path which is circular from coordinates (e, f) to (g, h) with a radius of 200 meters.
In one example of the cross section, the cross section may include a specification or selection of a shape type from one of several possible or permitted shapes (e.g., circle, ellipse, rectangle, etc.) with defined parameters that are relevant for that shape type (e.g., height and width for rectangular cross sections, radius for circular cross sections, etc.).
In some embodiments, there are “gaps” between adjacent or successive segments of a 3D flying space and interpolation is performed on-board the aircraft to determine the boundaries of the 3D flying space between the (e.g., explicitly and/or piecewise-defined) segments. Naturally, the interpolation is performed in a manner that ensures the 3D flying spaces are mutually exclusive. Using on-board interpolation may help to further improve the efficient representation of a 3D flying space (e.g., so that storage space and/or bandwidth consumption is further reduced).
In a similar approach, in some embodiments, segments are touching and/or contiguous but smoothing is performed where adjacent or successive segments meet. For example, suppose that the 3D flying space may be defined as piecewise, overlapping linear segments where on-board smoothing is performed so that the 3D flying space has rounded turns (e.g., for a smoother and/or more natural flying experience) instead of sharp, abrupt turns where the linear segments join each other. This may support an efficient manner in which to represent or otherwise store a 3D flying space while also supporting or otherwise enabling a smoother and/or more natural flying experience.
Returning to
As will be described in more detail below, a 3D flying space is virtual and it is not necessary to have infrastructure and/or devices in place in order for a 3D flying space to be defined and/or respected. For example, with this technique, it is not necessary for some physical device to be present or otherwise installed to (as an example) indicate or assign a 3D flying space to a particular aircraft. Rather, as will be described in more detail below, the aircraft has a sense of its location in the air and where the boundaries of the 3D flying space are. Both of these things enable the aircraft to stay within a 3D flying space, including by ignoring pilot input as/if needed.
In some embodiments, a 3D flying space is dynamic and/or temporal (e.g., lasting only for some time and not forever). For example, when the winds on the San Francisco Bay are strong, it may be desirable to have a larger distance between two adjacent 3D flying spaces. In one example, each morning, before people are permitted to take the aircraft out along the permitted routes, the distance between two adjacent 3D flying spaces is set according to the weather (e.g., with a larger separation if the winds are strong). To accommodate the larger separations, the number of 3D flying spaces may be decreased.
In the example of
Although the techniques described herein may be used with any appropriate type of aircraft, the exemplary aircraft shown here in
The 3D flying spaces described above are merely exemplary and are not intended to be limiting. The following figures describe another embodiment of a 3D flying space.
For compactness, the example shown here has no gap or buffer zone between 3D flying space 310 and 3D flying space 312. In some embodiments, there is some gap or buffer zone between adjacent layers to further ensure the safety of the pilots and those around them.
With 3D flying spaces (e.g., which are virtual and are not necessarily demarcated in a physical manner in the sky using lasers, smoke, etc.), it would be helpful to display or otherwise provide information associated with a 3D flying space to the pilot and/or the location of the aircraft (e.g., so that the pilot does not inadvertently and/or unknowingly bump up against the boundaries of the 3D flying space). The following figure describes one example of such a process.
At 400, boundary information associated with a three-dimensional (3D) flying space is obtained. For example, boundary information which describes the three-dimensional flying space may be received. 3D flying space 100 and 3D flying space 110 in
In some embodiments, some segments or sections of the three-dimensional flying space have one set of rules (e.g., about the permitted directions of flight) and other segments or sections have different rules. For example, suppose that permitted route 100 in
At 402, location information associated with the aircraft is obtained. For example, this information may be received from a GPS system in the aircraft and may include the aircraft's latitude, longitude, and altitude (i.e., a position or location within 3D space).
At 404, information is presented based at least in part on the boundary information associated with the 3D flying space and the location information associated with the aircraft. In some embodiments, the information presented is a warning (e.g., in advance of any automatic intervention by the aircraft to keep the aircraft in the 3D flying space) that the aircraft is getting too close to the boundary of a 3D flying space. Various embodiments of this are described in more detail below where a variety of user interfaces (e.g., displays, speakers, force feedback hand controls, etc.) may be used to present or otherwise display such a warning.
In some embodiments, the information presented is the boundaries of the 3D flying space and/or the location of the aircraft. As will be described in more detail below, a variety of user interfaces may be used (e.g., displays, speakers, etc.) and the information may be visual information (e.g., an icon or avatar representing the aircraft with the boundaries of the 3D flying space indicated) or audio information (e.g., an audible message or announcement about the distance between the aircraft's current location and the boundary of the 3D flying space in a specified or announced direction).
In some embodiments, information in addition to boundary information but also associated with the 3D flying space is obtained at step 400 and presented at step 404. For example, in
The following figure shows an example of a system which performs the process of
In this example, the boundary information associated with a 3D flying space is stored in memory 502. In various embodiments, the selection or assignment of a particular 3D flying space for a given aircraft may be performed in a variety of ways. In some embodiments, there is some assignor or other device which assigns a 3D flying space to a particular aircraft and the 3D flying space information which is stored in 502 is obtained from such an assignor.
Alternatively, in some embodiments there is no assignor or other authority and each aircraft selects for themselves what their 3D flying space is. In some such embodiments, memory 502 stores a number of predefined 3D flying spaces associated with particular locations and listens on a wireless channel for any aircraft which are already present in the vicinity and which predefined 3D flying spaces those aircraft have already claimed. For example, referring back to
Input device 504 (e.g., a joystick, an up-down thumbwheel, etc.) is used to receive an input associated with flying or otherwise controlling an aircraft from a pilot. In some embodiments, an input device (504) is also a user interface (508) via which information is presented to the pilot (e.g., aircraft is too close to the boundary of the 3D flying space). In various embodiments, the user interface is vibrational, includes force feedback, etc.
Location sensor (506) provides the location of the aircraft to flight computer 500 and in some embodiments is a GPS system. As described above, the flight computer (500) will respond to the input from the pilot, so long as the pilot's input or instructions do not cause the aircraft to leave the 3D flying space.
Using these inputs, the flight computer (500) generates two output signals: one or more control signals to one or more control surfaces (510) and information to present or otherwise display to the pilot (e.g., based on the 3D flying space, the location of the aircraft, etc.) via the user interface (508). For example, for multiple 202/206 in
The flight computer (500) also generates information or signals to be presented via user interface 508. In various embodiments, the user interface may be a display which presents visual information (e.g., the boundaries of the 3D flying space, an icon or avatar of the aircraft showing the position or location of the aircraft relative to the 3D flying space, a permitted direction of flight, a speed limit, etc.), a speaker which presents audio information (e.g., an audible warning when the aircraft gets too close to the boundary of a 3D flying space), and a force feedback hand control (e.g., a force feedback joystick, a force feedback thumbwheel, etc.) which outputs more resistance or force as the aircraft gets closer and closer to the boundary of the 3D flying space. The following figures describe some exemplary user interfaces and exemplary presented information in more detail.
In this example, the pilot's left hand controls a single axis thumbwheel (610). The thumbwheel (610) is mounted to the (left) handgrip (612) on the side or surface of the handgrip that faces into the cockpit. The thumbwheel is spring centered so that the thumbwheel returns to the centered position if the pilot releases the thumbwheel. When the thumbwheel is pushed up, the aircraft ascends. Conversely, when the thumbwheel is pushed down, the aircraft descends. The speed at which the multicopter ascends or descends corresponds to the degree or amount of displacement experienced by the thumbwheel. Although these example show specific hand controls, it is noted that these feedback techniques may be adapted for any hand control.
The pilot's right hand controls a three-axis fingertip joystick (614). A fingertip joystick offers fingertip control and is generally smaller and offers less resistance than a hand-controlled joystick (e.g., where the pilot's hand would wrap around a hand-controlled joystick). The first axis is a vertical (e.g., yaw) axis extending upward from the top of the joystick where the joystick's knob or tip can be twisted about this axis in the clockwise direction or counterclockwise direction. Turning the twistable knob of the joystick causes the multicopter to correspondingly rotate about a vertical or yaw axis. The other two axes of the joystick are the x (e.g., roll) axis and y (e.g., pitch) axis (e.g., the pilot pushes the joystick in any direction and/or to any degree). Pushing the joystick controls the multicopter's movement within a plane formed or otherwise defined by the roll axis and pitch axis. For example, pushing the joystick forward causes the multicopter to fly forward and pulling the joystick backward causes the multicopter to fly backward.
In this example, the windshield (600) includes a display (620a) which is configured to display the aircraft's position relative to a 3D flying space. Display 620b shows a larger, more detailed view of the display. In this example, the 3D flying space is path-like where it is much longer than it is wider or taller and the cross-section of the exemplary 3D flying space is rectangular (e.g., similar to rectangular cross-section 204 shown in
Within display 620b, the position of cross-sectional boundary 622 remains fixed (e.g., assuming that the cross-section does not change as the aircraft travels along the exemplary path). Within that fixed frame of reference, an icon or avatar which represents the aircraft (624) is updated based on the current position of the aircraft, relative to the 3D flying space. In this view, the position of the aircraft's avatar is not updated as the aircraft moves forwards or backwards along the path (e.g., along a longitudinal or roll axis) but is updated as the aircraft moves up or down (e.g., along a vertical or yaw axis) and/or left or right (e.g., along a lateral or pitch axis).
In this example, color is used to indicate whether the aircraft's position, relative to the boundaries of the 3D flying space, is good or bad (this example assumes only two states). If the aircraft is relatively centered and is therefore in a good position relative to cross-sectional boundary 622 (e.g., not crossing any of thresholds 220, 222, 224, or 226 in
In the state shown here, the aircraft is vertically centered within the 3D flying space (e.g., it is equidistant from the top border as it is from the bottom border) but it is relatively close to the left-hand border of the 3D flying space. The pilot, if desired, may observe this in the display (620b) and use the joystick (614) to move the aircraft to the right so that the aircraft is better centered within the boundary or cross section of the 3D flying space (622). Naturally, the position of the aircraft's avatar (624) is updated within the display as the pilot steers or otherwise adjusts the position of the aircraft.
Depending upon the application (e.g., cost and/or weight considerations), the display may include other types of information (e.g., visual information). For example, in some embodiments, the aircraft includes a forward-facing camera and the display includes a current and/or real-time video feed of what the pilot sees (e.g., with the aircraft avatar and boundary markers superimposed on the real-time video). Alternatively (e.g., to keep cost and/or weight down), the display may not present any real-time video or views. Other information such as remaining battery life, aircraft speed, wind speed, etc. may also be displayed via the display (620a/620b). In some embodiments, a path-like 3D flying space has a direction of flight (e.g., the path-like 3D flying space is a one-way street). In some such embodiments, a display includes an arrow to indicate the (enforced) direction of flight.
As an aircraft flies through a 3D flying space, the boundaries may change and the information presented may be varied accordingly. For example, suppose the aircraft enters a part of a 3D flying space where the cross-sectional area increases. To convey this, in one example, the aircraft's avatar (624) is shrunk so that the relative size of the aircraft's avatar compared to the size of the boundary 622 is smaller.
Or, suppose that the aircraft enters a part of a 3D flying space where the lateral or side boundaries open up but the top and bottom boundaries remain relatively the same (e.g., so that the 3D flying space is more like the example of
In some embodiments, instead of using a display in the aircraft to present the information, a virtual reality technique is used to present or otherwise display information. In one example, a pilot wears a virtual reality (VR) headset which is used to display or otherwise indicate the boundaries of the 3D flying space (e.g., superimposed on the pilot's real-time field of view).
In some embodiments, a display or other user interface indicates or otherwise presents advance information about a part of the 3D flying space coming up. The following figure shows an example of this.
In some embodiments (e.g., for cost and/or weight reasons), an aircraft does not include a display. The following figure describes some embodiments where other types of user interfaces are used.
However, if the aircraft were to cross the right threshold 226 in
In this example, the hand controls (i.e., up-down thumbwheel 806 and joystick 808) are not expected to be used at the same time. In fact, novice pilots may find it more comfortable to use only one hand control at a time (e.g., so they can more easily focus on the response of the aircraft to just a single hand control). To avoid overwhelming a novice pilot with too complex of a correction and/or a correction suggestion which would require the simultaneous use of the thumbwheel (806) and the joystick (808), in some embodiments only one of the four arrow indicators (800) is illuminated at any given time so that the pilot only has to worry about manipulating one hand control to make the correction suggested. For example, a correction for the most egregious threshold or boundary crossing may be indicated first (e.g., illuminate up arrow corrective indicator 804 first instead of illuminating both up arrow 804 and left arrow 802). Then, once a sufficient correction has been performed along that axis, the smaller correction along the orthogonal axis may be suggested (e.g., illuminate left arrow 802). Another way to describe this is to say that a correction suggestion which would require the simultaneous use of two input devices (e.g., one manipulated by the pilot's right hand and the other by the pilot's left hand) is simplified or otherwise reduced to a correction suggestion which only requires the use of a single input device (e.g., which only requires the use of the right hand or the left hand).
Similarly, it may be desirable to have at most four arrow indicators (800), as shown here. For example, if there were also an up-right arrow, a down-right arrow, a down-left arrow, and an up-left arrow, any of those correction suggestions would require the simultaneous use of up-down thumbwheel 806 and joystick 808 which may be difficult for novice pilots. More generally, in some embodiments, correction suggestions or indications which would require the simultaneous use of multiple hand controls are not presented.
In some embodiments, arrow indicators 800 are used to provide advance information (e.g., about an upcoming section of the 3D flying space). For example, as described above, some path-like 3D flying spaces may be straight in some sections and curved in the other sections. In some embodiments, an appropriate arrow indicator is used to indicate or otherwise suggest an upcoming maneuver so that the aircraft can stay on course and/or on track with the 3D flying space and not bump up against the boundaries.
The exemplary arrow indicators may be modified as desired (e.g., to convey more and/or different information). For example, to preserve the readability of the figure, only a single size or single length of arrow indicators is shown. In some embodiments there are different sized or different lengths arrows (e.g., to indicate different degrees or amounts of correction or different degrees of turning up ahead). For example, a shorter and/or smaller arrow may be used to suggest a smaller amount of correction or a smaller upcoming turn whereas a longer and/or larger arrow may be used to suggest a larger amount of correction or a sharper upcoming turn.
In some embodiments, audio information about the position of the aircraft relative to the boundaries of the 3D flying space is provided via speaker 810. For example, while the aircraft is not in any danger of crossing the boundary of a 3D flying space (e.g., not crossing any of thresholds 220, 222, 224, or 226 in
In some embodiments, speaker 810 is used to provide audible advance information. For example, “There is a 15 degree turn to the right coming up in 5 seconds. 5, 4, 3, 2, 1. Please turn to the right 15 degrees now.”
In some embodiments, haptic information is provided via a hand control, such as thumbwheel 806 or joystick 808. For simplicity and ease of explanation, joystick 808 will be used as an example. Suppose that joystick 808 is a force feedback joystick where the joystick can provide a variable amount of resistance when the joystick is displaced from center. In some embodiments, force feedback is used to indicate or otherwise signal when an aircraft is getting too close to a boundary of a 3D flying space. For example, while an aircraft is in the center of cross-section 204 in
However, suppose the pilot (e.g., in a straight section of the 3D flying space) steers the aircraft to the left using joystick 808 such that left threshold 224 in
Another way to describe this is that the input devices (e.g., thumbwheel 806 and joystick 808) vary the haptic output (e.g., the force feedback generated by the joystick) to give a kind of “spring-centered” feeling to the center of the tube or other 3D flying space (e.g., which depends upon the position of the aircraft relative to or within the tube, and which does not depend upon the displacement of the joystick). This may also be used with tube or path-like 3D flying spaces to convey when a tube or path has turned and the aircraft has not correspondingly turned (e.g., the pilot (e.g., inadvertently and/or unknowingly) keeps the aircraft on straight trajectory 106 in
In some embodiments, the amount of force feedback varies with the distance between the aircraft and the (e.g., relevant) edge or boundary. For example, as the aircraft gets closer and closer to the edge or boundary, the amount of force feedback correspondingly increases. The amount of force feedback is not (at least in this example) dependent on the amount of joystick displacement. For example, for a given distance between the aircraft and a boundary of a 3D flying space, the same amount of force or resistance output by the joystick (or other hand control) would be the same for a relatively small amount of joystick displacement (e.g., the aircraft is moving relatively slowly in the indicated direction) as well as for a relatively large amount of joystick displacement (e.g., the aircraft is moving relatively quickly in the indicated direction).
The following figures describe the above examples more generally and/or formally in flowcharts.
At 400a, boundary information associated with a three-dimensional (3D) flying space is obtained, including by obtaining a boundary of the 3D flying space. See, for example,
At 402a, location information associated with the aircraft is obtained, including by obtaining a location of the aircraft. For example, the aircraft may include a GPS system and the aircraft's location is obtained from the GPS system.
At 404a, information is presented based at least in part on the boundary information associated with the 3D flying space and the location information associated with the aircraft, including by presenting, in a display, the boundary of the 3D flying space and an avatar which represents the aircraft at the location of the aircraft. See, for example,
In some embodiments, additional information is also presented via the display at step 404a. For example, a speed limit associated with the 3D flying space and/or a permitted direction of flight associated with the 3D flying space may be presented in the display.
In some embodiments, the display is a virtual reality (VR) headset. In some embodiments, the display is an integrated and/or touchscreen display in the aircraft.
In some embodiments, the display presents a warning when a distance between the location information and the boundary of the 3D flying space is less than (i.e., does not exceed) a threshold and presents no warning when the distance is greater than (i.e., exceeds) the threshold. For example, a border or background color may be red for the former and green for the latter.
At 400b, boundary information associated with a three-dimensional (3D) flying space is obtained, including by obtaining a boundary of the 3D flying space.
At 402b, location information associated with the aircraft is obtained, including by obtaining a location of the aircraft.
At 1000, a distance between the boundary of the 3D flying space and the location of the aircraft is determined. For example, in
At 404b, information is presented based at least in part on the boundary information associated with the 3D flying space and the location information associated with the aircraft, including by announcing, via a speaker, the distance between the boundary of the 3D flying space and the location of the aircraft. For example, speaker 810 may be used to make the announcement. In some embodiments, the distance is only announced when the aircraft is close to the boundary of the 3D flying space (e.g., because it may be less distracting to the pilot if the speaker is silent when the aircraft is not in any danger of leaving the 3D flying space).
In some embodiments, some other information (e.g., in addition to the distance between the boundary of the 3D flying space and the location of the aircraft, which is announced at step 404b) may be presented audibly using a speaker (e.g., a speed limit and/or if a section of the 3D flying space is one-way).
At 400c, boundary information associated with a three-dimensional (3D) flying space is obtained, including by obtaining a boundary of the 3D flying space.
At 402c, location information associated with the aircraft is obtained, including by obtaining a location of the aircraft.
At 1100, a distance between the boundary of the 3D flying space and the location of the aircraft is determined.
At 1102, the distance between the boundary of the 3D flying space and the location of the aircraft is compared against a threshold. For example, in
At 404c, information is presented based at least in part on the boundary information associated with the 3D flying space and the location information associated with the aircraft, including by in response to the distance between the boundary of the 3D flying space and the location of the aircraft being less than the threshold, suggesting, via a speaker, a correction direction which would cause the distance between the boundary of the 3D flying space and the location of the aircraft to increase. For example, when an aircraft is relatively centered in a 3D flying space (as aircraft 206 is in
As described above, in some embodiments, a correction direction may be simplified, reduced, or otherwise constrained to be a correction direction which only requires the use of one hand and/or one input device. For example, if the aircraft is too close to a top border and right border (and ideally should move down and to the left to be perfectly centered), only one of those directions would be suggested (e.g., only “Please move to the right” and not “Please move down and to the right”). As described above, suggesting a correction which would require the simultaneous use of both hands may overwhelm a novice and/or inexperienced pilot.
At 400d, boundary information associated with a three-dimensional (3D) flying space is obtained, including by obtaining a boundary of the 3D flying space.
At 402d, location information associated with the aircraft is obtained, including by obtaining a location of the aircraft.
At 1200, a distance between the boundary of the 3D flying space and the location of the aircraft is determined.
At 1202, the distance between the boundary of the 3D flying space and the location of the aircraft is compared against a threshold.
At 404d, information is presented based at least in part on the boundary information associated with the 3D flying space and the location information associated with the aircraft, including by in response to the distance between the boundary of the 3D flying space and the location of the aircraft being less than the threshold, increasing an amount of force feedback output by a force feedback input device. In some embodiments, the input device via which the direction suggestion is presented at step 404d includes one or more of the following: a thumbwheel, a joystick, etc.
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.
Claims
1. A system, comprising:
- a communications interface that obtains boundary information associated with a three-dimensional (3D) flying space, including a boundary of the 3D flying space, wherein the 3D flying space is defined by a center path and a cross section about the path;
- a processor that: determines a distance between the boundary of the 3D flying space and a location of an aircraft; and compares the distance between the boundary of the 3D flying space and the location of the aircraft against a threshold; and
- a user interface that presents at least one of visual, audio, and haptic feedback about a relative distance between the boundary of the 3D flying space and the location of the aircraft based at least in part on the comparison.
2. The system recited in claim 1, wherein the 3D flying space has one or more of the is following cross sections: a circular cross section, an elliptical cross section, or a rectangular cross section.
3. The system recited in claim 1, wherein the user interface includes one or more of the following: a virtual reality headset, a touchscreen display, or a display integrated into the aircraft.
4. The system recited in claim 1, wherein the user interface presents a speed limit associated with the 3D flying space.
5. The system recited in claim 1, wherein the user interface presents a permitted direction of flight associated with the 3D flying space.
6. The system recited in claim 1, wherein the user interface announces, via a speaker, the distance between the boundary of the 3D flying space and the location of the aircraft.
7. The system recited in claim 1, wherein the user interface, in response to the distance between the boundary of the 3D flying space and the location of the aircraft not exceeding the threshold, suggests, via a speaker, a correction direction which would cause the distance between the boundary of the 3D flying space and the location of the aircraft to increase.
8. The system recited in claim 1, wherein the user interface, in response to the distance between the boundary of the 3D flying space and the location of the aircraft not exceeding the threshold, increases an amount of force feedback output by a force feedback input device.
9. A method, comprising:
- obtaining boundary information associated with a three-dimensional (3D) flying space, including a boundary of the 3D flying space, wherein the 3D flying space is defined by a center path and a cross section about the path;
- determining a distance between the boundary of the 3D flying space and a location of an aircraft;
- comparing the distance between the boundary of the 3D flying space and the location of the aircraft against a threshold; and
- presenting, in a user interface, at least one of visual, audio, and haptic feedback about a relative distance between the boundary of the 3D flying space and the location of the aircraft based at least in part on the comparison.
10. The method recited in claim 9, wherein the 3D flying space has one or more of the following cross sections: a circular cross section, an elliptical cross section, or a rectangular cross section.
11. The method recited in claim 9, wherein the user interface includes one or more of the following: a virtual reality headset, a touchscreen display, or a display integrated into the aircraft.
12. The method recited in claim 9, further comprising presenting, in the user interface, a speed limit associated with the 3D flying space.
13. The method recited in claim 9, further comprising presenting, in the user interface, a permitted direction of flight associated with the 3D flying space.
14. The method recited in claim 9, further comprising announcing, via a speaker, the distance between the boundary of the 3D flying space and the location of the aircraft.
15. The method recited in claim 9, further comprising suggesting, via a speaker, a correction direction which would cause the distance between the boundary of the 3D flying space and the location of the aircraft to increase in response to the distance between the boundary of the 3D flying space and the location of the aircraft not exceeding the threshold.
16. The method recited in claim 9, further comprising increasing an amount of force feedback output by a force feedback input device in response to the distance between the boundary of the 3D flying space and the location of the aircraft not exceeding the threshold.
17. A computer program product, the computer program product being embodied in a non-transitory computer readable storage medium and comprising computer instructions for:
- obtaining boundary information associated with a three-dimensional (3D) flying space, including a boundary of the 3D flying space, wherein the 3D flying space is defined by a center path and a cross section about the path;
- determining a distance between the boundary of the 3D flying space and a location of an aircraft;
- comparing the distance between the boundary of the 3D flying space and the location of the aircraft against a threshold; and
- presenting, in a user interface, at least one of visual, audio, and haptic feedback about a relative distance between the boundary of the 3D flying space and the location of the aircraft is based at least in part on the comparison.
5420582 | May 30, 1995 | Kubbat |
5920321 | July 6, 1999 | Owen |
6433729 | August 13, 2002 | Staggs |
6653947 | November 25, 2003 | Dwyer |
6696980 | February 24, 2004 | Langner |
7010398 | March 7, 2006 | Wilkins, Jr. |
7598888 | October 6, 2009 | Matuska |
7603209 | October 13, 2009 | Dwyer |
7693621 | April 6, 2010 | Chamas |
7869943 | January 11, 2011 | Simon |
8140197 | March 20, 2012 | Lapidot |
8160755 | April 17, 2012 | Nichols |
8339283 | December 25, 2012 | Filliatre |
8362925 | January 29, 2013 | Brinkman |
8527118 | September 3, 2013 | Jones |
8581748 | November 12, 2013 | Barber |
8786633 | July 22, 2014 | Dairman |
8849477 | September 30, 2014 | Brinkman |
8849483 | September 30, 2014 | Kuwata |
8965601 | February 24, 2015 | Barber |
8983689 | March 17, 2015 | Putz |
9014880 | April 21, 2015 | Durling |
9020663 | April 28, 2015 | Smith |
9086280 | July 21, 2015 | Gurusamy |
9117368 | August 25, 2015 | Agarwal |
9132913 | September 15, 2015 | Shapiro |
9147349 | September 29, 2015 | Maddanimath |
9237313 | January 12, 2016 | Aspen |
9354078 | May 31, 2016 | Burgin |
9405005 | August 2, 2016 | Arteaga |
9495877 | November 15, 2016 | Duffy |
9508264 | November 29, 2016 | Chan |
9728089 | August 8, 2017 | Marcus |
9734723 | August 15, 2017 | Bruno |
9875659 | January 23, 2018 | Feyereisen |
10147329 | December 4, 2018 | Liu |
10438495 | October 8, 2019 | Robertson |
10598932 | March 24, 2020 | Marshall |
20020053983 | May 9, 2002 | Chamas |
20030137444 | July 24, 2003 | Stone |
20030151630 | August 14, 2003 | Kellman |
20040015274 | January 22, 2004 | Wilkins, Jr. |
20050200501 | September 15, 2005 | Smith |
20050206533 | September 22, 2005 | Rogers |
20060265109 | November 23, 2006 | Canu-Chiesa |
20070168122 | July 19, 2007 | Aspen |
20070235594 | October 11, 2007 | Wingett |
20080142642 | June 19, 2008 | Marino |
20080147320 | June 19, 2008 | Burch |
20090210109 | August 20, 2009 | Ravenscroft |
20100023187 | January 28, 2010 | Gannon |
20100094487 | April 15, 2010 | Brinkman |
20100145599 | June 10, 2010 | Wise |
20100280753 | November 4, 2010 | Chytil |
20100292871 | November 18, 2010 | Schultz |
20100332056 | December 30, 2010 | Kirk |
20110202206 | August 18, 2011 | Karthikeyan |
20110231036 | September 22, 2011 | Yogesha |
20120194556 | August 2, 2012 | Schmitt |
20130138275 | May 30, 2013 | Nauman |
20130234884 | September 12, 2013 | Bunch |
20130261850 | October 3, 2013 | Smith |
20140018979 | January 16, 2014 | Goossen |
20140266807 | September 18, 2014 | Behara |
20150254988 | September 10, 2015 | Wang |
20150325064 | November 12, 2015 | Downey |
20170278404 | September 28, 2017 | Gordon |
20170320589 | November 9, 2017 | Moravek |
20170357273 | December 14, 2017 | Michini |
20180068567 | March 8, 2018 | Gong |
20180204469 | July 19, 2018 | Moster |
20180268721 | September 20, 2018 | McCullough |
Type: Grant
Filed: Aug 28, 2019
Date of Patent: Feb 2, 2021
Patent Publication Number: 20200066165
Assignee: Kitty Hawk Corporation (Palo Alto, CA)
Inventors: Cameron Robertson (San Mateo, CA), Alex Roetter (San Francisco, CA)
Primary Examiner: Jonathan M Dager
Application Number: 16/553,786
International Classification: G08G 5/04 (20060101); G08G 5/00 (20060101); G01C 23/00 (20060101); G06F 3/01 (20060101); B64D 43/02 (20060101);