US20210341614A1 - Movable object for performing real-time mapping - Google Patents
Movable object for performing real-time mapping Download PDFInfo
- Publication number
- US20210341614A1 US20210341614A1 US17/162,358 US202117162358A US2021341614A1 US 20210341614 A1 US20210341614 A1 US 20210341614A1 US 202117162358 A US202117162358 A US 202117162358A US 2021341614 A1 US2021341614 A1 US 2021341614A1
- Authority
- US
- United States
- Prior art keywords
- payload
- assembly
- sensor
- uav
- movable object
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
- 238000013507 mapping Methods 0.000 title abstract description 116
- 239000000463 material Substances 0.000 claims description 14
- 239000011248 coating agent Substances 0.000 claims description 4
- 238000000576 coating method Methods 0.000 claims description 4
- 238000001514 detection method Methods 0.000 claims description 2
- 230000000712 assembly Effects 0.000 claims 1
- 238000000429 assembly Methods 0.000 claims 1
- 238000000034 method Methods 0.000 abstract description 21
- 238000004891 communication Methods 0.000 description 45
- 230000033001 locomotion Effects 0.000 description 33
- 230000006870 function Effects 0.000 description 21
- 230000007246 mechanism Effects 0.000 description 20
- 238000012545 processing Methods 0.000 description 17
- 238000005516 engineering process Methods 0.000 description 7
- 238000001125 extrusion Methods 0.000 description 7
- 238000009877 rendering Methods 0.000 description 7
- 238000005259 measurement Methods 0.000 description 6
- 238000009826 distribution Methods 0.000 description 5
- 230000005540 biological transmission Effects 0.000 description 4
- 238000012986 modification Methods 0.000 description 4
- 230000004048 modification Effects 0.000 description 4
- 238000013439 planning Methods 0.000 description 4
- 230000001360 synchronised effect Effects 0.000 description 4
- 230000001133 acceleration Effects 0.000 description 3
- 230000008901 benefit Effects 0.000 description 3
- 230000008859 change Effects 0.000 description 3
- 239000003086 colorant Substances 0.000 description 3
- 238000010276 construction Methods 0.000 description 3
- 238000012937 correction Methods 0.000 description 3
- 238000007689 inspection Methods 0.000 description 3
- 238000003860 storage Methods 0.000 description 3
- RZVHIXYEVGDQDX-UHFFFAOYSA-N 9,10-anthraquinone Chemical compound C1=CC=C2C(=O)C3=CC=CC=C3C(=O)C2=C1 RZVHIXYEVGDQDX-UHFFFAOYSA-N 0.000 description 2
- 238000003491 array Methods 0.000 description 2
- 230000003190 augmentative effect Effects 0.000 description 2
- 238000006243 chemical reaction Methods 0.000 description 2
- 238000007906 compression Methods 0.000 description 2
- 230000006835 compression Effects 0.000 description 2
- 238000013461 design Methods 0.000 description 2
- 230000000694 effects Effects 0.000 description 2
- 229920001971 elastomer Polymers 0.000 description 2
- 230000010354 integration Effects 0.000 description 2
- 239000011159 matrix material Substances 0.000 description 2
- 230000003287 optical effect Effects 0.000 description 2
- 239000003973 paint Substances 0.000 description 2
- 230000008569 process Effects 0.000 description 2
- 239000005060 rubber Substances 0.000 description 2
- 230000035939 shock Effects 0.000 description 2
- 238000004088 simulation Methods 0.000 description 2
- 229920003051 synthetic elastomer Polymers 0.000 description 2
- 230000009466 transformation Effects 0.000 description 2
- 238000013519 translation Methods 0.000 description 2
- 238000012800 visualization Methods 0.000 description 2
- 238000012935 Averaging Methods 0.000 description 1
- 229920000049 Carbon (fiber) Polymers 0.000 description 1
- RYGMFSIKBFXOCR-UHFFFAOYSA-N Copper Chemical compound [Cu] RYGMFSIKBFXOCR-UHFFFAOYSA-N 0.000 description 1
- 241000282414 Homo sapiens Species 0.000 description 1
- 241001465754 Metazoa Species 0.000 description 1
- 229910000831 Steel Inorganic materials 0.000 description 1
- 238000010521 absorption reaction Methods 0.000 description 1
- 230000002776 aggregation Effects 0.000 description 1
- 238000004220 aggregation Methods 0.000 description 1
- XAGFODPZIPBFFR-UHFFFAOYSA-N aluminium Chemical compound [Al] XAGFODPZIPBFFR-UHFFFAOYSA-N 0.000 description 1
- 229910052782 aluminium Inorganic materials 0.000 description 1
- 238000004458 analytical method Methods 0.000 description 1
- 230000006399 behavior Effects 0.000 description 1
- 239000004917 carbon fiber Substances 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 229910052802 copper Inorganic materials 0.000 description 1
- 239000010949 copper Substances 0.000 description 1
- 230000008878 coupling Effects 0.000 description 1
- 238000010168 coupling process Methods 0.000 description 1
- 238000005859 coupling reaction Methods 0.000 description 1
- 238000013480 data collection Methods 0.000 description 1
- 238000013144 data compression Methods 0.000 description 1
- 230000001934 delay Effects 0.000 description 1
- 239000000383 hazardous chemical Substances 0.000 description 1
- 238000003384 imaging method Methods 0.000 description 1
- 238000009434 installation Methods 0.000 description 1
- 230000002452 interceptive effect Effects 0.000 description 1
- 238000002955 isolation Methods 0.000 description 1
- 230000004807 localization Effects 0.000 description 1
- VNWKTOKETHGBQD-UHFFFAOYSA-N methane Chemical compound C VNWKTOKETHGBQD-UHFFFAOYSA-N 0.000 description 1
- 239000000203 mixture Substances 0.000 description 1
- 229920003052 natural elastomer Polymers 0.000 description 1
- 229920001194 natural rubber Polymers 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000000149 penetrating effect Effects 0.000 description 1
- 238000012805 post-processing Methods 0.000 description 1
- 238000002360 preparation method Methods 0.000 description 1
- 230000005855 radiation Effects 0.000 description 1
- 230000000284 resting effect Effects 0.000 description 1
- 239000011359 shock absorbing material Substances 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 230000000087 stabilizing effect Effects 0.000 description 1
- 239000010959 steel Substances 0.000 description 1
- 239000000126 substance Substances 0.000 description 1
- 239000005061 synthetic rubber Substances 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 229920002725 thermoplastic elastomer Polymers 0.000 description 1
- 230000001131 transforming effect Effects 0.000 description 1
- 239000011800 void material Substances 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S7/00—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00
- G01S7/48—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00 of systems according to group G01S17/00
- G01S7/51—Display arrangements
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B64—AIRCRAFT; AVIATION; COSMONAUTICS
- B64C—AEROPLANES; HELICOPTERS
- B64C39/00—Aircraft not otherwise provided for
- B64C39/02—Aircraft not otherwise provided for characterised by special use
- B64C39/024—Aircraft not otherwise provided for characterised by special use of the remote controlled vehicle type, i.e. RPV
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B64—AIRCRAFT; AVIATION; COSMONAUTICS
- B64D—EQUIPMENT FOR FITTING IN OR TO AIRCRAFT; FLIGHT SUITS; PARACHUTES; ARRANGEMENT OR MOUNTING OF POWER PLANTS OR PROPULSION TRANSMISSIONS IN AIRCRAFT
- B64D47/00—Equipment not otherwise provided for
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B64—AIRCRAFT; AVIATION; COSMONAUTICS
- B64U—UNMANNED AERIAL VEHICLES [UAV]; EQUIPMENT THEREFOR
- B64U10/00—Type of UAV
- B64U10/10—Rotorcrafts
- B64U10/13—Flying platforms
- B64U10/14—Flying platforms with four distinct rotor axes, e.g. quadcopters
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01C—MEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
- G01C11/00—Photogrammetry or videogrammetry, e.g. stereogrammetry; Photographic surveying
- G01C11/02—Picture taking arrangements specially adapted for photogrammetry or photographic surveying, e.g. controlling overlapping of pictures
- G01C11/025—Picture taking arrangements specially adapted for photogrammetry or photographic surveying, e.g. controlling overlapping of pictures by scanning the object
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01C—MEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
- G01C21/00—Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
- G01C21/20—Instruments for performing navigational calculations
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01C—MEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
- G01C23/00—Combined instruments indicating more than one navigational value, e.g. for aircraft; Combined measuring devices for measuring two or more variables of movement, e.g. distance, speed or acceleration
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S17/00—Systems using the reflection or reradiation of electromagnetic waves other than radio waves, e.g. lidar systems
- G01S17/02—Systems using the reflection of electromagnetic waves other than radio waves
- G01S17/06—Systems determining position data of a target
- G01S17/42—Simultaneous measurement of distance and other co-ordinates
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S17/00—Systems using the reflection or reradiation of electromagnetic waves other than radio waves, e.g. lidar systems
- G01S17/86—Combinations of lidar systems with systems other than lidar, radar or sonar, e.g. with direction finders
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S17/00—Systems using the reflection or reradiation of electromagnetic waves other than radio waves, e.g. lidar systems
- G01S17/88—Lidar systems specially adapted for specific applications
- G01S17/89—Lidar systems specially adapted for specific applications for mapping or imaging
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01S—RADIO DIRECTION-FINDING; RADIO NAVIGATION; DETERMINING DISTANCE OR VELOCITY BY USE OF RADIO WAVES; LOCATING OR PRESENCE-DETECTING BY USE OF THE REFLECTION OR RERADIATION OF RADIO WAVES; ANALOGOUS ARRANGEMENTS USING OTHER WAVES
- G01S7/00—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00
- G01S7/48—Details of systems according to groups G01S13/00, G01S15/00, G01S17/00 of systems according to group G01S17/00
- G01S7/481—Constructional features, e.g. arrangements of optical elements
- G01S7/4811—Constructional features, e.g. arrangements of optical elements common to transmitter and receiver
- G01S7/4813—Housing arrangements
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05D—SYSTEMS FOR CONTROLLING OR REGULATING NON-ELECTRIC VARIABLES
- G05D1/00—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots
- G05D1/0011—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots associated with a remote control arrangement
- G05D1/0038—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots associated with a remote control arrangement by providing the operator with simple or augmented images from one or more cameras located onboard the vehicle, e.g. tele-operation
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05D—SYSTEMS FOR CONTROLLING OR REGULATING NON-ELECTRIC VARIABLES
- G05D1/00—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots
- G05D1/0094—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots involving pointing a payload, e.g. camera, weapon, sensor, towards a fixed or moving target
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05D—SYSTEMS FOR CONTROLLING OR REGULATING NON-ELECTRIC VARIABLES
- G05D1/00—Control of position, course, altitude or attitude of land, water, air or space vehicles, e.g. using automatic pilots
- G05D1/10—Simultaneous control of position or course in three dimensions
- G05D1/101—Simultaneous control of position or course in three dimensions specially adapted for aircraft
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
- G06F3/0484—Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
- G06F3/04845—Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range for image manipulation, e.g. dragging, rotation, expansion or change of colour
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T15/00—3D [Three Dimensional] image rendering
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T15/00—3D [Three Dimensional] image rendering
- G06T15/08—Volume rendering
-
- B64C2201/123—
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B64—AIRCRAFT; AVIATION; COSMONAUTICS
- B64U—UNMANNED AERIAL VEHICLES [UAV]; EQUIPMENT THEREFOR
- B64U2101/00—UAVs specially adapted for particular uses or applications
- B64U2101/30—UAVs specially adapted for particular uses or applications for imaging, photography or videography
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2200/00—Indexing scheme for image data processing or generation, in general
- G06T2200/24—Indexing scheme for image data processing or generation, in general involving graphical user interfaces [GUIs]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2210/00—Indexing scheme for image generation or computer graphics
- G06T2210/56—Particle system, point based geometry or rendering
Definitions
- the disclosed embodiments relate generally to techniques for mapping and more particularly, but not exclusively, to a movable object for performing real-time mapping.
- Movable objects such as unmanned aerial vehicles (UAVs) can be used for performing surveillance, reconnaissance, and exploration tasks for various applications.
- Movable objects may carry a payload, including various sensors, which enables the movable objects to capture sensor data during movement of the movable objects.
- the captured sensor data may be rendered on a client device, such as a client device in communication with the movable objects via a remote control, remote server, or other computing device.
- a real-time mapping system can include at least an unmanned aerial vehicle (UAV), comprising a propulsion system, a main body coupled to the propulsion system and a payload assembly coupled to the main body via a mounting assembly, wherein the payload assembly includes a payload comprising a scanning sensor and a positioning sensor, the payload assembly configured to orient the scanning sensor at a plurality of angles relative to the main body.
- UAV unmanned aerial vehicle
- FIG. 1 illustrates an example of a movable object in a movable object environment, in accordance with various embodiments.
- FIG. 2 illustrates an example of a movable object architecture in a movable object environment, in accordance with various embodiments.
- FIG. 3 illustrates an example of a mapping manager in a movable object environment, in accordance with various embodiments.
- FIGS. 4A and 4B illustrate an example of a hierarchical data structure, in accordance with various embodiments.
- FIGS. 5A and 5B illustrate an example of outlier removal in mapping data, in accordance with various embodiments.
- FIG. 6 illustrates an example of intensity values in mapping data, in accordance with various embodiments.
- FIG. 7 illustrates an example of supporting a movable object interface in a software development environment, in accordance with various embodiments.
- FIG. 8 illustrates an example of a movable object interface, in accordance with various embodiments.
- FIG. 9 illustrates an example of components for a movable object in a software development kit (SDK), in accordance with various embodiments.
- SDK software development kit
- FIG. 10 shows a flowchart of a method of target mapping in a movable object environment, in accordance with various embodiments.
- FIG. 11 shows an isometric view of a movable object for performing real-time mapping, in accordance with an embodiment.
- FIG. 12 shows a rear view of a movable object for performing real-time mapping, in accordance with an embodiment.
- FIG. 13 shows an isometric exploded view of the mounting assembly and payload assembly, in accordance with an embodiment.
- FIG. 14 shows an isometric view of base plate, in accordance with some embodiments.
- FIG. 15 shows an isometric assembled view of the mounting assembly and payload assembly, in accordance with an embodiment.
- FIGS. 16A-16D show additional views of the payload assembly in accordance with various embodiments.
- FIG. 17 shows an alternative enclosure to prevent jamming of the positioning sensor of a movable object in accordance with various embodiments.
- FIGS. 18A and 18B show example alignments of lower expansion brackets in accordance with various embodiments.
- FIG. 19 shows an example of the alignment brackets being connected to the movable object body and the expansion brackets, in accordance with an embodiment.
- FIG. 20 shows an alternative mechanical attachment of the payload assembly to a movable object in accordance with various embodiments.
- FIGS. 21-23 show an alternative mechanical attachment of the light detection and ranging (LiDAR) sensor and positioning sensor to a movable object in accordance with various embodiments.
- LiDAR light detection and ranging
- FIG. 24 shows an example of a landing gear in accordance with various embodiments.
- FIG. 25 shows an example of a landing gear bracket in accordance with various embodiments.
- FIG. 26 shows an example of an alternative landing gear mounting point in accordance with various embodiments.
- FIGS. 27-29 show LiDAR fields of view in accordance with various embodiments.
- FIGS. 30-32 show examples of angled positions of a scanning sensor coupled to a movable object, in accordance with various embodiments.
- FIG. 33 shows example scanning patterns that may be implemented by LiDAR sensors that may be used in various embodiments.
- UAV unmanned aerial vehicle
- Embodiments enable a movable object to map a target environment in real-time using data collected from a positioning sensor and a scanning sensor.
- Alternative embodiments may take advantage of post-processing to generate a map following completion of one or more data collection missions executed by one or more movable objects.
- the various embodiments may utilize scan matching techniques for mapping a complex target environment.
- Embodiments can be used to provide LiDAR-based real-time mapping for various applications, such as construction, surveying, target inspection, etc.
- a map can be constructed in real-time, enabling a version of the map to be rendered on a client device as it is collected.
- Such live rendering may enable the user to determine if any areas within the target environment have not been scanned by a scanning sensor electronically coupled to the movable object. Additionally, a high-density version of the map can be generated during the mapping mission and downloaded upon return of the movable object.
- a mapping manager may utilize a parallel computing architecture to perform the real-time mapping while the movable object is performing its mapping mission.
- the mapping data may be output as a LiDAR Data Exchange File (LAS) which may be used by various tools to render the map of the target environment and/or use the mapping data for further processing, planning, etc. Metadata embedded in the LAS output file can facilitate integration of the map with various third-party tools.
- the map may be output in various file formats depending on user preferences.
- a mapping manager can receive mapping data from a scanning sensor (such as a LiDAR sensor or other sensor that provides high resolution scanning of a target environment), and positioning data from a positioning sensor (e.g., a global positioning system (GPS) module, real-time kinematic (RTK) module, an inertial measurement unit (IMU) module, or other positioning sensor).
- the mapping data can be geo-referenced using the positioning data and used to construct the map of the target environment.
- Embodiments objectively geo-reference the mapping data, enabling various target environments to be mapped regardless of environment complexity.
- FIG. 1 illustrates an example of a movable object in a movable object environment 100 , in accordance with various embodiments.
- client device 110 in a movable object environment 100 can communicate with a movable object 104 via a communication link 106 .
- the movable object 104 can be an unmanned aircraft, an unmanned vehicle, a handheld device, and/or a robot.
- the client device 110 can be a portable personal computing device, a smart phone, a remote control, a wearable computer, a virtual reality/augmented reality system, and/or a personal computer.
- the client device 110 can include a remote controller 111 and communication system 120 A, which is responsible for handling the communication between the client device 110 and the movable object 104 via communication system 120 B.
- the communication between the client device 110 and the movable object 104 can include uplink and downlink communication.
- the uplink communication can be used for transmitting control signals
- the downlink communication can be used for transmitting media or video stream, mapping data collected scanning sensors, or other sensor data collected by other sensors.
- the communication link 106 can be (part of) a network, which is based on various wireless technologies, such as the WiFi, Bluetooth, 3G/4G, and other radio frequency technologies. Furthermore, the communication link 106 can be based on other computer network technologies, such as the internet technology, or any other wired or wireless networking technology. In some embodiments, the communication link 106 may be a non-network technology, including direct point-to-point connections such as universal serial bus (USB) or universal asynchronous receiver-transmitter (UART).
- USB universal serial bus
- UART universal asynchronous receiver-transmitter
- movable object 104 in a movable object environment 100 can include a payload assembly 122 and a payload, such as a scanning sensor 124 (e.g., a LiDAR sensor).
- a scanning sensor 124 e.g., a LiDAR sensor
- the movable object 104 is described generally as an aircraft, this is not intended to be limiting, and any suitable type of movable object can be used.
- the payload may be provided on the movable object 104 without requiring the payload assembly.
- the movable object 104 may include one or more movement mechanisms 116 (e.g., propulsion mechanisms), a sensing system 118 , and a communication system 120 B.
- the movement mechanisms 116 can include one or more of rotors, propellers, blades, engines, motors, wheels, axles, magnets, nozzles, animals, or human beings.
- the movable object may have one or more propulsion mechanisms.
- the movement mechanisms may all be of the same type. Alternatively, the movement mechanisms can be different types of movement mechanisms.
- the movement mechanisms 116 can be mounted on the movable object 104 (or vice-versa), using any suitable means such as a support element (e.g., a drive shaft).
- the movement mechanisms 116 can be mounted on any suitable portion of the movable object 104 , such on the top, bottom, front, back, sides, or suitable combinations thereof.
- the movement mechanisms 116 can enable the movable object 104 to take off vertically from a surface or land vertically on a surface without requiring any horizontal movement of the movable object 104 (e.g., without traveling down a runway).
- the movement mechanisms 116 can be operable to permit the movable object 104 to hover in the air at a specified position and/or orientation.
- One or more of the movement mechanisms 116 may be controlled independently of the other movement mechanisms, for example by an application executing on client device 110 , computing device 112 , or other computing device in communication with the movement mechanisms.
- the movement mechanisms 116 can be configured to be controlled simultaneously.
- the movable object 104 can have multiple horizontally oriented rotors that can provide lift and/or thrust to the movable object.
- the multiple horizontally oriented rotors can be actuated to provide vertical takeoff, vertical landing, and hovering capabilities to the movable object 104 .
- one or more of the horizontally oriented rotors may spin in a clockwise direction, while one or more of the horizontally oriented rotors may spin in a counterclockwise direction.
- the number of clockwise rotors may be equal to the number of counterclockwise rotors.
- each of the horizontally oriented rotors can be varied independently in order to control the lift and/or thrust produced by each rotor, and thereby adjust the spatial disposition, velocity, and/or acceleration of the movable object 104 (e.g., with respect to up to three degrees of translation and up to three degrees of rotation).
- a controller such as flight controller 114 , can send movement commands to the movement mechanisms 116 to control the movement of movable object 104 . These movement commands may be based on and/or derived from instructions received from client device 110 , computing device 112 , or other entity.
- the sensing system 118 can include one or more sensors that may sense the spatial disposition, velocity, and/or acceleration of the movable object 104 (e.g., with respect to various degrees of translation and various degrees of rotation).
- the one or more sensors can include any of the sensors, including GPS sensors, motion sensors, inertial sensors, proximity sensors, or image sensors.
- the sensing data provided by the sensing system 118 can be used to control the spatial disposition, velocity, and/or orientation of the movable object 104 (e.g., using a suitable processing unit and/or control module).
- the sensing system 118 can be used to provide data regarding the environment surrounding the movable object, such as weather conditions, proximity to potential obstacles, location of geographical features, location of manmade structures, and the like.
- the communication system 120 B enables communication with client device 110 via communication link 106 , which may include various wired and/or wireless technologies as discussed above, and communication system 120 A.
- the communication system 120 A or 120 B may include any number of transmitters, receivers, and/or transceivers suitable for wireless communication.
- the communication may be one-way communication, such that data can be transmitted in only one direction. For example, one-way communication may involve only the movable object 104 transmitting data to the client device 110 , or vice-versa.
- the data may be transmitted from one or more transmitters of the communication system 120 B of the movable object to one or more receivers of the communication system 120 A of the client device, or vice-versa.
- the communication may be two-way communication, such that data can be transmitted in both directions between the movable object 104 and the client device 110 .
- the two-way communication can involve transmitting data from one or more transmitters of the communication system 120 B of the movable object 104 to one or more receivers of the communication system 120 A of the client device 110 , and transmitting data from one or more transmitters of the communication system 120 A of the client device 110 to one or more receivers of the communication system 120 B of the movable object 104 .
- a client device 110 may communicate with a mapping manager 126 installed on computing device 112 over a transparent transmission channel of a communication link 106 .
- the transparent transmission channel can be provided through the flight controller of the movable object which allows the data to pass through unchanged (e.g., “transparent”) to the mapping manager or other application on computing device 112 .
- mapping manager 126 may utilize a software development kit (SDK), application programming interfaces (APIs), or other interfaces made available by the movable object, computing device, scanning sensor 124 , etc.
- SDK software development kit
- APIs application programming interfaces
- mapping manager may be implemented by one or more processors on movable object 104 (e.g., flight controller 114 or other processors), computing device 112 , remote controller 111 , client device 110 , or other computing device in communication with movable object 104 .
- mapping manager 126 may be implemented as an application executing on client device 110 , computing device 112 , or other computing device in communication with movable object 104 .
- an application executing on client device 110 or computing device 112 can provide control data to one or more of the movable object 104 , payload assembly 122 , and payload 124 and receive information from one or more of the movable object 104 , payload assembly 122 , and payload 124 (e.g., position and/or motion information of the movable object, payload assembly or payload; data sensed by the payload such as image data captured by a payload camera or mapping data captured by a LiDAR sensor; and data generated from image data captured by the payload camera or LiDAR data generated from mapping data captured by the LiDAR sensor).
- position and/or motion information of the movable object, payload assembly or payload e.g., position and/or motion information of the movable object, payload assembly or payload
- data sensed by the payload such as image data captured by a payload camera or mapping data captured by a LiDAR sensor
- control data may result in a modification of the location and/or orientation of the movable object (e.g., via control of the movement mechanisms 116 ), or a movement of the payload with respect to the movable object (e.g., via control of the payload assembly 122 ).
- the control data from the application may result in control of the payload, such as control of the operation of scanning sensor 124 , a camera or other image capturing device (e.g., taking still or moving pictures, zooming in or out, turning on or off, switching imaging modes, changing image resolution, changing focus, changing depth of field, changing exposure time, changing viewing angle or field of view).
- the communications from the movable object, payload assembly and/or payload may include information obtained from one or more sensors (e.g., of the sensing system 118 or of the scanning sensor 124 or other payload) and/or data generated based on the sensing information.
- the communications may include sensed information obtained from one or more different types of sensors (e.g., GPS sensors, motion sensors, inertial sensors, proximity sensors, or image sensors). Such information may pertain to the position (e.g., location, orientation), movement, or acceleration of the movable object, payload assembly, and/or payload.
- Such information from a payload may include data captured by the payload or a sensed state of the payload.
- computing device 112 can be added to the movable object.
- the computing device can be powered by the movable object and can include one or more processors, such as CPUs, GPUs, field programmable gate arrays (FPGAs), system on chip (SoC), application-specific integrated circuit (ASIC), or other processors.
- the computing device can include an operating system (OS), such as Windows 10®, Linux®, Unix®-based operating systems, or other OS.
- OS operating system
- Mission processing can be offloaded from the flight controller 114 to the computing device 112 .
- the mapping manager 126 can execute on the computing device 112 , client device 110 , payload 124 , a remote server (not shown), or other computing device.
- mapping manager 126 can be used to provide LiDAR-based real-time mapping for various applications, such as construction, surveying, target inspection, etc. Rather than collecting data to be post-processed into a map representation of the target, a map can be constructed in real-time, enabling a version of the map to be rendered on client device 110 as it is collected. Such live rendering may enable the user to determine if any areas within the target environment have not been scanned by scanning sensor 124 . Additionally, another version of the map may be downloaded and used upon return of the movable object. In various embodiments, the mapping manager 126 may utilize a parallel computing architecture in computing device 112 to perform the real-time mapping.
- the mapping manager 126 may perform data compression to transform a dense map into a sparse map to be rendered on client device 110 .
- the mapping manager 126 may be used to reduce data size required for transmission from the movable object 104 to the client device 110 , and thus, data transmission time and bandwidth are saved for efficient real-time map rendering.
- the live rendering of the map may be a lower resolution or a compressed data version of the map (i.e., a sparse map) compared to the version obtained from the movable object upon its return from scanning the target environment (i.e., a dense map).
- the map may be output as a LiDAR Data Exchange File (LAS) which may be used by various tools to render the map of the target environment and/or use the mapping data for further processing, planning, etc. Metadata embedded in the LAS output file can facilitate integration of the map with various third-party tools.
- the map may be output in various file formats depending on user preferences.
- Mapping manager 126 can receive mapping data from scanning sensor 124 .
- scanning sensor 124 may be a LiDAR sensor or other sensor that provides high resolution scanning of a target environment.
- the mapping manager 126 may also receive positioning data from a positioning sensor (e.g., a GPS module, RTK module, or other positioning sensor).
- the positioning sensor may be part of functional modules 108 , sensing system 118 , or a separate module coupled to movable object 104 which provides positioning data for the movable object.
- the mapping data can be geo-referenced using the positioning data and used to construct the map of the target environment.
- Prior methods of 3D mapping have relied on complex environments that are conducive to scan-matching. Unlike prior mapping systems, which require complex environments in order to use scan-matching to prepare the map, embodiments objectively geo-reference the mapping data. This allows for various target environments to be mapped regardless of environment complexity.
- FIG. 2 illustrates an example 200 of a movable object architecture in a movable object environment, in accordance with various embodiments.
- a movable object 104 can include a computing device 112 and flight controller 114 .
- the computing device 112 can connect to the scanning sensor 124 via a high bandwidth connection, such as Ethernet or universal serial bus (USB).
- the computing device 112 may also connect to a positioning sensor 202 over a low bandwidth connection, such as universal asynchronous receiver-transmitter (UART).
- UART universal asynchronous receiver-transmitter
- the positioning sensor 202 may be included as a separate module (as shown in FIG. 2 ) or may be included as part of functional modules 108 or sensing system 118 .
- Positioning sensor 202 may include a radio 204 , such as a 4G, 5G, or other cellular or mobile network radio.
- the radio 204 may be used by RTK module 206 to enhance positioning data collected by GPS module 208 .
- GPS module 208 can receive a reference signal from a reference station using radio 204 and provide a correction to the positioning data provided by GPS module 208 .
- GPS module 208 can output a clock signal, such as a pulse per second (1PPS) signal, to the scanning sensor 124 . This allows for the scanning sensor and the GPS sensor to apply synchronized time stamps to their collected data using the same clock signal.
- a clock signal such as a pulse per second (1PPS) signal
- the computing device 112 can connect to one or more high bandwidth components, such as one or more cameras, a stereo vision module, or payload.
- the computing device 112 can connect to the flight controller 114 via UART and/or USB to send and receive data to and from the remote control via communication system 120 B.
- the computing device 112 may include one or more CPUs, GPUs, field programmable gate arrays (FPGA), systems on chip (SoC), or other processor(s).
- Flight controller 114 can connect to various functional modules 108 , such as magnetometer 210 , barometer 212 , and inertial measurement unit (IMU) 214 .
- communication system 120 B can connect to computing device 112 instead of, or in addition to, flight controller 114 .
- sensor data collected by the one or more functional modules 108 and the positioning sensor 202 can be passed from the flight controller 114 to the computing device 112 .
- flight controller 114 and computing device 112 can be implemented as separate devices (e.g., separate processors on separate circuit boards). Alternatively, one or more of the flight controller 114 and computing device 112 can be implemented as a single device, such as an SoC. In various embodiments, computing device 112 may be removable from the movable object.
- FIG. 3 illustrates an example 300 of a mapping manager 126 in a movable object environment, in accordance with various embodiments.
- a mapping manager 126 may execute on one or more processors 302 of computing device 112 .
- the one or more processors 302 may include CPUs, GPUs, FGPAs, SoCs, or other processors, and may be part of a parallel computing architecture implemented by computing device 112 .
- the mapping manager 126 may include sensor interfaces 303 , data preparation module 308 , and map generator 316 .
- Sensor interfaces 303 can include a scanning sensor interface 304 and a positioning sensor interface 306 .
- the sensor interfaces 303 may include hardware and/or software interfaces.
- the scanning sensor interface 304 can receive data from the scanning sensor (e.g., a LiDAR or other scanning sensor) and the positioning sensor interface 306 can receive data from the positioning sensor (e.g., a GPS sensor, an RTK sensor, an IMU sensor, and/or other positioning sensors or a combination thereof).
- the scanning sensor may produce mapping data in a point cloud format.
- the point cloud of the mapping data may be a three-dimensional representation of the target environment.
- the point cloud of the mapping data may be converted to a matrix representation.
- the positioning data may include GPS coordinates for the movable object and, in some embodiments, may include roll, pitch, and yaw values associated with the movable object corresponding to each GPS coordinate.
- the roll, pitch, and yaw values may be obtained from the positioning sensor, such as an inertial measurement unit (IMU), or other sensor.
- the positioning data may be obtained from an RTK module, which corrects the GPS coordinates based on a correction signal received from a reference station.
- the RTK module may produce a variance value associated with each output coordinate.
- the variance value may represent the accuracy of the corresponding positioning data. For example, if the movable object is performing sharp movements, the variance value may go up, indicating less accurate positioning data has been collected.
- the variance value may also vary depending on atmospheric conditions, leading to different accuracies measured by the movable object depending on the particular conditions present when the data was collected.
- the positioning sensor and scanning sensor may share clock circuitry.
- the positioning sensor may include clock circuitry and output a clock signal to the scanning sensor.
- a separate clock circuit may output a clock signal to both the scanning sensor and the positioning sensor.
- the positioning data and the mapping data may be time-stamped using the shared clock signal.
- the positioning sensor and scanning sensor may output data with differing delays.
- the positioning sensor and the scanning sensor may not start generating data at the same time.
- the positioning data and/or mapping data may be buffered to account for the delay.
- a buffer size may be chosen based on the delay between the output of each sensor.
- mapping manager can receive the data from the positioning sensor and scanning sensor and output synchronized data using the timestamps shared by the sensor data with respect to the shared clock signal. This enables the positioning data and mapping data to be synchronized before further processing. Additionally, the frequency of the data obtained from each sensor may be different.
- the scanning sensor may be producing data in the range of hundreds of kHz, while the positioning sensor may be producing data in the range of hundreds of Hz.
- upsampling module 310 can interpolate the lower frequency data to match the higher frequency data. For example, assuming the positioning data is produced by the positioning sensor at 100 Hz and the mapping data is produced by the scanning sensor (e.g., a LiDAR sensor) at 100 kHz, the positioning data may be upsampled from 100 Hz to 100 kHz.
- Various upsampling techniques may be used to upsample the positioning data. For example, a linear fit algorithm, such as least squares, may be used.
- non-linear fit algorithms may be used to upsample the positioning data.
- the roll, pitch, yaw values of the positioning data may also be interpolated to match the frequency of the mapping data.
- the roll, pitch, and yaw values may be spherical linear interpolated (SLERP) to match the number of points in the mapping data.
- SLERP spherical linear interpolated
- the time stamps may likewise be interpolated to match the interpolated positioning data.
- geo-reference module 312 can convert the matrix representation of the mapping data from the frame of reference (or the reference coordinate system) in which it was collected (e.g., scanner reference frame or scanner reference coordinate system) to a desired frame of reference (or a desired reference coordinate system).
- the positioning data may be converted from the scanner reference frame to a north-east-down (NED) reference frame (or a NED coordinate system).
- NED north-east-down
- the reference frame to which the positioning data is converted may vary depending on the application of the map that is being produced. For example, if the map is being used in surveying, it may be converted to the NED reference frame. For another example, if the map is being used for rendering motions such as flight simulation, it may be converted to the FlightGear coordinate system. Other applications of the map may effect conversions of the positioning data to different reference frames or different coordinate systems.
- Each point in the point cloud of the mapping data is associated with a position in the scanner reference frame that is determined relative to the scanning sensor.
- the positioning data of the movable object, produced by the positioning sensor may then be used to convert this position in the scanner reference frame to the output reference frame in a world coordinate system, such as a GPS coordinate system.
- a world coordinate system such as a GPS coordinate system.
- the position of the scanning sensor in the world coordinate system is known based on the positioning data.
- the positioning sensor and the scanning module may be offset (e.g., due to being located at different positions on the movable object).
- a further correction factoring in this offset may be used to convert from the scanner reference frame to the output reference frame (e.g., each measured position in the positioning data may be corrected using the offset between the positioning sensor and the scanning sensor).
- the corresponding positioning data can be identified using the time stamp. The point can then be converted to the new reference frame.
- the scanner reference frame can be converted into a horizontal reference frame using the interpolated roll, pitch, and yaw values from the positioning data. Once the mapping data has been converted into the horizontal reference frame, it may be further converted into a Cartesian frame or other output reference frame.
- the result is a geo-referenced point cloud, with each point in the point cloud now referenced to the world coordinate system.
- the geo-referenced point cloud can be provided to map generator 316 before performing outlier removal to remove outlier data from the geo-referenced point cloud.
- outlier removal module 314 can remove outlier data from the geo-referenced point cloud.
- the geo-referenced point cloud may be downsampled, reducing the number of outliers in the data. Downsampling of this data may be performed using voxels.
- the points in each voxel may be averaged, and one or more averaged points may be output per voxel. As such, outlier points will be removed from the data set in the course of averaging the points in each voxel.
- the resolution of the voxels e.g., the size of each voxel
- the resolution may be determined by the user, or by the mapping manager based on, e.g., available computing resources, user preferences, default values, or other application-specific information. For example, a lower resolution (e.g., larger voxel size) may be used to produce a sparse downsampled point cloud for visualization on a client device or a mobile device. Additionally, or alternatively, outliers may be removed statistically. For example, the distance from each point to its nearest neighbor may be determined and statistically analyzed.
- the outlier removal technique may be selectable by the user or be automatically selected by the mapping manager. In some embodiments, outlier removal may be disabled.
- the point cloud data may be a three-dimensional representation of the target environment.
- This 3D representation can be divided into voxels (e.g., 3D pixels).
- the resulting point cloud data can be provided to map generator 316 .
- the map generator 316 may include a dense map generator 318 and/or a sparse map generator 320 .
- dense map generator 318 can produce a high-density map from the point cloud data received before outlier removal
- sparse map generator 320 can produce a low-density map from the sparse downsampled point cloud data received after outlier removal.
- dense map generator 318 and sparse map generator 320 may produce a high-density map and a low-density map separately from the point cloud received both after outlier removal.
- each map generator may generate the output map using the same process but may vary the size of the voxels to produce high-density or low-density maps.
- the low-density map can be used by a client device or a mobile device to provide real-time visualization of the mapping data.
- the high-density map can be output as a LIDAR Data Exchange File (LAS) or other file type to be used with various mapping, planning, analysis, or other tools.
- LAS LIDAR Data Exchange File
- the map generator may use the point cloud data to perform a probabilistic estimation of the position of points in the map.
- the map generator may use a 3D mapping library, such as OctoMap to produce the output map.
- the map generator can divide the point cloud data into voxels. For each voxel, the map generator can determine how many points are in the voxel and, based on the number of points and the variance associated with each point, determine the probability that a point is in that voxel. The probability may be compared to an occupancy threshold and, if the probability is greater than the occupancy threshold, a point may be represented in that voxel in the output map. In some embodiments, the probability that a given voxel is occupied can be represented as:
- ⁇ z 1 : t ) [ 1 + 1 - P ⁇ ( n ⁇
- z 1:t ) of a node n being occupied is a function of the current measurement z 1 , a prior probability P(n), and the previous estimate P(n
- P(n) represents the total probability that a voxel n is occupied.
- the use of 1 ⁇ 2 in the above equation is implementation specific, such that the probability is mapped to a range of 1 ⁇ 2-1. This range may vary, depending on the particular implementation in use.
- the total probability is the product of probabilities calculated for the x, y, and z dimensions. The probability in each dimension may be determined based on the mean, ⁇ , for each point in that dimension, and the variance, ⁇ 2 , of each measurement in a given dimension, with x, y, and z corresponding to the coordinate values of a given point.
- a large number of points near the mean point in a given voxel may increase the probability, while a more diffuse collection of points in the voxel may lower the probability.
- a large variance associated with the data e.g., indicating lower accuracy position data has been collected
- P(n, ⁇ , ⁇ 2 ) represents the Gaussian distribution for the voxel, given the mean and variance values of the points in that voxel.
- the occupancy threshold can be set based on the amount of processing resources available and/or based on the acceptable amount of noise in the data for a given application.
- the occupancy threshold can be set to a default value of 70%.
- a higher threshold can be set to reduce noise.
- the occupancy threshold may be set depending on the quality of the data being collected. For example, data collected under one set of conditions may be high quality (e.g., low variance) and a lower occupancy threshold can be set, while lower quality data may necessitate a higher occupancy threshold.
- the resulting map data can then be output as an LAS file, or other file format.
- the geo-referenced point cloud data may be output without additional processing (e.g., outlier removal).
- each point in the point cloud data may also be associated with an intensity value.
- the intensity value may represent various features of the object being scanned, such as elevation above a reference plane, material composition, etc.
- the intensity value for each point in the output map may be an average of the intensity values measured for each point in the mapping data collected by the scanning sensor (e.g., a LiDAR sensor).
- FIGS. 4A and 4B illustrate an example of a hierarchical data structure, in accordance with various embodiments.
- data representing a 3D environment 400 can be divided into a plurality of voxels.
- the target environment can be divided into eight voxels, with each voxel being further divided into eight sub-voxels, and each sub-voxel divided into eight further smaller sub-voxels.
- Each voxel may represent a different volumetric portion of the 3D environment.
- the voxels may be subdivided until a smallest voxel size is reached.
- the resulting 3D environment can be represented as a hierarchical data structure 402 , where the root of the data structure represents the entire 3D environment, and each child node represents a different voxel in different hierarchy within the 3D environment.
- FIGS. 5A and 5B illustrate an example of outlier removal in mapping data, in accordance with various embodiments.
- a target object when scanned, it may be represented as a plurality of points, with those points clustered on different parts of the object, including surfaces (such as surface 501 ), edges (such as edge 503 ), and other portions of the target object in the target environment. For simplicity of depiction, these surfaces, edges, etc. are shown solid.
- regions 500 A- 500 F of the data there are additional outlier points. This may be most noticeable in regions of empty space, as shown in FIG. 5A . These points are diffuse, as compared to the more densely packed points of the surfaces and edges of the target object.
- Outlier removal may be used to eliminate or reduce the number of these points in the data.
- the geo-referenced point cloud data may be downsampled, reducing the number of outliers in the data.
- outliers may be removed statistically. For example, the distance from each point to its nearest neighbor may be determined and statistically analyzed. If the distance from a point to its nearest neighbor is greater than a threshold value (e.g., a standard deviation of the nearest neighbor distances in the point cloud), then that point may be removed from the point cloud.
- a threshold value e.g., a standard deviation of the nearest neighbor distances in the point cloud
- FIG. 6 illustrates an example 600 of intensity values in mapping data, in accordance with various embodiments.
- intensity values may be to represent elevation above a reference plane.
- different elevation ranges may be assigned a different intensity value 602 - 606 , as depicted here using greyscale coloration.
- intensity may be represented using different colors to represent different values or ranges of values.
- intensity may be used to represent different materials being scanned. For example, steel and concrete will absorb and reflect the incident radiation produced by the scanning sensor differently, enabling the scanning sensor to identify different materials in use. Each material may be encoded as a different intensity value associated with each point and represented by a different color in the output map.
- continuous gradients of colors may be used to represent continuous changes in elevation value above a reference plane.
- FIG. 7 illustrates an example of supporting a movable object interface in a software development environment, in accordance with various embodiments.
- a movable object interface 703 can be used for providing access to a movable object 701 in a software development environment 700 , such as a software development kit (SDK) environment.
- the movable object interface 703 may render a real-time map generated by the mapping manager and other interfacing components for receiving user input.
- the real-time map may be rendered on a display of a client device or other computing device in communication with the movable object.
- the SDK can be an onboard SDK implemented on an onboard environment that is coupled to the movable object 701 .
- the SDK can also be a mobile SDK implemented on an off-board environment that is coupled to a client device or a mobile device.
- the mapping manager can be implemented using an onboard SDK coupled to the movable object 701 or a mobile SDK coupled to a client device or a mobile device to enable applications to perform real-time mapping, as described herein.
- the movable object 701 can include various functional modules A-C 711 - 713
- the movable object interface 703 can include different interfacing components A-C 731 - 733 .
- Each said interfacing component A-C 731 - 733 in the movable object interface 703 corresponds to a module A-C 711 - 713 in the movable object 701 .
- the interfacing components may be rendered on a user interface of a display of a client device or other computing device in communication with the movable object.
- the interfacing components, as rendered may include selectable command buttons for receiving user input/instructions to control corresponding functional modules of the movable object.
- the movable object interface 703 can provide one or more callback functions for supporting a distributed computing model between the application and movable object 701 .
- the callback functions can be used by an application for confirming whether the movable object 701 has received the commands. Also, the callback functions can be used by an application for receiving the execution results. Thus, the application and the movable object 701 can interact even though they are separated in space and in logic.
- the interfacing components A-C 731 - 733 can be associated with the listeners A-C 741 - 743 .
- a listener A-C 741 - 743 can inform an interfacing component A-C 731 - 733 to use a corresponding callback function to receive information from the related module(s).
- a data manager 702 which prepares data 720 for the movable object interface 703 , can decouple and package the related functionalities of the movable object 701 .
- the data manager 702 may be onboard, that is coupled to or located on the movable object 701 , which prepares the data 720 to be communicated to the movable object interface 703 via communication between the movable object 701 and a client device or a mobile device.
- the data manager 702 may be off board, that is coupled to or located on a client device or a mobile device, which prepares data 720 for the movable object interface 703 via communication within the client device or the mobile device.
- mapping manager 702 can be used for managing the data exchange between the applications and the movable object 701 .
- mapping manager 126 may be one implementation of data manager 702 .
- the mapping manager is used for managing mapping data, including generating a map using mapping data and positioning data and rendering the generated map for display based on a default setting or a user selection.
- the onboard or mobile SDK can provide a series of callback functions for communicating instant messages and for receiving the execution results from a movable object.
- the onboard or mobile SDK can configure the life cycle for the callback functions in order to make sure that the information interchange is stable and completed.
- the onboard or mobile SDK can establish connection between a movable object and an application on a smart phone (e.g. using an Android system or an iOS system).
- the callback functions such as the ones receiving information from the movable object, can take advantage of the patterns in the smart phone system and update the statements accordingly to the different stages in the life cycle of the smart phone system.
- FIG. 8 illustrates an example of a movable object interface, in accordance with various embodiments.
- a movable object interface 803 can be rendered on a display of a client device or other computing devices representing statuses of different components of a movable object 801 .
- the applications e.g., APPs 804 - 806
- these apps may include an inspection app 804 , a viewing app 805 , and a calibration app 806 .
- the movable object 801 can include various modules, such as a camera 811 , a battery 812 , a gimbal 813 , and a flight controller 814 .
- the movable object interface 803 can include a camera component 821 , a battery component 822 , a gimbal component 823 , and a flight controller component 824 to be rendered on a computing device or other computing devices to receive user input/instructions by way of using the APPs 804 - 806 .
- the movable object interface 803 can include a ground station component 826 , which is associated with the flight controller component 824 .
- the ground station component operates to perform one or more flight control operations, which may require a high-level privilege.
- FIG. 9 illustrates an example of components for a movable object in a software development kit (SDK), in accordance with various embodiments.
- the SDK 900 may be an onboard SDK implemented on an onboard mapping manager or a mobile SDK implemented on mapping manager located on a client device or a mobile device.
- the SDK 900 may correspond to all or a portion of the mapping manager described above or may be used to implement the mapping manager as a standalone application.
- the drone class 901 in the SDK 900 is an aggregation of other components 902 - 907 for a movable object (e.g., a drone).
- the drone class 901 which have access to the other components 902 - 907 , can exchange information with the other components 902 - 907 and controls the other components 902 - 907 .
- an application may be accessible to only one instance of the drone class 901 .
- multiple instances of the drone class 901 can present in an application.
- an application can connect to the instance of the drone class 901 in order to upload the controlling commands to the movable object.
- the SDK may include a function for establishing the connection to the movable object.
- the SDK can disconnect the connection to the movable object using an end connection function.
- the developer can have access to the other classes (e.g. the camera class 902 , the battery class 903 , the gimbal class 904 , and the flight controller class 905 ).
- the drone class 901 can be used for invoking the specific functions, e.g. providing access data which can be used by the flight controller to control the behavior, and/or limit the movement, of the movable object.
- an application can use a battery class 903 for controlling the power source of a movable object. Also, the application can use the battery class 903 for planning and testing the schedule for various flight tasks. As battery is one of the most restricted elements in a movable object, the application may seriously consider the status of battery not only for the safety of the movable object but also for making sure that the movable object can finish the designated tasks.
- the battery class 903 can be configured such that if the battery level is low, the movable object can terminate the tasks and go home outright. For example, if the movable object is determined to have a battery level that is below a threshold level, the battery class may cause the movable object to enter a power savings mode.
- the battery class may shut off, or reduce, power available to various components that are not integral to safely returning the movable object to its home. For example, cameras that are not used for navigation and other accessories may lose power, to increase the amount of power available to the flight controller, motors, navigation system, and any other systems needed to return the movable object home, make a safe landing, etc.
- the application can obtain the current status and information of the battery by invoking a function to request information from in the Drone Battery Class.
- the SDK can include a function for controlling the frequency of such feedback.
- an application can use a camera class 902 for defining various operations on the camera in a movable object, such as an unmanned aircraft.
- the Camera Class includes functions for receiving media data in SD card, getting & setting photo parameters, taking photo and recording videos.
- An application can use the camera class 902 for modifying the setting of photos and records.
- the SDK may include a function that enables the developer to adjust the size of photos taken.
- an application can use a media class for maintaining the photos and records.
- an application can use a gimbal class 904 for controlling the view of the movable object.
- the Gimbal Class can be used for configuring an actual view, e.g. setting a first personal view of the movable object.
- the Gimbal Class can be used for automatically stabilizing the gimbal, in order to be focused on one direction.
- the application can use the Gimbal Class to change the angle of view for detecting different objects.
- an application can use a flight controller class 905 for providing various flight control information and status about the movable object.
- the flight controller class can include functions for receiving and/or requesting access data to be used to control the movement of the movable object across various regions in a movable object environment.
- an application can monitor the flight status, e.g. using instant messages.
- the callback function in the Flight Controller Class can send back the instant message every one thousand milliseconds (1000 ms).
- the Flight Controller Class allows a user of the application to investigate the instant message received from the movable object. For example, the pilots can analyze the data for each flight in order to further improve their flying skills.
- an application can use a ground station class 907 to perform a series of operations for controlling the movable object.
- the SDK may require applications to have an SDK-LEVEL-2 key for using the Ground Station Class.
- the Ground Station Class can provide one-key-fly, on-key-go-home, manually controlling the drone by app (i.e. joystick mode), setting up a cruise and/or waypoints, and various other task scheduling functionalities.
- an application can use a communication component for establishing the network connection between the application and the movable object.
- mapping data can be obtained from a scanning sensor (e.g., a LiDAR sensor) supported by a movable object (e.g., a UAV).
- the scanning sensor can be a LiDAR sensor.
- positioning data can be obtained from a positioning sensor (e.g., a GPS sensor, an RTK sensor, an IMU sensor, and/or other positioning sensors or a combination thereof) supported by the movable object (e.g., a UAV).
- the positioning sensor can be an RTK sensor or an IMU sensor.
- the mapping data can be associated with the positioning data based at least on time data associated with the mapping data and the positioning data.
- associating the mapping data with the positioning data may include upsampling the positioning data to include a number of positions equal to a number of points in the mapping data, and associating each point in the mapping data with a corresponding position in the upsampled positioning data.
- the time data associated with the mapping data and the positioning data may be obtained using clock circuitry providing a reference clock signal electronically coupled to the scanning sensor and the positioning sensor.
- a map in a first coordinate system may be generated based at least on the associated mapping data and positioning data.
- generating the map may include, for each voxel of a plurality of voxels of the map, determining one or more points from the mapping data to be located in the voxel, and determining an occupancy probability for the voxel based at least on a number of points in that voxel.
- the occupancy probability is determined based on a variance of the positioning data associated with the one or more points located in the voxel.
- an average position of the one or more points in the voxel can be calculated, and a point can be generated in the map at the average position.
- an average intensity value of the one or more points in the voxel can be calculated, and the average intensity value can be associated with the generated point in the map.
- the average intensity value is calculated based on feature of each point in the voxel, where the feature of each point is associated with an elevation or a material detected by the scanning sensor.
- the method may further include determining a distribution of points in the mapping data, each of the points in the mapping data associated with a distance from a nearest neighboring point in the mapping data, and removing any points associated with a distance greater than a distance threshold value.
- the method may further include downsampling the mapping data by a scaling factor, dividing the mapping data into a plurality of voxels, and outputting an average point from the downsampled mapping data for each of the plurality of voxels.
- the method may further include transforming the map into a second coordinate system and outputting the transformed map.
- the positioning data may be converted from the scanner reference frame to a north-east-down (NED) reference frame (or a NED coordinate system).
- the reference frame to which the positioning data is converted may vary depending on the application of the map that is being produced. For example, if the map is being used in surveying, it may be converted to the NED reference frame. For another example, if the map is being used for rendering motions such as flight simulation, it may be converted to the FlightGear coordinate system. Other applications of the map may effect conversions of the positioning data to different reference frames or different coordinate systems.
- geo-referencing as described above may be combined with scan matching, such as Simultaneous Localization and Mapping (SLAM) or LiDAR Odometry and Mapping (LOAM).
- scan matching such as Simultaneous Localization and Mapping (SLAM) or LiDAR Odometry and Mapping (LOAM).
- SLAM Simultaneous Localization and Mapping
- LOAM LiDAR Odometry and Mapping
- Traditional methods make use of SLAM with or without inertial navigation input. For example, some methods inject IMU information with SLAM and sometimes inject odometry via GPS which provides an improved mapping algorithm.
- embodiments can perform direct geo-referencing as discussed above, and then a layer of SLAM or LOAM can be added on top of the geo-references. This provides a robust mapping algorithm as the geo-references serves as a floor on the quality of the resulting map.
- geo-referencing as described above may be combined with normal distribution transformation (NDT).
- NDT is a LiDAR scan registration method which is in between a feature-based registration method (such as LOAM) and a point-based registration method (such as iterative closest point).
- the “features” of the world are described by multivariate Gaussian distributions defined in each voxel.
- a probability density function (PDF) is generated for each cell and points are matched to the map by maximizing the sum of probability generated by the PDF, points x, and a transformation T:
- a movable object may be used for performing real-time mapping of various application environments, such as construction site mapping, surveying, target object mapping, etc.
- the movable object may be an unmanned aerial vehicle (UAV), such as shown in FIG. 11 , which has been configured to perform real-time mapping.
- UAV unmanned aerial vehicle
- FIG. 11 shows an isometric view 1100 of a movable object for performing real-time mapping, in accordance with an embodiment.
- a UAV in various embodiments may include a main body 1110 .
- the main body may include, or be coupled to, a sensing system, a communications system, movement mechanisms, such as motors 1112 which may independently power rotors (not shown) to cause the UAV to fly and navigate a predefined route and/or a route based on real time user commands, and other systems and functional modules as discussed above.
- a UAV configured to perform real-time mapping may include a payload assembly (or a sensor assembly) 1102 , which may include a scanning sensor and a positioning sensor (as discussed above), and a mounting assembly 1104 to connect the payload assembly to the movable object body.
- the UAV may further include a landing gear assembly 1106 designed to provide a secure platform when not in flight and during landing/takeoff, while not interfering with the field of view (FOV) of the scanning sensor of payload assembly 1102 .
- the angle 1108 of the landing gear may be based on the FOV of the scanning sensor in use. This may include fixed landing gear, such as shown in FIG. 11 , and adjustable landing gear, which may change the angle 1108 of the landing gear dynamically, based on the sensor in use.
- FIG. 12 shows a rear view 1200 of a movable object (e.g., a UAV) for performing real-time mapping, in accordance with an embodiment.
- a main body 1202 can be coupled to the mounting assembly 1104 .
- the mounting assembly can include expansion brackets 1204 which are coupled to the main body 1202 using one or more fasteners, and which provide clearance for various components of the movable object, such as batteries, onboard computing device 1206 , and other components.
- the mounting assembly may further include a base plate 1208 coupled to the expansion brackets using a plurality of dampers 1210 .
- the payload assembly 1102 including a LiDAR/global navigation satellite service (GNSS) IMU system is secured to the underside of the movable object via the mounting assembly using a plurality of mounting points of the base plate 1208 .
- Vibration isolation is provided to the LiDAR/GNSS IMU system via the base plate 1208 resting on the plurality of dampers 1210 .
- GNSS global navigation satellite service
- base plate 1208 may include dovetail mounts 1212 .
- the dovetail mounts 1212 enable the user to slide the payload assembly 1102 (e.g., including a LiDAR/GNSS IMU system) in position and secure with two fasteners, such as M4 wingnuts or other suitable fasteners. This enables the payload assembly, including the LiDAR/GNSS IMU system to be easily removed from the movable object via the mounting assembly.
- the angle 1216 of the landing gear legs from the movable object may be adjustable, depending on the size of the payload, batteries, or other components and/or based on the FOV of the scanning sensor or other sensors included in the payload.
- FIG. 13 shows an isometric exploded view 1300 of the mounting assembly and payload assembly, in accordance with an embodiment.
- mounting assembly 1104 may include base plate 1208 which is coupled to the expansion brackets 1204 at a plurality of locations 1304 .
- the lower end of each expansion bracket e.g., the end closest to the payload assembly
- Each location may include a damper that, when assembled, is under compression between the base plate 1208 and the expansion brackets 1204 .
- Each damper may be made of a compressible material, such as a natural or synthetic rubber, thermoplastic elastomer, or other shock absorbing material.
- each damper may include flared ends. A lower flared end may be forced through a hole in an expansion bracket 1204 and an upper flared end may be forced through a hole in the base plate 1208 .
- Such an arrangement couples the base plate 1208 to the expansion brackets 1204 using the plurality of dampers.
- the base plate 1208 may be coupled to the expansion brackets 1204 at more or fewer locations, in accordance with various embodiments.
- the base plate 1208 may further include a plurality of holes 1306 which line up with holes 1308 of the payload assembly when assembled via the dovetails. A fastener may be inserted through the aligned holes to secure the payload assembly to the base plate 1208 .
- the payload assembly may include two payload support brackets 1302 . Each payload support bracket may include a dovetail which enables the payload support bracket to be connected to the dovetail groove in the base plate 1208 .
- the base plate 1208 may include a dovetail that can be inserted into a dovetail groove in each payload support bracket 1302 .
- the payload assembly may further include a pivot bracket 1312 .
- the pivot bracket can be connected to scanning sensor 1310 (such as a LiDAR sensor) using one or more fasteners.
- the pivot bracket may include one or more pivot arms 1314 which can be connected to the payload support brackets 1302 .
- the pivot bracket includes two pivot arms 1314 .
- a hole 1316 in each pivot arm can be aligned with a hole 1318 in each payload support bracket 1302 to secure the scanning sensor 1310 at a particular scanning angle.
- the payload support bracket can be secured to the pivot bracket using any suitable fastener which is removable such that the pivot bracket can be pivoted to another scanning angle (e.g., aligned with a different hole in the payload support bracket) and then recoupled to change the scanning angle of the scanning sensor 1310 .
- the pivot bracket 1312 may further include at least one mounting point 1319 to which a positioning sensor 1320 (e.g., a GNSS IMU system, an RTK system, an RTK/IMU system, etc.) can be attached.
- a positioning sensor 1320 e.g., a GNSS IMU system, an RTK system, an RTK/IMU system, etc.
- the positioning sensor 1320 can be bolted, screwed, epoxied, or be otherwise fixedly coupled to the pivot bracket 1312 .
- the positioning sensor 1320 may be permanently coupled to the pivot bracket 1312 or may be removably coupled to the pivot bracket 1312 .
- the positioning sensor 1320 may be protected from the elements and/or electromagnetic interference using a positioning sensor enclosure 1322 which may be coupled to the pivot bracket 1312 .
- the positioning sensor enclosure 1322 provides ingress protection (IP) for the electronics from foreign debris and moisture.
- IP ingress protection
- the enclosure 1322 is sprayed with a thin layer of paint or other substance to protect the GNSS IMU from jamming caused by electromagnetic interference. This may include copper paint, or other material suitable to preventing jamming due to electromagnetic interference.
- an onboard computing device 1206 (such as computing device 112 described above) may be coupled to the base plate 1208 using a computing device bracket 1324 .
- expansion brackets 1204 can be stabilized using alignment brackets 1326 . These can ensure that the expansion brackets 1204 remain parallel while in flight and eliminate or reduce undesirable twisting of the mounting assembly which might affect the reliability of the sensor data, such as mapping data and positioning data, collected by the scanning sensor and positioning sensor.
- FIG. 14 shows an isometric view 1400 of base plate 1208 , in accordance with some embodiments.
- Base plate 1208 can include the plurality of mounting locations 1402 at which the dampers may be used to couple the base plate to the expansion brackets, as discussed above.
- mounting holes 1306 may be located above the dovetail grooves 1404 , with the holes penetrating from the surface of the base plate 1208 to the dovetail grooves 1404 , allowing them to be aligned with holes of the payload support interface as discussed above.
- FIG. 15 shows an isometric assembled view 1500 of the mounting assembly and payload assembly, in accordance with an embodiment.
- the dovetails of payload support brackets 1302 are inserted into the dovetail grooves of base plate 1208 .
- Positioning sensor enclosure 1322 is in place covering the positioning sensor and coupled to the pivot bracket.
- the pivot arms are aligned with an intermediate hole of the payload support brackets 1302 , causing the scanning sensor to be set at an angle between 90 degrees and 0 degrees, such as 35 degrees relative to the base plate 1208 or a horizontal plane when a UAV (e.g., as shown above with respect to FIG. 11 ) is in its landing pose.
- the expansion brackets 1204 and alignment brackets 1326 can be coupled to a UAV (e.g., as shown above with respect to FIG. 11 ), to secure the mounting assembly to the UAV for mapping missions, as discussed above.
- FIGS. 16A-16D show additional views 1600 - 1606 of the payload assembly in accordance with various embodiments.
- the pivot bracket 1312 may include a plurality of mounting points 1608 to which the positioning sensor may be coupled.
- the positioning sensor can be mounted to the plurality of mounting points 1608 by aligning a plurality of mounting holes 1610 in the positioning sensor 1320 and securing the positioning sensor 1320 to the mounting points 1608 using fasteners, such as screws or other suitable fasteners.
- the payload support brackets 1302 can be coupled to the pivot brackets at pivot arms 1314 .
- the pivot arms can be aligned to corresponding holes on the payload support brackets to secure the scanning sensor 1310 at a predefined scanning angle.
- the payload support brackets 1302 may include grooves to which the pivot arms 1304 may be coupled, enabling a selection of a range of angles rather than particular angles predefined by the hole placements in the payload support brackets.
- the positioning sensor enclosure 1322 can be secured to the pivot bracket to protect the positioning sensor from debris, electromagnetic interference, and/or other environmental hazards.
- the assembled payload assembly may be connected to the base plate of the mounting assembly using dovetails and coupled to the base plate by aligning holes 1308 with corresponding holes in the base plate and securing with a suitable fastener.
- FIG. 17 shows an alternative enclosure 1700 to prevent jamming of the positioning sensor of a movable object in accordance with various embodiments.
- an aluminum enclosure can be added which serves as a Faraday cage with its various circular cutouts. The size and locations of the circular cutouts may be selected for the frequency or frequencies of electromagnetic interference that are expected and/or those frequencies most likely to interfere with the functioning of the IMU.
- FIGS. 18A and 18B show example alignments of lower expansion brackets in accordance with various embodiments.
- an alignment bracket 1326 can provide alignment of the expansion brackets such that the expansion brackets remain in parallel to one another. Absent the alignment brackets, the expansion brackets may freely rotate in place after installation on the movable object. Thus, there is a need to constrain the expansion brackets such that the back planes of the brackets remain parallel.
- the alignment bracket may include a square (or other shaped) extension 1804 . This may be inserted into correspondingly shaped holes 1806 in the expansion brackets 1204 .
- FIG. 19 shows an example 1900 of the alignment bracket 1326 being connected to the movable object body 1202 and the expansion brackets 1204 , in accordance with an embodiment.
- two threaded screw holes can be used: a first for alignment and a second for mounting on the movable object.
- movable object body 1202 may include holes 1902 through which a screw may be inserted and screwed into a first threaded screw hole of alignment bracket 1326 .
- Alignment bracket 1326 may further include a second threaded screw hole 1904 which may be aligned with a hole 1906 in expansion brackets 1204 , as shown in FIG. 19 .
- FIG. 20 shows an alternative 2000 mechanical attachment of the payload assembly (including a scanning sensor and a positioning sensor, as discussed above) to a movable object via a mounting assembly, in accordance with various embodiments.
- Plate 2002 is fastened to the underside of the movable object directly or indirectly via the mounting assembly, and plate 2004 can be fastened to the payload assembly.
- the two plates can be coupled using a plurality of dampers 2006 which are under compression when assembled.
- a fastener (such as a wingnut or other suitable fastener) can be attached into the bottom of the rod piece 2008 inserted through plates 2002 and 2004 and fastened to the payload assembly through the hole 2010 in a crossbar 2012 connecting the payload support brackets 1302 , making the payload assembly easily removable.
- plate 2002 may be coupled to the base plate of the mounting assembly described above or may be used to replace the base plate of the mounting assembly. In other embodiments, plate 2002 may be coupled directly to the main body of a movable object (e.g., an UAV).
- a movable object e.g., an UAV
- a mirror or a plate with a reflective coating material may be installed on the scanning sensor (such as the LiDAR sensor) via the fastener, at a certain angle that overlaps with at least a portion of the FOV of the scanning sensor in use.
- the FOV of the scanning sensor may be broadened to include a second FOV that is created by laser lights illuminated from the scanning sensor that are being reflected by the mirror or the plate with the reflective coating material.
- FIGS. 21-23 show an alternative mechanical attachment of the LiDAR and positioning sensor to a movable object in accordance with various embodiments.
- the alternative mechanical attachment shown at 2100 may include a payload assembly similar to that discussed above.
- the payload assembly may include payload support brackets 2102 coupled by a crossbar 2104 .
- a T-extrusion member 2106 can be fastened to an upper surface of the crossbar (e.g., the surface closest to the movable object).
- the T-extrusion member may be permanently coupled to the crossbar (e.g., welded, epoxied, or otherwise fixedly coupled) or fastened using one or more removable fasteners.
- a long axis 2108 of the T-extrusion member may be substantially orthogonal to a long axis 2110 of a clearance slot in alternative base plate 2112 .
- FIG. 22 shows an alternative view 2200 of the mechanical attachment.
- the payload assembly can be rotated 90 degrees relative to the alternative base plate 2112 such that the long axis 2108 of the T-extrusion member is aligned with the long axis 2110 of the clearance slot and the T-extrusion member can be raised through the clearance slot.
- the T-extrusion member 2106 has been raised through the clearance slot of the alternative base plate 2112 and then the payload assembly has been rotated 90 degrees in the opposite direction.
- the T-extrusion member can be secured to the top pressure plate 2300 with fasteners (e.g., wingnuts or other suitable fasteners).
- the top pressure plate 2300 can be coupled to the alternative base plate 2112 using a plurality of dampers 2302 to reduce the movement of the payload assembly relative to the alternative base plate 2112 .
- FIG. 24 shows an example 2400 of a landing gear in accordance with various embodiments.
- the landing gear legs 2402 may be angled 1108 based on the field of view (FOV) of the scanning sensor 1310 .
- FOV field of view
- the landing gear legs 2402 may be at a fixed angle of 55 degrees (e.g., measured in the plane formed by the landing gear legs) to accommodate the FOV of the particular scanning sensor in use.
- the angle 1108 of the landing gear legs 2402 may be adjusted, manually or automatically, based on the FOV of the scanning sensor in use.
- the landing gear legs 2402 may be coupled to the movable object using a landing gear bracket 2404 .
- the landing gear bracket can provide the fixed angle 1108 of the landing gear legs 2402 .
- the landing gear bracket can be connected to the movable object using connecting member 2406 .
- the connecting member 2406 and the landing gear legs 2402 can be made of the same material.
- the connecting member can connect to a landing gear mounting bracket of the movable object body via a quick release connection.
- FIG. 25 shows an example 2500 of a landing gear bracket 2404 in accordance with various embodiments.
- the landing gear bracket 2404 can secure the landing gear legs 2402 as well as provide shock absorption for the landing gear legs.
- the landing gear bracket 2404 may include a rubber (such as, SPE I synthetic elastomer) damper to fill the void at the location where the landing gear legs and connection member (such as carbon fiber tubes) intersect. This rubber damper helps to absorb and dissipate energy during an impulse force.
- FIG. 26 shows an example 2600 of an alternative landing gear mounting point in accordance with various embodiments.
- a mounting point 2602 can be used to attach landing gear legs on the movable object such that the landing gear remains outside the field of view of the scanning sensor.
- This design uses the space adjacent to the motor heat sinks 2604 to attach the landing gear to the movable object arms. Using this small area helps to improve the vertical alignment of landing legs.
- a landing gear leg can be attached adjacent to each motor heat sink. For example, if the movable object is a quadcopter with four motors and corresponding heat sinks, then four landing gear mounting points can be provided with four landing gear legs. In some embodiments, at least three landing gear mounting points and associated landing gear legs may be provided regardless of the number of motors equipped on the movable object.
- FIGS. 27-29 show LiDAR fields of view in accordance with various embodiments.
- the LiDAR is positioned to scan at 35 degrees.
- the LiDAR's FOV is in between the two planes 2702 .
- the FOV of the LiDAR would intersect the traditional landing gear assembly 2704 (shown dashed to indicate where it would be located if it were provided).
- the traditional landing gear assembly 2704 would partially obstruct the FOV of the scanning sensor.
- the angled landing gear assembly 2706 can include angled legs, as discussed above.
- the landing gear legs may be angled depending on the FOV of the scanning sensor in use. As shown in FIG. 27 , when so angled, the landing gear legs remain outside of LiDAR's field of view at the 35° position. This eliminates the obstructions caused by the traditional landing gear assembly, leading to more efficient scanning missions.
- FIGS. 28 and 29 show the LiDAR FOV at its 90° position. In the example 2800 of FIG. 28 , the UAV is shown from the side view, with the LiDAR positioned to scan at 90 degrees. The FOV 2802 of the LiDAR in this position is obstructed by the traditional landing gear assembly 2704 , similar to that discussed above with respect to FIG. 27 .
- FIG. 29 shows an isometric view 2900 of the UAV with the LiDAR in the 90-degree position. As discussed with respect to FIG. 28 , the angled landing gear assembly 2706 does not obstruct the FOV 2802 in this position as the traditional landing gear assembly 2704 would.
- FIGS. 30-32 show examples of angled positions of a scanning sensor coupled to a movable object, in accordance with various embodiments.
- the LiDAR 1310 can be positioned at 0 degrees relative to horizontal. As discussed above, this position can be achieved using the pivot bracket 1312 and the payload support brackets 1302 .
- the LiDAR 1310 can be positioned at 35 degrees relative to horizontal. This angle position may also be achieved using the payload support brackets 1302 and the pivot bracket 1312 , by aligning corresponding holes in the brackets for the 35-degree position.
- the example 3200 shown in FIG. 32 shows the LiDAR 1310 positioned at 90 degrees relative to horizontal.
- this position may be achieved by changing the alignment of holes in the pivot bracket 1312 to corresponding holes in the payload support bracket 1302 .
- the payload support brackets 1302 may include slots, which enable the user to select various angular positions.
- FIG. 33 shows example 3300 scanning patterns that may be implemented by LiDAR sensors that may be used in various embodiments.
- a LiDAR system is an active sensing system that emits light beams and measures a two-way travel time (i.e. time-of-flight) for the reflected light detected by the LiDAR sensor.
- the collected sensor data may generally be used to measure a range or a distance to an object which has reflected the light emitted by the LiDAR.
- the object's position in a three-dimensional space may be determined using (1) the detected two-way travel time of the emitted light beam, (2) the scanning angle of the light beam in reference to the three-dimensional space, and/or (3) the absolute location of the LiDAR sensor detected using a GPS, GNSS, INS or IMU sensor, etc.
- Different LiDAR sensors may be associated with different scan patterns, scan frequencies, and/or scan angles.
- the scan patterns of a LiDAR sensor can be virtually any waveform by way of utilizing different scanning mechanisms (e.g., using a constant-velocity rotating polygon mirror or an oscillating mirror).
- Some examples of scan patterns include parallel scan lines, which may be generated by a rotating polygon mirror, or sawtooth scan lines which may be generated by an oscillating mirror.
- Other examples may include a sinusoidal scan pattern 3302 , sawtooth scan pattern 3304 , elliptical scan pattern 3306 , spiral scan pattern 3308 , or flower shape scan pattern 3310 , or uniform scan pattern 3312 (which may be a series of concentric scans, such as circular, oval, or other scan shapes).
- LiDAR data may be collected or recorded as discrete points or as a full waveform. Discrete points identify and record points at each peak location in the waveform curve. A full waveform records a distribution of returned energy and thus captures more information compared to discrete points. Whether collected as discrete points or full waveform, LiDAR data are available as discrete points, which is known as a LiDAR point cloud. LiDAR point cloud is usually stored as .las format (or .laz format, which is a highly compressed version of .las).
- Each lidar point data and its metadata may include various data attributes, such as associated coordinate values, an intensity value representing the amount of light energy recorded by the sensor, or classification data representing the type of object the laser return reflected off of (such as classified as ground or non-ground, as different altitudes, or as different material features), etc.
- processors can include, without limitation, one or more general purpose microprocessors (for example, single or multi-core processors), application-specific integrated circuits, application-specific instruction-set processors, graphics processing units, physics processing units, digital signal processing units, coprocessors, network processing units, audio processing units, encryption processing units, and the like.
- the storage medium can include, but is not limited to, any type of disk including floppy disks, optical discs, DVD, CD-ROMs, microdrive, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, DRAMs, VRAMs, flash memory devices, magnetic or optical cards, nanosystems (including molecular memory ICs), or any type of media or device suitable for storing instructions and/or data.
- features can be incorporated in software and/or firmware for controlling the hardware of a processing system, and for enabling a processing system to interact with other mechanism utilizing the results.
- software or firmware may include, but is not limited to, application code, device drivers, operating systems and execution environments/containers.
- ASICs application specific integrated circuits
- FPGA field-programmable gate array
- the present invention may be conveniently implemented using one or more conventional general purpose or specialized digital computer, computing device, machine, or microprocessor, including one or more processors, memory and/or computer readable storage media programmed according to the teachings of the present disclosure.
- Appropriate software coding can readily be prepared by skilled programmers based on the teachings of the present disclosure, as will be apparent to those skilled in the software art.
- disjunctive language such as the phrase “at least one of A, B, or C,” is intended to be understood to mean either A, B, or C, or any combination thereof (e.g., A, B, and/or C). As such, disjunctive language is not intended to, nor should it be understood to, imply that a given embodiment requires at least one of A, at least one of B, or at least one of C to each be present.
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Remote Sensing (AREA)
- Radar, Positioning & Navigation (AREA)
- General Physics & Mathematics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Electromagnetism (AREA)
- Aviation & Aerospace Engineering (AREA)
- Theoretical Computer Science (AREA)
- Automation & Control Theory (AREA)
- General Engineering & Computer Science (AREA)
- Computer Graphics (AREA)
- Mechanical Engineering (AREA)
- Human Computer Interaction (AREA)
- Multimedia (AREA)
- Traffic Control Systems (AREA)
- Position Fixing By Use Of Radio Waves (AREA)
- Navigation (AREA)
- Length Measuring Devices With Unspecified Measuring Means (AREA)
- Optical Radar Systems And Details Thereof (AREA)
- Processing Or Creating Images (AREA)
Abstract
Techniques are disclosed for real-time mapping in a movable object environment. A real-time mapping system can include at least an unmanned aerial vehicle (UAV), comprising a propulsion system, a main body coupled to the propulsion system and a payload assembly coupled to the main body via a mounting assembly, wherein the payload assembly includes a payload comprising a scanning sensor and a positioning sensor, the payload assembly configured to orient the scanning sensor at a plurality of angles relative to the main body.
Description
- This application is a continuation of International Patent Application No. PCT/US2019/058219, filed Oct. 25, 2019, which claims the benefit of U.S. Provisional Application No. 62/752,273, filed Oct. 29, 2018, which is hereby incorporated by reference.
- A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever.
- The disclosed embodiments relate generally to techniques for mapping and more particularly, but not exclusively, to a movable object for performing real-time mapping.
- Movable objects such as unmanned aerial vehicles (UAVs) can be used for performing surveillance, reconnaissance, and exploration tasks for various applications. Movable objects may carry a payload, including various sensors, which enables the movable objects to capture sensor data during movement of the movable objects. The captured sensor data may be rendered on a client device, such as a client device in communication with the movable objects via a remote control, remote server, or other computing device.
- Techniques are disclosed for real-time mapping in a movable object environment. A real-time mapping system can include at least an unmanned aerial vehicle (UAV), comprising a propulsion system, a main body coupled to the propulsion system and a payload assembly coupled to the main body via a mounting assembly, wherein the payload assembly includes a payload comprising a scanning sensor and a positioning sensor, the payload assembly configured to orient the scanning sensor at a plurality of angles relative to the main body.
-
FIG. 1 illustrates an example of a movable object in a movable object environment, in accordance with various embodiments. -
FIG. 2 illustrates an example of a movable object architecture in a movable object environment, in accordance with various embodiments. -
FIG. 3 illustrates an example of a mapping manager in a movable object environment, in accordance with various embodiments. -
FIGS. 4A and 4B illustrate an example of a hierarchical data structure, in accordance with various embodiments. -
FIGS. 5A and 5B illustrate an example of outlier removal in mapping data, in accordance with various embodiments. -
FIG. 6 illustrates an example of intensity values in mapping data, in accordance with various embodiments. -
FIG. 7 illustrates an example of supporting a movable object interface in a software development environment, in accordance with various embodiments. -
FIG. 8 illustrates an example of a movable object interface, in accordance with various embodiments. -
FIG. 9 illustrates an example of components for a movable object in a software development kit (SDK), in accordance with various embodiments. -
FIG. 10 shows a flowchart of a method of target mapping in a movable object environment, in accordance with various embodiments. -
FIG. 11 shows an isometric view of a movable object for performing real-time mapping, in accordance with an embodiment. -
FIG. 12 shows a rear view of a movable object for performing real-time mapping, in accordance with an embodiment. -
FIG. 13 shows an isometric exploded view of the mounting assembly and payload assembly, in accordance with an embodiment. -
FIG. 14 shows an isometric view of base plate, in accordance with some embodiments. -
FIG. 15 shows an isometric assembled view of the mounting assembly and payload assembly, in accordance with an embodiment. -
FIGS. 16A-16D show additional views of the payload assembly in accordance with various embodiments. -
FIG. 17 shows an alternative enclosure to prevent jamming of the positioning sensor of a movable object in accordance with various embodiments. -
FIGS. 18A and 18B show example alignments of lower expansion brackets in accordance with various embodiments. -
FIG. 19 shows an example of the alignment brackets being connected to the movable object body and the expansion brackets, in accordance with an embodiment. -
FIG. 20 shows an alternative mechanical attachment of the payload assembly to a movable object in accordance with various embodiments. -
FIGS. 21-23 show an alternative mechanical attachment of the light detection and ranging (LiDAR) sensor and positioning sensor to a movable object in accordance with various embodiments. -
FIG. 24 shows an example of a landing gear in accordance with various embodiments. -
FIG. 25 shows an example of a landing gear bracket in accordance with various embodiments. -
FIG. 26 shows an example of an alternative landing gear mounting point in accordance with various embodiments. -
FIGS. 27-29 show LiDAR fields of view in accordance with various embodiments. -
FIGS. 30-32 show examples of angled positions of a scanning sensor coupled to a movable object, in accordance with various embodiments. -
FIG. 33 shows example scanning patterns that may be implemented by LiDAR sensors that may be used in various embodiments. - The invention is illustrated, by way of example and not by way of limitation, in the figures of the accompanying drawings in which like references indicate similar elements. It should be noted that references to “an” or “one” or “some” embodiment(s) in this disclosure are not necessarily to the same embodiment, and such references mean at least one.
- The following description of the invention describes target mapping using a movable object. For simplicity of explanation, an unmanned aerial vehicle (UAV) is generally used as an example of a movable object. It will be apparent to those skilled in the art that other types of movable objects can be used without limitation.
- Embodiments enable a movable object to map a target environment in real-time using data collected from a positioning sensor and a scanning sensor. Alternative embodiments may take advantage of post-processing to generate a map following completion of one or more data collection missions executed by one or more movable objects. For example, the various embodiments may utilize scan matching techniques for mapping a complex target environment. Embodiments can be used to provide LiDAR-based real-time mapping for various applications, such as construction, surveying, target inspection, etc. Rather than collecting data to be post-processed into a map representation of the target, a map can be constructed in real-time, enabling a version of the map to be rendered on a client device as it is collected. Such live rendering may enable the user to determine if any areas within the target environment have not been scanned by a scanning sensor electronically coupled to the movable object. Additionally, a high-density version of the map can be generated during the mapping mission and downloaded upon return of the movable object. In various embodiments, a mapping manager may utilize a parallel computing architecture to perform the real-time mapping while the movable object is performing its mapping mission. In some embodiments, the mapping data may be output as a LiDAR Data Exchange File (LAS) which may be used by various tools to render the map of the target environment and/or use the mapping data for further processing, planning, etc. Metadata embedded in the LAS output file can facilitate integration of the map with various third-party tools. In various embodiments, the map may be output in various file formats depending on user preferences.
- In some embodiments, a mapping manager can receive mapping data from a scanning sensor (such as a LiDAR sensor or other sensor that provides high resolution scanning of a target environment), and positioning data from a positioning sensor (e.g., a global positioning system (GPS) module, real-time kinematic (RTK) module, an inertial measurement unit (IMU) module, or other positioning sensor). The mapping data can be geo-referenced using the positioning data and used to construct the map of the target environment. Embodiments objectively geo-reference the mapping data, enabling various target environments to be mapped regardless of environment complexity.
-
FIG. 1 illustrates an example of a movable object in amovable object environment 100, in accordance with various embodiments. As shown inFIG. 1 ,client device 110 in amovable object environment 100 can communicate with amovable object 104 via acommunication link 106. Themovable object 104 can be an unmanned aircraft, an unmanned vehicle, a handheld device, and/or a robot. Theclient device 110 can be a portable personal computing device, a smart phone, a remote control, a wearable computer, a virtual reality/augmented reality system, and/or a personal computer. Additionally, theclient device 110 can include aremote controller 111 andcommunication system 120A, which is responsible for handling the communication between theclient device 110 and themovable object 104 viacommunication system 120B. For example, the communication between theclient device 110 and the movable object 104 (e.g., an unmanned aircraft) can include uplink and downlink communication. The uplink communication can be used for transmitting control signals, the downlink communication can be used for transmitting media or video stream, mapping data collected scanning sensors, or other sensor data collected by other sensors. - In accordance with various embodiments, the
communication link 106 can be (part of) a network, which is based on various wireless technologies, such as the WiFi, Bluetooth, 3G/4G, and other radio frequency technologies. Furthermore, thecommunication link 106 can be based on other computer network technologies, such as the internet technology, or any other wired or wireless networking technology. In some embodiments, thecommunication link 106 may be a non-network technology, including direct point-to-point connections such as universal serial bus (USB) or universal asynchronous receiver-transmitter (UART). - In various embodiments,
movable object 104 in amovable object environment 100 can include apayload assembly 122 and a payload, such as a scanning sensor 124 (e.g., a LiDAR sensor). Although themovable object 104 is described generally as an aircraft, this is not intended to be limiting, and any suitable type of movable object can be used. One of skill in the art would appreciate that any of the embodiments described herein in the context of aircraft systems can be applied to any suitable movable object (e.g., a UAV). In some instances, the payload may be provided on themovable object 104 without requiring the payload assembly. - In accordance with various embodiments, the
movable object 104 may include one or more movement mechanisms 116 (e.g., propulsion mechanisms), asensing system 118, and acommunication system 120B. Themovement mechanisms 116 can include one or more of rotors, propellers, blades, engines, motors, wheels, axles, magnets, nozzles, animals, or human beings. For example, the movable object may have one or more propulsion mechanisms. The movement mechanisms may all be of the same type. Alternatively, the movement mechanisms can be different types of movement mechanisms. Themovement mechanisms 116 can be mounted on the movable object 104 (or vice-versa), using any suitable means such as a support element (e.g., a drive shaft). Themovement mechanisms 116 can be mounted on any suitable portion of themovable object 104, such on the top, bottom, front, back, sides, or suitable combinations thereof. - In some embodiments, the
movement mechanisms 116 can enable themovable object 104 to take off vertically from a surface or land vertically on a surface without requiring any horizontal movement of the movable object 104 (e.g., without traveling down a runway). Optionally, themovement mechanisms 116 can be operable to permit themovable object 104 to hover in the air at a specified position and/or orientation. One or more of themovement mechanisms 116 may be controlled independently of the other movement mechanisms, for example by an application executing onclient device 110,computing device 112, or other computing device in communication with the movement mechanisms. Alternatively, themovement mechanisms 116 can be configured to be controlled simultaneously. For example, themovable object 104 can have multiple horizontally oriented rotors that can provide lift and/or thrust to the movable object. The multiple horizontally oriented rotors can be actuated to provide vertical takeoff, vertical landing, and hovering capabilities to themovable object 104. In some embodiments, one or more of the horizontally oriented rotors may spin in a clockwise direction, while one or more of the horizontally oriented rotors may spin in a counterclockwise direction. For example, the number of clockwise rotors may be equal to the number of counterclockwise rotors. The rotation rate of each of the horizontally oriented rotors can be varied independently in order to control the lift and/or thrust produced by each rotor, and thereby adjust the spatial disposition, velocity, and/or acceleration of the movable object 104 (e.g., with respect to up to three degrees of translation and up to three degrees of rotation). As discussed further herein, a controller, such asflight controller 114, can send movement commands to themovement mechanisms 116 to control the movement ofmovable object 104. These movement commands may be based on and/or derived from instructions received fromclient device 110,computing device 112, or other entity. - The
sensing system 118 can include one or more sensors that may sense the spatial disposition, velocity, and/or acceleration of the movable object 104 (e.g., with respect to various degrees of translation and various degrees of rotation). The one or more sensors can include any of the sensors, including GPS sensors, motion sensors, inertial sensors, proximity sensors, or image sensors. The sensing data provided by thesensing system 118 can be used to control the spatial disposition, velocity, and/or orientation of the movable object 104 (e.g., using a suitable processing unit and/or control module). Alternatively, thesensing system 118 can be used to provide data regarding the environment surrounding the movable object, such as weather conditions, proximity to potential obstacles, location of geographical features, location of manmade structures, and the like. - The
communication system 120B enables communication withclient device 110 viacommunication link 106, which may include various wired and/or wireless technologies as discussed above, andcommunication system 120A. Thecommunication system movable object 104 transmitting data to theclient device 110, or vice-versa. The data may be transmitted from one or more transmitters of thecommunication system 120B of the movable object to one or more receivers of thecommunication system 120A of the client device, or vice-versa. Alternatively, the communication may be two-way communication, such that data can be transmitted in both directions between themovable object 104 and theclient device 110. The two-way communication can involve transmitting data from one or more transmitters of thecommunication system 120B of themovable object 104 to one or more receivers of thecommunication system 120A of theclient device 110, and transmitting data from one or more transmitters of thecommunication system 120A of theclient device 110 to one or more receivers of thecommunication system 120B of themovable object 104. - In some embodiments, a
client device 110 may communicate with amapping manager 126 installed oncomputing device 112 over a transparent transmission channel of acommunication link 106. The transparent transmission channel can be provided through the flight controller of the movable object which allows the data to pass through unchanged (e.g., “transparent”) to the mapping manager or other application oncomputing device 112. In some embodiments,mapping manager 126 may utilize a software development kit (SDK), application programming interfaces (APIs), or other interfaces made available by the movable object, computing device,scanning sensor 124, etc. In various embodiments, the mapping manager may be implemented by one or more processors on movable object 104 (e.g.,flight controller 114 or other processors),computing device 112,remote controller 111,client device 110, or other computing device in communication withmovable object 104. In some embodiments,mapping manager 126 may be implemented as an application executing onclient device 110,computing device 112, or other computing device in communication withmovable object 104. - In some embodiments, an application executing on
client device 110 orcomputing device 112 can provide control data to one or more of themovable object 104,payload assembly 122, andpayload 124 and receive information from one or more of themovable object 104,payload assembly 122, and payload 124 (e.g., position and/or motion information of the movable object, payload assembly or payload; data sensed by the payload such as image data captured by a payload camera or mapping data captured by a LiDAR sensor; and data generated from image data captured by the payload camera or LiDAR data generated from mapping data captured by the LiDAR sensor). - In some embodiments, the control data may result in a modification of the location and/or orientation of the movable object (e.g., via control of the movement mechanisms 116), or a movement of the payload with respect to the movable object (e.g., via control of the payload assembly 122). The control data from the application may result in control of the payload, such as control of the operation of
scanning sensor 124, a camera or other image capturing device (e.g., taking still or moving pictures, zooming in or out, turning on or off, switching imaging modes, changing image resolution, changing focus, changing depth of field, changing exposure time, changing viewing angle or field of view). - In some instances, the communications from the movable object, payload assembly and/or payload may include information obtained from one or more sensors (e.g., of the
sensing system 118 or of thescanning sensor 124 or other payload) and/or data generated based on the sensing information. The communications may include sensed information obtained from one or more different types of sensors (e.g., GPS sensors, motion sensors, inertial sensors, proximity sensors, or image sensors). Such information may pertain to the position (e.g., location, orientation), movement, or acceleration of the movable object, payload assembly, and/or payload. Such information from a payload may include data captured by the payload or a sensed state of the payload. - In some embodiments,
computing device 112 can be added to the movable object. The computing device can be powered by the movable object and can include one or more processors, such as CPUs, GPUs, field programmable gate arrays (FPGAs), system on chip (SoC), application-specific integrated circuit (ASIC), or other processors. The computing device can include an operating system (OS), such as Windows 10®, Linux®, Unix®-based operating systems, or other OS. Mission processing can be offloaded from theflight controller 114 to thecomputing device 112. In various embodiments, themapping manager 126 can execute on thecomputing device 112,client device 110,payload 124, a remote server (not shown), or other computing device. - In some embodiments,
mapping manager 126 can be used to provide LiDAR-based real-time mapping for various applications, such as construction, surveying, target inspection, etc. Rather than collecting data to be post-processed into a map representation of the target, a map can be constructed in real-time, enabling a version of the map to be rendered onclient device 110 as it is collected. Such live rendering may enable the user to determine if any areas within the target environment have not been scanned by scanningsensor 124. Additionally, another version of the map may be downloaded and used upon return of the movable object. In various embodiments, themapping manager 126 may utilize a parallel computing architecture incomputing device 112 to perform the real-time mapping. In some embodiments, themapping manager 126 may perform data compression to transform a dense map into a sparse map to be rendered onclient device 110. By way of compressing the dense map into the sparse map, themapping manager 126 may be used to reduce data size required for transmission from themovable object 104 to theclient device 110, and thus, data transmission time and bandwidth are saved for efficient real-time map rendering. In such embodiments, the live rendering of the map may be a lower resolution or a compressed data version of the map (i.e., a sparse map) compared to the version obtained from the movable object upon its return from scanning the target environment (i.e., a dense map). In some embodiments, the map may be output as a LiDAR Data Exchange File (LAS) which may be used by various tools to render the map of the target environment and/or use the mapping data for further processing, planning, etc. Metadata embedded in the LAS output file can facilitate integration of the map with various third-party tools. In various embodiments, the map may be output in various file formats depending on user preferences. -
Mapping manager 126 can receive mapping data from scanningsensor 124. As discussed,scanning sensor 124 may be a LiDAR sensor or other sensor that provides high resolution scanning of a target environment. Themapping manager 126 may also receive positioning data from a positioning sensor (e.g., a GPS module, RTK module, or other positioning sensor). In some embodiments, the positioning sensor may be part offunctional modules 108,sensing system 118, or a separate module coupled tomovable object 104 which provides positioning data for the movable object. The mapping data can be geo-referenced using the positioning data and used to construct the map of the target environment. Prior methods of 3D mapping have relied on complex environments that are conducive to scan-matching. Unlike prior mapping systems, which require complex environments in order to use scan-matching to prepare the map, embodiments objectively geo-reference the mapping data. This allows for various target environments to be mapped regardless of environment complexity. - Additional details of the movable object architecture are described below with respect to
FIG. 2 . -
FIG. 2 illustrates an example 200 of a movable object architecture in a movable object environment, in accordance with various embodiments. As shown inFIG. 2 , amovable object 104 can include acomputing device 112 andflight controller 114. Thecomputing device 112 can connect to thescanning sensor 124 via a high bandwidth connection, such as Ethernet or universal serial bus (USB). Thecomputing device 112 may also connect to apositioning sensor 202 over a low bandwidth connection, such as universal asynchronous receiver-transmitter (UART). As discussed, thepositioning sensor 202 may be included as a separate module (as shown inFIG. 2 ) or may be included as part offunctional modules 108 orsensing system 118.Positioning sensor 202 may include aradio 204, such as a 4G, 5G, or other cellular or mobile network radio. Theradio 204 may be used byRTK module 206 to enhance positioning data collected byGPS module 208. Although a GPS module is shown inFIG. 2 , any global navigation satellite service may be used, such as GLOSNASS, Galileo, BeiDou, etc.RTK module 206 can receive a reference signal from a referencestation using radio 204 and provide a correction to the positioning data provided byGPS module 208. Additionally,GPS module 208 can output a clock signal, such as a pulse per second (1PPS) signal, to thescanning sensor 124. This allows for the scanning sensor and the GPS sensor to apply synchronized time stamps to their collected data using the same clock signal. - In various embodiments, the
computing device 112 can connect to one or more high bandwidth components, such as one or more cameras, a stereo vision module, or payload. Thecomputing device 112 can connect to theflight controller 114 via UART and/or USB to send and receive data to and from the remote control viacommunication system 120B. In various embodiments, thecomputing device 112 may include one or more CPUs, GPUs, field programmable gate arrays (FPGA), systems on chip (SoC), or other processor(s). -
Flight controller 114 can connect to variousfunctional modules 108, such asmagnetometer 210,barometer 212, and inertial measurement unit (IMU) 214. In some embodiments,communication system 120B can connect tocomputing device 112 instead of, or in addition to,flight controller 114. In some embodiments, sensor data collected by the one or morefunctional modules 108 and thepositioning sensor 202 can be passed from theflight controller 114 to thecomputing device 112. - In some embodiments,
flight controller 114 andcomputing device 112 can be implemented as separate devices (e.g., separate processors on separate circuit boards). Alternatively, one or more of theflight controller 114 andcomputing device 112 can be implemented as a single device, such as an SoC. In various embodiments,computing device 112 may be removable from the movable object. -
FIG. 3 illustrates an example 300 of amapping manager 126 in a movable object environment, in accordance with various embodiments. As shown inFIG. 3 , amapping manager 126 may execute on one ormore processors 302 ofcomputing device 112. The one ormore processors 302 may include CPUs, GPUs, FGPAs, SoCs, or other processors, and may be part of a parallel computing architecture implemented by computingdevice 112. Themapping manager 126 may includesensor interfaces 303,data preparation module 308, andmap generator 316. - Sensor interfaces 303 can include a
scanning sensor interface 304 and apositioning sensor interface 306. The sensor interfaces 303 may include hardware and/or software interfaces. Thescanning sensor interface 304 can receive data from the scanning sensor (e.g., a LiDAR or other scanning sensor) and thepositioning sensor interface 306 can receive data from the positioning sensor (e.g., a GPS sensor, an RTK sensor, an IMU sensor, and/or other positioning sensors or a combination thereof). In various embodiments, the scanning sensor may produce mapping data in a point cloud format. The point cloud of the mapping data may be a three-dimensional representation of the target environment. In some embodiments, the point cloud of the mapping data may be converted to a matrix representation. The positioning data may include GPS coordinates for the movable object and, in some embodiments, may include roll, pitch, and yaw values associated with the movable object corresponding to each GPS coordinate. The roll, pitch, and yaw values may be obtained from the positioning sensor, such as an inertial measurement unit (IMU), or other sensor. As discussed, the positioning data may be obtained from an RTK module, which corrects the GPS coordinates based on a correction signal received from a reference station. In some embodiments, the RTK module may produce a variance value associated with each output coordinate. The variance value may represent the accuracy of the corresponding positioning data. For example, if the movable object is performing sharp movements, the variance value may go up, indicating less accurate positioning data has been collected. The variance value may also vary depending on atmospheric conditions, leading to different accuracies measured by the movable object depending on the particular conditions present when the data was collected. - The positioning sensor and scanning sensor may share clock circuitry. For example, the positioning sensor may include clock circuitry and output a clock signal to the scanning sensor. In some embodiments, a separate clock circuit may output a clock signal to both the scanning sensor and the positioning sensor. As such, the positioning data and the mapping data may be time-stamped using the shared clock signal.
- In some embodiments, the positioning sensor and scanning sensor may output data with differing delays. For example, the positioning sensor and the scanning sensor may not start generating data at the same time. As such, the positioning data and/or mapping data may be buffered to account for the delay. In some embodiments, a buffer size may be chosen based on the delay between the output of each sensor. In some embodiments, mapping manager can receive the data from the positioning sensor and scanning sensor and output synchronized data using the timestamps shared by the sensor data with respect to the shared clock signal. This enables the positioning data and mapping data to be synchronized before further processing. Additionally, the frequency of the data obtained from each sensor may be different. For example, the scanning sensor may be producing data in the range of hundreds of kHz, while the positioning sensor may be producing data in the range of hundreds of Hz. Accordingly, to ensure each point of the mapping data has corresponding positioning data,
upsampling module 310 can interpolate the lower frequency data to match the higher frequency data. For example, assuming the positioning data is produced by the positioning sensor at 100 Hz and the mapping data is produced by the scanning sensor (e.g., a LiDAR sensor) at 100 kHz, the positioning data may be upsampled from 100 Hz to 100 kHz. Various upsampling techniques may be used to upsample the positioning data. For example, a linear fit algorithm, such as least squares, may be used. In some embodiments, non-linear fit algorithms may be used to upsample the positioning data. Additionally, the roll, pitch, yaw values of the positioning data may also be interpolated to match the frequency of the mapping data. In some embodiments, the roll, pitch, and yaw values may be spherical linear interpolated (SLERP) to match the number of points in the mapping data. The time stamps may likewise be interpolated to match the interpolated positioning data. - Once the positioning data has been upsampled and synchronized with the mapping data by
upsampling module 310, geo-reference module 312 can convert the matrix representation of the mapping data from the frame of reference (or the reference coordinate system) in which it was collected (e.g., scanner reference frame or scanner reference coordinate system) to a desired frame of reference (or a desired reference coordinate system). For example, the positioning data may be converted from the scanner reference frame to a north-east-down (NED) reference frame (or a NED coordinate system). The reference frame to which the positioning data is converted may vary depending on the application of the map that is being produced. For example, if the map is being used in surveying, it may be converted to the NED reference frame. For another example, if the map is being used for rendering motions such as flight simulation, it may be converted to the FlightGear coordinate system. Other applications of the map may effect conversions of the positioning data to different reference frames or different coordinate systems. - Each point in the point cloud of the mapping data is associated with a position in the scanner reference frame that is determined relative to the scanning sensor. The positioning data of the movable object, produced by the positioning sensor, may then be used to convert this position in the scanner reference frame to the output reference frame in a world coordinate system, such as a GPS coordinate system. For example, the position of the scanning sensor in the world coordinate system is known based on the positioning data. In some embodiments, the positioning sensor and the scanning module may be offset (e.g., due to being located at different positions on the movable object). In such embodiments, a further correction factoring in this offset may be used to convert from the scanner reference frame to the output reference frame (e.g., each measured position in the positioning data may be corrected using the offset between the positioning sensor and the scanning sensor). For each point in the point cloud of the mapping data, the corresponding positioning data can be identified using the time stamp. The point can then be converted to the new reference frame. In some embodiments, the scanner reference frame can be converted into a horizontal reference frame using the interpolated roll, pitch, and yaw values from the positioning data. Once the mapping data has been converted into the horizontal reference frame, it may be further converted into a Cartesian frame or other output reference frame. Once each point has been converted, the result is a geo-referenced point cloud, with each point in the point cloud now referenced to the world coordinate system. In some embodiments, the geo-referenced point cloud can be provided to map
generator 316 before performing outlier removal to remove outlier data from the geo-referenced point cloud. - After the geo-referenced point cloud has been produced,
outlier removal module 314 can remove outlier data from the geo-referenced point cloud. In some embodiments, the geo-referenced point cloud may be downsampled, reducing the number of outliers in the data. Downsampling of this data may be performed using voxels. In some embodiments, the points in each voxel may be averaged, and one or more averaged points may be output per voxel. As such, outlier points will be removed from the data set in the course of averaging the points in each voxel. In various embodiments, the resolution of the voxels (e.g., the size of each voxel), may be arbitrarily defined. This allows for sparse and dense downsampled point clouds to be produced. The resolution may be determined by the user, or by the mapping manager based on, e.g., available computing resources, user preferences, default values, or other application-specific information. For example, a lower resolution (e.g., larger voxel size) may be used to produce a sparse downsampled point cloud for visualization on a client device or a mobile device. Additionally, or alternatively, outliers may be removed statistically. For example, the distance from each point to its nearest neighbor may be determined and statistically analyzed. If the distance from a point to its nearest neighbor is greater than a threshold value (e.g., a standard deviation of the nearest neighbor distances in the point cloud), then that point may be removed from the point cloud. In some embodiments, the outlier removal technique may be selectable by the user or be automatically selected by the mapping manager. In some embodiments, outlier removal may be disabled. - As discussed, the point cloud data may be a three-dimensional representation of the target environment. This 3D representation can be divided into voxels (e.g., 3D pixels).
- After statistical outlier removal, the resulting point cloud data can be provided to map
generator 316. In some embodiments, themap generator 316 may include a dense map generator 318 and/or asparse map generator 320. In such embodiments, dense map generator 318 can produce a high-density map from the point cloud data received before outlier removal, andsparse map generator 320 can produce a low-density map from the sparse downsampled point cloud data received after outlier removal. In other embodiments, dense map generator 318 andsparse map generator 320 may produce a high-density map and a low-density map separately from the point cloud received both after outlier removal. In such embodiments, each map generator may generate the output map using the same process but may vary the size of the voxels to produce high-density or low-density maps. In some embodiments, the low-density map can be used by a client device or a mobile device to provide real-time visualization of the mapping data. The high-density map can be output as a LIDAR Data Exchange File (LAS) or other file type to be used with various mapping, planning, analysis, or other tools. - The map generator may use the point cloud data to perform a probabilistic estimation of the position of points in the map. For example, the map generator may use a 3D mapping library, such as OctoMap to produce the output map. The map generator can divide the point cloud data into voxels. For each voxel, the map generator can determine how many points are in the voxel and, based on the number of points and the variance associated with each point, determine the probability that a point is in that voxel. The probability may be compared to an occupancy threshold and, if the probability is greater than the occupancy threshold, a point may be represented in that voxel in the output map. In some embodiments, the probability that a given voxel is occupied can be represented as:
-
- The probability P(n|z1:t) of a node n being occupied is a function of the current measurement z1, a prior probability P(n), and the previous estimate P(n|z1:t-1). Additionally, P(n|zt) represents the probability that voxel n is occupied given the measurement zt. This probability may be augmented to include the variance of each point, as measured by the positioning sensor, as represented by the following equations:
-
- In the equations above, P(n) represents the total probability that a voxel n is occupied. The use of ½ in the above equation is implementation specific, such that the probability is mapped to a range of ½-1. This range may vary, depending on the particular implementation in use. In the above equations, the total probability is the product of probabilities calculated for the x, y, and z dimensions. The probability in each dimension may be determined based on the mean, μ, for each point in that dimension, and the variance, σ2, of each measurement in a given dimension, with x, y, and z corresponding to the coordinate values of a given point. A large number of points near the mean point in a given voxel may increase the probability, while a more diffuse collection of points in the voxel may lower the probability. Likewise, a large variance associated with the data (e.g., indicating lower accuracy position data has been collected) may lower the probability while a lower variance may increase the probability. P(n, μ, σ2) represents the Gaussian distribution for the voxel, given the mean and variance values of the points in that voxel.
- If the total probability of a voxel being occupied is greater than a threshold occupancy value, then a point can be added to that voxel. In some embodiments, all of the points in that voxel can be averaged, and the resulting mean coordinate can be used as the location of the point in that voxel. This improves the accuracy of the resulting map over alternative methods, such as using the center point of an occupied voxel as the point, which may result in skewed results depending on the resolution of the voxels. In various embodiments, the occupancy threshold can be set based on the amount of processing resources available and/or based on the acceptable amount of noise in the data for a given application. For example, the occupancy threshold can be set to a default value of 70%. A higher threshold can be set to reduce noise. Additionally, the occupancy threshold may be set depending on the quality of the data being collected. For example, data collected under one set of conditions may be high quality (e.g., low variance) and a lower occupancy threshold can be set, while lower quality data may necessitate a higher occupancy threshold.
- The resulting map data, with one point in each occupied voxel, can then be output as an LAS file, or other file format. In some embodiments, the geo-referenced point cloud data may be output without additional processing (e.g., outlier removal). In some embodiments, each point in the point cloud data may also be associated with an intensity value. The intensity value may represent various features of the object being scanned, such as elevation above a reference plane, material composition, etc. The intensity value for each point in the output map may be an average of the intensity values measured for each point in the mapping data collected by the scanning sensor (e.g., a LiDAR sensor).
-
FIGS. 4A and 4B illustrate an example of a hierarchical data structure, in accordance with various embodiments. As discussed above, and as shown inFIG. 4A , data representing a3D environment 400 can be divided into a plurality of voxels. As shown inFIG. 4A , the target environment can be divided into eight voxels, with each voxel being further divided into eight sub-voxels, and each sub-voxel divided into eight further smaller sub-voxels. Each voxel may represent a different volumetric portion of the 3D environment. The voxels may be subdivided until a smallest voxel size is reached. The resulting 3D environment can be represented as ahierarchical data structure 402, where the root of the data structure represents the entire 3D environment, and each child node represents a different voxel in different hierarchy within the 3D environment. -
FIGS. 5A and 5B illustrate an example of outlier removal in mapping data, in accordance with various embodiments. As shown inFIG. 5A , when a target object is scanned, it may be represented as a plurality of points, with those points clustered on different parts of the object, including surfaces (such as surface 501), edges (such as edge 503), and other portions of the target object in the target environment. For simplicity of depiction, these surfaces, edges, etc. are shown solid. Invarious regions 500A-500F of the data, there are additional outlier points. This may be most noticeable in regions of empty space, as shown inFIG. 5A . These points are diffuse, as compared to the more densely packed points of the surfaces and edges of the target object. Outlier removal may be used to eliminate or reduce the number of these points in the data. As discussed above, the geo-referenced point cloud data may be downsampled, reducing the number of outliers in the data. Additionally, or alternatively, outliers may be removed statistically. For example, the distance from each point to its nearest neighbor may be determined and statistically analyzed. If the distance from a point to its nearest neighbor is greater than a threshold value (e.g., a standard deviation of the nearest neighbor distances in the point cloud), then that point may be removed from the point cloud. As shown inFIG. 5B , following outlier removal, the regions of thepoint cloud data 502A-502F have been reduced, providing a cleaner 3D map. -
FIG. 6 illustrates an example 600 of intensity values in mapping data, in accordance with various embodiments. As shown inFIG. 6 , one example of intensity values may be to represent elevation above a reference plane. In this example, different elevation ranges may be assigned a different intensity value 602-606, as depicted here using greyscale coloration. In various embodiments, intensity may be represented using different colors to represent different values or ranges of values. Additionally, intensity may be used to represent different materials being scanned. For example, steel and concrete will absorb and reflect the incident radiation produced by the scanning sensor differently, enabling the scanning sensor to identify different materials in use. Each material may be encoded as a different intensity value associated with each point and represented by a different color in the output map. Additionally, although the example shown inFIG. 6 shows three greyscale colors representing different elevation ranges, in various embodiments, continuous gradients of colors may be used to represent continuous changes in elevation value above a reference plane. -
FIG. 7 illustrates an example of supporting a movable object interface in a software development environment, in accordance with various embodiments. As shown inFIG. 7 , amovable object interface 703 can be used for providing access to amovable object 701 in asoftware development environment 700, such as a software development kit (SDK) environment. In some embodiments, themovable object interface 703, may render a real-time map generated by the mapping manager and other interfacing components for receiving user input. The real-time map may be rendered on a display of a client device or other computing device in communication with the movable object. As used herein, the SDK can be an onboard SDK implemented on an onboard environment that is coupled to themovable object 701. The SDK can also be a mobile SDK implemented on an off-board environment that is coupled to a client device or a mobile device. As discussed above, the mapping manager can be implemented using an onboard SDK coupled to themovable object 701 or a mobile SDK coupled to a client device or a mobile device to enable applications to perform real-time mapping, as described herein. - Furthermore, the
movable object 701 can include various functional modules A-C 711-713, and themovable object interface 703 can include different interfacing components A-C 731-733. Each said interfacing component A-C 731-733 in themovable object interface 703 corresponds to a module A-C 711-713 in themovable object 701. In some embodiments, the interfacing components may be rendered on a user interface of a display of a client device or other computing device in communication with the movable object. In such an example, the interfacing components, as rendered, may include selectable command buttons for receiving user input/instructions to control corresponding functional modules of the movable object. - In accordance with various embodiments, the
movable object interface 703 can provide one or more callback functions for supporting a distributed computing model between the application andmovable object 701. - The callback functions can be used by an application for confirming whether the
movable object 701 has received the commands. Also, the callback functions can be used by an application for receiving the execution results. Thus, the application and themovable object 701 can interact even though they are separated in space and in logic. - As shown in
FIG. 7 , the interfacing components A-C 731-733 can be associated with the listeners A-C 741-743. A listener A-C 741-743 can inform an interfacing component A-C 731-733 to use a corresponding callback function to receive information from the related module(s). - Additionally, a
data manager 702, which preparesdata 720 for themovable object interface 703, can decouple and package the related functionalities of themovable object 701. Thedata manager 702 may be onboard, that is coupled to or located on themovable object 701, which prepares thedata 720 to be communicated to themovable object interface 703 via communication between themovable object 701 and a client device or a mobile device. Thedata manager 702 may be off board, that is coupled to or located on a client device or a mobile device, which preparesdata 720 for themovable object interface 703 via communication within the client device or the mobile device. Also, thedata manager 702 can be used for managing the data exchange between the applications and themovable object 701. Thus, the application developer does not need to be involved in the complex data exchanging process. In some embodiments,mapping manager 126 may be one implementation ofdata manager 702. In such an embodiment, the mapping manager is used for managing mapping data, including generating a map using mapping data and positioning data and rendering the generated map for display based on a default setting or a user selection. - For example, the onboard or mobile SDK can provide a series of callback functions for communicating instant messages and for receiving the execution results from a movable object. The onboard or mobile SDK can configure the life cycle for the callback functions in order to make sure that the information interchange is stable and completed. For example, the onboard or mobile SDK can establish connection between a movable object and an application on a smart phone (e.g. using an Android system or an iOS system). Following the life cycle of a smart phone system, the callback functions, such as the ones receiving information from the movable object, can take advantage of the patterns in the smart phone system and update the statements accordingly to the different stages in the life cycle of the smart phone system.
-
FIG. 8 illustrates an example of a movable object interface, in accordance with various embodiments. As shown inFIG. 8 , amovable object interface 803 can be rendered on a display of a client device or other computing devices representing statuses of different components of amovable object 801. Thus, the applications, e.g., APPs 804-806, in themovable object environment 800 can access and control themovable object 801 via themovable object interface 803. As discussed, these apps may include aninspection app 804, aviewing app 805, and acalibration app 806. - For example, the
movable object 801 can include various modules, such as acamera 811, abattery 812, agimbal 813, and aflight controller 814. - Correspondently, the
movable object interface 803 can include acamera component 821, abattery component 822, agimbal component 823, and aflight controller component 824 to be rendered on a computing device or other computing devices to receive user input/instructions by way of using the APPs 804-806. - Additionally, the
movable object interface 803 can include aground station component 826, which is associated with theflight controller component 824. The ground station component operates to perform one or more flight control operations, which may require a high-level privilege. -
FIG. 9 illustrates an example of components for a movable object in a software development kit (SDK), in accordance with various embodiments. TheSDK 900 may be an onboard SDK implemented on an onboard mapping manager or a mobile SDK implemented on mapping manager located on a client device or a mobile device. TheSDK 900 may correspond to all or a portion of the mapping manager described above or may be used to implement the mapping manager as a standalone application. As shown inFIG. 9 , thedrone class 901 in theSDK 900 is an aggregation of other components 902-907 for a movable object (e.g., a drone). Thedrone class 901, which have access to the other components 902-907, can exchange information with the other components 902-907 and controls the other components 902-907. - In accordance with various embodiments, an application may be accessible to only one instance of the
drone class 901. Alternatively, multiple instances of thedrone class 901 can present in an application. - In the SDK, an application can connect to the instance of the
drone class 901 in order to upload the controlling commands to the movable object. For example, the SDK may include a function for establishing the connection to the movable object. Also, the SDK can disconnect the connection to the movable object using an end connection function. After connecting to the movable object, the developer can have access to the other classes (e.g. thecamera class 902, thebattery class 903, thegimbal class 904, and the flight controller class 905). Then, thedrone class 901 can be used for invoking the specific functions, e.g. providing access data which can be used by the flight controller to control the behavior, and/or limit the movement, of the movable object. - In accordance with various embodiments, an application can use a
battery class 903 for controlling the power source of a movable object. Also, the application can use thebattery class 903 for planning and testing the schedule for various flight tasks. As battery is one of the most restricted elements in a movable object, the application may seriously consider the status of battery not only for the safety of the movable object but also for making sure that the movable object can finish the designated tasks. For example, thebattery class 903 can be configured such that if the battery level is low, the movable object can terminate the tasks and go home outright. For example, if the movable object is determined to have a battery level that is below a threshold level, the battery class may cause the movable object to enter a power savings mode. In power savings mode, the battery class may shut off, or reduce, power available to various components that are not integral to safely returning the movable object to its home. For example, cameras that are not used for navigation and other accessories may lose power, to increase the amount of power available to the flight controller, motors, navigation system, and any other systems needed to return the movable object home, make a safe landing, etc. - Using the SDK, the application can obtain the current status and information of the battery by invoking a function to request information from in the Drone Battery Class. In some embodiments, the SDK can include a function for controlling the frequency of such feedback.
- In accordance with various embodiments, an application can use a
camera class 902 for defining various operations on the camera in a movable object, such as an unmanned aircraft. For example, in SDK, the Camera Class includes functions for receiving media data in SD card, getting & setting photo parameters, taking photo and recording videos. - An application can use the
camera class 902 for modifying the setting of photos and records. For example, the SDK may include a function that enables the developer to adjust the size of photos taken. Also, an application can use a media class for maintaining the photos and records. - In accordance with various embodiments, an application can use a
gimbal class 904 for controlling the view of the movable object. For example, the Gimbal Class can be used for configuring an actual view, e.g. setting a first personal view of the movable object. Also, the Gimbal Class can be used for automatically stabilizing the gimbal, in order to be focused on one direction. Also, the application can use the Gimbal Class to change the angle of view for detecting different objects. - In accordance with various embodiments, an application can use a
flight controller class 905 for providing various flight control information and status about the movable object. As discussed, the flight controller class can include functions for receiving and/or requesting access data to be used to control the movement of the movable object across various regions in a movable object environment. - Using the Flight Controller Class, an application can monitor the flight status, e.g. using instant messages. For example, the callback function in the Flight Controller Class can send back the instant message every one thousand milliseconds (1000 ms).
- Furthermore, the Flight Controller Class allows a user of the application to investigate the instant message received from the movable object. For example, the pilots can analyze the data for each flight in order to further improve their flying skills.
- In accordance with various embodiments, an application can use a
ground station class 907 to perform a series of operations for controlling the movable object. - For example, the SDK may require applications to have an SDK-LEVEL-2 key for using the Ground Station Class. The Ground Station Class can provide one-key-fly, on-key-go-home, manually controlling the drone by app (i.e. joystick mode), setting up a cruise and/or waypoints, and various other task scheduling functionalities.
- In accordance with various embodiments, an application can use a communication component for establishing the network connection between the application and the movable object.
-
FIG. 10 shows a flowchart of a method of target mapping in a movable object environment, in accordance with various embodiments. At operation/step 1002, mapping data can be obtained from a scanning sensor (e.g., a LiDAR sensor) supported by a movable object (e.g., a UAV). In some embodiments, the scanning sensor can be a LiDAR sensor. At operation/step 1004, positioning data can be obtained from a positioning sensor (e.g., a GPS sensor, an RTK sensor, an IMU sensor, and/or other positioning sensors or a combination thereof) supported by the movable object (e.g., a UAV). In some embodiments, the positioning sensor can be an RTK sensor or an IMU sensor. - At operation/
step 1006, the mapping data can be associated with the positioning data based at least on time data associated with the mapping data and the positioning data. In some embodiments, associating the mapping data with the positioning data may include upsampling the positioning data to include a number of positions equal to a number of points in the mapping data, and associating each point in the mapping data with a corresponding position in the upsampled positioning data. In some embodiments, the time data associated with the mapping data and the positioning data may be obtained using clock circuitry providing a reference clock signal electronically coupled to the scanning sensor and the positioning sensor. - At operation/
step 1008, a map in a first coordinate system may be generated based at least on the associated mapping data and positioning data. In some embodiments, generating the map may include, for each voxel of a plurality of voxels of the map, determining one or more points from the mapping data to be located in the voxel, and determining an occupancy probability for the voxel based at least on a number of points in that voxel. In some embodiments, the occupancy probability is determined based on a variance of the positioning data associated with the one or more points located in the voxel. In some embodiments, for each voxel having an occupancy probability greater than an occupancy probability threshold value, an average position of the one or more points in the voxel can be calculated, and a point can be generated in the map at the average position. In some embodiments, for each voxel having an occupancy probability greater than the occupancy probability threshold value, an average intensity value of the one or more points in the voxel can be calculated, and the average intensity value can be associated with the generated point in the map. In an embodiment, the average intensity value is calculated based on feature of each point in the voxel, where the feature of each point is associated with an elevation or a material detected by the scanning sensor. - In some embodiments, the method may further include determining a distribution of points in the mapping data, each of the points in the mapping data associated with a distance from a nearest neighboring point in the mapping data, and removing any points associated with a distance greater than a distance threshold value. In some embodiments, the method may further include downsampling the mapping data by a scaling factor, dividing the mapping data into a plurality of voxels, and outputting an average point from the downsampled mapping data for each of the plurality of voxels. In some embodiments, the method may further include transforming the map into a second coordinate system and outputting the transformed map. For example, the positioning data may be converted from the scanner reference frame to a north-east-down (NED) reference frame (or a NED coordinate system). The reference frame to which the positioning data is converted may vary depending on the application of the map that is being produced. For example, if the map is being used in surveying, it may be converted to the NED reference frame. For another example, if the map is being used for rendering motions such as flight simulation, it may be converted to the FlightGear coordinate system. Other applications of the map may effect conversions of the positioning data to different reference frames or different coordinate systems.
- In some embodiments, geo-referencing as described above may be combined with scan matching, such as Simultaneous Localization and Mapping (SLAM) or LiDAR Odometry and Mapping (LOAM). Traditional methods make use of SLAM with or without inertial navigation input. For example, some methods inject IMU information with SLAM and sometimes inject odometry via GPS which provides an improved mapping algorithm. Unlike traditional methods, embodiments can perform direct geo-referencing as discussed above, and then a layer of SLAM or LOAM can be added on top of the geo-references. This provides a robust mapping algorithm as the geo-references serves as a floor on the quality of the resulting map.
- In some embodiments, geo-referencing as described above may be combined with normal distribution transformation (NDT). NDT is a LiDAR scan registration method which is in between a feature-based registration method (such as LOAM) and a point-based registration method (such as iterative closest point). The “features” of the world are described by multivariate Gaussian distributions defined in each voxel. A probability density function (PDF) is generated for each cell and points are matched to the map by maximizing the sum of probability generated by the PDF, points x, and a transformation T:
-
- As discussed, in various embodiments, a movable object may be used for performing real-time mapping of various application environments, such as construction site mapping, surveying, target object mapping, etc. In some embodiments, the movable object may be an unmanned aerial vehicle (UAV), such as shown in
FIG. 11 , which has been configured to perform real-time mapping.FIG. 11 shows anisometric view 1100 of a movable object for performing real-time mapping, in accordance with an embodiment. As discussed above, a UAV in various embodiments may include amain body 1110. The main body may include, or be coupled to, a sensing system, a communications system, movement mechanisms, such asmotors 1112 which may independently power rotors (not shown) to cause the UAV to fly and navigate a predefined route and/or a route based on real time user commands, and other systems and functional modules as discussed above. - As shown in
FIG. 11 , a UAV configured to perform real-time mapping may include a payload assembly (or a sensor assembly) 1102, which may include a scanning sensor and a positioning sensor (as discussed above), and a mountingassembly 1104 to connect the payload assembly to the movable object body. In some embodiments, the UAV may further include alanding gear assembly 1106 designed to provide a secure platform when not in flight and during landing/takeoff, while not interfering with the field of view (FOV) of the scanning sensor ofpayload assembly 1102. In some embodiments, theangle 1108 of the landing gear may be based on the FOV of the scanning sensor in use. This may include fixed landing gear, such as shown inFIG. 11 , and adjustable landing gear, which may change theangle 1108 of the landing gear dynamically, based on the sensor in use. -
FIG. 12 shows arear view 1200 of a movable object (e.g., a UAV) for performing real-time mapping, in accordance with an embodiment. As shown inFIG. 12 , amain body 1202 can be coupled to the mountingassembly 1104. In some embodiments, the mounting assembly can includeexpansion brackets 1204 which are coupled to themain body 1202 using one or more fasteners, and which provide clearance for various components of the movable object, such as batteries,onboard computing device 1206, and other components. The mounting assembly may further include abase plate 1208 coupled to the expansion brackets using a plurality ofdampers 1210. In some embodiments, thepayload assembly 1102 including a LiDAR/global navigation satellite service (GNSS) IMU system is secured to the underside of the movable object via the mounting assembly using a plurality of mounting points of thebase plate 1208. Vibration isolation is provided to the LiDAR/GNSS IMU system via thebase plate 1208 resting on the plurality ofdampers 1210. - As shown in
FIG. 12 ,base plate 1208 may include dovetail mounts 1212. In various embodiments, the dovetail mounts 1212 enable the user to slide the payload assembly 1102 (e.g., including a LiDAR/GNSS IMU system) in position and secure with two fasteners, such as M4 wingnuts or other suitable fasteners. This enables the payload assembly, including the LiDAR/GNSS IMU system to be easily removed from the movable object via the mounting assembly. In some embodiments, theangle 1216 of the landing gear legs from the movable object may be adjustable, depending on the size of the payload, batteries, or other components and/or based on the FOV of the scanning sensor or other sensors included in the payload. -
FIG. 13 shows an isometric explodedview 1300 of the mounting assembly and payload assembly, in accordance with an embodiment. As shown inFIG. 13 , mountingassembly 1104 may includebase plate 1208 which is coupled to theexpansion brackets 1204 at a plurality oflocations 1304. For example, as shown inFIG. 13 , the lower end of each expansion bracket (e.g., the end closest to the payload assembly) may include a hole which aligns with a corresponding hole on thebase plate 1208. Each location may include a damper that, when assembled, is under compression between thebase plate 1208 and theexpansion brackets 1204. Each damper may be made of a compressible material, such as a natural or synthetic rubber, thermoplastic elastomer, or other shock absorbing material. The dampers may be secured between thebase plate 1208 and theexpansion brackets 1204 at the plurality of locations. For example, each damper may include flared ends. A lower flared end may be forced through a hole in anexpansion bracket 1204 and an upper flared end may be forced through a hole in thebase plate 1208. Such an arrangement couples thebase plate 1208 to theexpansion brackets 1204 using the plurality of dampers. In the example shown inFIG. 13 , there may be six dampers coupling thebase plate 1208 to theexpansion brackets 1204, three on either side of thebase plate 1208. However, thebase plate 1208 may be coupled to theexpansion brackets 1204 at more or fewer locations, in accordance with various embodiments. - The
base plate 1208 may further include a plurality ofholes 1306 which line up withholes 1308 of the payload assembly when assembled via the dovetails. A fastener may be inserted through the aligned holes to secure the payload assembly to thebase plate 1208. As shown inFIG. 13 , the payload assembly may include twopayload support brackets 1302. Each payload support bracket may include a dovetail which enables the payload support bracket to be connected to the dovetail groove in thebase plate 1208. Alternatively, in some embodiments, thebase plate 1208 may include a dovetail that can be inserted into a dovetail groove in eachpayload support bracket 1302. The payload assembly may further include apivot bracket 1312. The pivot bracket can be connected to scanning sensor 1310 (such as a LiDAR sensor) using one or more fasteners. The pivot bracket may include one ormore pivot arms 1314 which can be connected to thepayload support brackets 1302. For example, in the embodiment ofFIG. 13 , the pivot bracket includes twopivot arms 1314. Ahole 1316 in each pivot arm can be aligned with ahole 1318 in eachpayload support bracket 1302 to secure thescanning sensor 1310 at a particular scanning angle. In various embodiments, the payload support bracket can be secured to the pivot bracket using any suitable fastener which is removable such that the pivot bracket can be pivoted to another scanning angle (e.g., aligned with a different hole in the payload support bracket) and then recoupled to change the scanning angle of thescanning sensor 1310. - As shown in
FIG. 13 , the dovetail design on the pivot bracket enables the LiDAR/GNSS IMU system to be quickly removed. Thepivot bracket 1312 may further include at least onemounting point 1319 to which a positioning sensor 1320 (e.g., a GNSS IMU system, an RTK system, an RTK/IMU system, etc.) can be attached. By mounting thepivot bracket 1312 to thescanning sensor 1310 on one side of thepivot bracket 1312 and thepositioning sensor 1320 on the other side of thepivot bracket 1312, any relative motion between the two sensors is eliminated or greatly reduced. Thepositioning sensor 1320 can be bolted, screwed, epoxied, or be otherwise fixedly coupled to thepivot bracket 1312. In some embodiments, thepositioning sensor 1320 may be permanently coupled to thepivot bracket 1312 or may be removably coupled to thepivot bracket 1312. Thepositioning sensor 1320 may be protected from the elements and/or electromagnetic interference using apositioning sensor enclosure 1322 which may be coupled to thepivot bracket 1312. Thepositioning sensor enclosure 1322 provides ingress protection (IP) for the electronics from foreign debris and moisture. In some embodiments, theenclosure 1322 is sprayed with a thin layer of paint or other substance to protect the GNSS IMU from jamming caused by electromagnetic interference. This may include copper paint, or other material suitable to preventing jamming due to electromagnetic interference. - Additionally, in some embodiments, an onboard computing device 1206 (such as
computing device 112 described above) may be coupled to thebase plate 1208 using acomputing device bracket 1324. In some embodiments,expansion brackets 1204 can be stabilized usingalignment brackets 1326. These can ensure that theexpansion brackets 1204 remain parallel while in flight and eliminate or reduce undesirable twisting of the mounting assembly which might affect the reliability of the sensor data, such as mapping data and positioning data, collected by the scanning sensor and positioning sensor. -
FIG. 14 shows anisometric view 1400 ofbase plate 1208, in accordance with some embodiments.Base plate 1208 can include the plurality of mountinglocations 1402 at which the dampers may be used to couple the base plate to the expansion brackets, as discussed above. Additionally, mountingholes 1306 may be located above thedovetail grooves 1404, with the holes penetrating from the surface of thebase plate 1208 to thedovetail grooves 1404, allowing them to be aligned with holes of the payload support interface as discussed above. -
FIG. 15 shows an isometric assembledview 1500 of the mounting assembly and payload assembly, in accordance with an embodiment. As shown inFIG. 15 , the dovetails ofpayload support brackets 1302 are inserted into the dovetail grooves ofbase plate 1208.Positioning sensor enclosure 1322 is in place covering the positioning sensor and coupled to the pivot bracket. In the embodiment ofFIG. 15 , the pivot arms are aligned with an intermediate hole of thepayload support brackets 1302, causing the scanning sensor to be set at an angle between 90 degrees and 0 degrees, such as 35 degrees relative to thebase plate 1208 or a horizontal plane when a UAV (e.g., as shown above with respect toFIG. 11 ) is in its landing pose. Theexpansion brackets 1204 andalignment brackets 1326 can be coupled to a UAV (e.g., as shown above with respect toFIG. 11 ), to secure the mounting assembly to the UAV for mapping missions, as discussed above. -
FIGS. 16A-16D show additional views 1600-1606 of the payload assembly in accordance with various embodiments. As shown inFIG. 16A at 1600, thepivot bracket 1312 may include a plurality of mountingpoints 1608 to which the positioning sensor may be coupled. As shown inFIG. 16B at 1602, the positioning sensor can be mounted to the plurality of mountingpoints 1608 by aligning a plurality of mountingholes 1610 in thepositioning sensor 1320 and securing thepositioning sensor 1320 to the mountingpoints 1608 using fasteners, such as screws or other suitable fasteners. As shown inFIG. 16C , at 1604, thepayload support brackets 1302 can be coupled to the pivot brackets atpivot arms 1314. As discussed, the pivot arms can be aligned to corresponding holes on the payload support brackets to secure thescanning sensor 1310 at a predefined scanning angle. In some embodiments, thepayload support brackets 1302 may include grooves to which thepivot arms 1304 may be coupled, enabling a selection of a range of angles rather than particular angles predefined by the hole placements in the payload support brackets. As shown inFIG. 16D , at 1606, thepositioning sensor enclosure 1322 can be secured to the pivot bracket to protect the positioning sensor from debris, electromagnetic interference, and/or other environmental hazards. As discussed, the assembled payload assembly may be connected to the base plate of the mounting assembly using dovetails and coupled to the base plate by aligningholes 1308 with corresponding holes in the base plate and securing with a suitable fastener. -
FIG. 17 shows analternative enclosure 1700 to prevent jamming of the positioning sensor of a movable object in accordance with various embodiments. In order to prevent the GNSS-IMU from jamming due to electromagnetic inference, an aluminum enclosure can be added which serves as a Faraday cage with its various circular cutouts. The size and locations of the circular cutouts may be selected for the frequency or frequencies of electromagnetic interference that are expected and/or those frequencies most likely to interfere with the functioning of the IMU. -
FIGS. 18A and 18B show example alignments of lower expansion brackets in accordance with various embodiments. As shown at 1800 and 1802, analignment bracket 1326 can provide alignment of the expansion brackets such that the expansion brackets remain in parallel to one another. Absent the alignment brackets, the expansion brackets may freely rotate in place after installation on the movable object. Thus, there is a need to constrain the expansion brackets such that the back planes of the brackets remain parallel. In some embodiments, the alignment bracket may include a square (or other shaped)extension 1804. This may be inserted into correspondingly shapedholes 1806 in theexpansion brackets 1204. -
FIG. 19 shows an example 1900 of thealignment bracket 1326 being connected to themovable object body 1202 and theexpansion brackets 1204, in accordance with an embodiment. In some embodiments, two threaded screw holes can be used: a first for alignment and a second for mounting on the movable object. For example,movable object body 1202 may includeholes 1902 through which a screw may be inserted and screwed into a first threaded screw hole ofalignment bracket 1326.Alignment bracket 1326 may further include a second threadedscrew hole 1904 which may be aligned with ahole 1906 inexpansion brackets 1204, as shown inFIG. 19 . -
FIG. 20 shows an alternative 2000 mechanical attachment of the payload assembly (including a scanning sensor and a positioning sensor, as discussed above) to a movable object via a mounting assembly, in accordance with various embodiments.Plate 2002 is fastened to the underside of the movable object directly or indirectly via the mounting assembly, andplate 2004 can be fastened to the payload assembly. The two plates can be coupled using a plurality ofdampers 2006 which are under compression when assembled. A fastener (such as a wingnut or other suitable fastener) can be attached into the bottom of therod piece 2008 inserted throughplates hole 2010 in acrossbar 2012 connecting thepayload support brackets 1302, making the payload assembly easily removable. In some embodiments,plate 2002 may be coupled to the base plate of the mounting assembly described above or may be used to replace the base plate of the mounting assembly. In other embodiments,plate 2002 may be coupled directly to the main body of a movable object (e.g., an UAV). - In some embodiments, a mirror or a plate with a reflective coating material may be installed on the scanning sensor (such as the LiDAR sensor) via the fastener, at a certain angle that overlaps with at least a portion of the FOV of the scanning sensor in use. By way of applying the mirror or the plate with the reflective coating material, the FOV of the scanning sensor may be broadened to include a second FOV that is created by laser lights illuminated from the scanning sensor that are being reflected by the mirror or the plate with the reflective coating material.
-
FIGS. 21-23 show an alternative mechanical attachment of the LiDAR and positioning sensor to a movable object in accordance with various embodiments. As shown inFIG. 21 , the alternative mechanical attachment shown at 2100 may include a payload assembly similar to that discussed above. The payload assembly may includepayload support brackets 2102 coupled by acrossbar 2104. A T-extrusion member 2106 can be fastened to an upper surface of the crossbar (e.g., the surface closest to the movable object). The T-extrusion member may be permanently coupled to the crossbar (e.g., welded, epoxied, or otherwise fixedly coupled) or fastened using one or more removable fasteners. Along axis 2108 of the T-extrusion member may be substantially orthogonal to along axis 2110 of a clearance slot inalternative base plate 2112.FIG. 22 shows analternative view 2200 of the mechanical attachment. To attach the payload assembly, the payload assembly can be rotated 90 degrees relative to thealternative base plate 2112 such that thelong axis 2108 of the T-extrusion member is aligned with thelong axis 2110 of the clearance slot and the T-extrusion member can be raised through the clearance slot. For example, as shown inFIG. 23 the T-extrusion member 2106 has been raised through the clearance slot of thealternative base plate 2112 and then the payload assembly has been rotated 90 degrees in the opposite direction. Once positioned as shown inFIG. 23 , the T-extrusion member can be secured to thetop pressure plate 2300 with fasteners (e.g., wingnuts or other suitable fasteners). Thetop pressure plate 2300 can be coupled to thealternative base plate 2112 using a plurality ofdampers 2302 to reduce the movement of the payload assembly relative to thealternative base plate 2112. -
FIG. 24 shows an example 2400 of a landing gear in accordance with various embodiments. As shown inFIG. 24 , thelanding gear legs 2402 may be angled 1108 based on the field of view (FOV) of thescanning sensor 1310. For example, in the embodiment ofFIG. 24 , thelanding gear legs 2402 may be at a fixed angle of 55 degrees (e.g., measured in the plane formed by the landing gear legs) to accommodate the FOV of the particular scanning sensor in use. Additionally, or alternatively, theangle 1108 of thelanding gear legs 2402 may be adjusted, manually or automatically, based on the FOV of the scanning sensor in use. In some embodiments, thelanding gear legs 2402 may be coupled to the movable object using alanding gear bracket 2404. The landing gear bracket can provide the fixedangle 1108 of thelanding gear legs 2402. The landing gear bracket can be connected to the movable object using connectingmember 2406. In some embodiments, the connectingmember 2406 and thelanding gear legs 2402 can be made of the same material. In some embodiments, the connecting member can connect to a landing gear mounting bracket of the movable object body via a quick release connection. -
FIG. 25 shows an example 2500 of alanding gear bracket 2404 in accordance with various embodiments. In some embodiments, thelanding gear bracket 2404 can secure thelanding gear legs 2402 as well as provide shock absorption for the landing gear legs. For example, to improve upon the landing gear performance from drops and other shocks, thelanding gear bracket 2404 may include a rubber (such as, SPE I synthetic elastomer) damper to fill the void at the location where the landing gear legs and connection member (such as carbon fiber tubes) intersect. This rubber damper helps to absorb and dissipate energy during an impulse force. -
FIG. 26 shows an example 2600 of an alternative landing gear mounting point in accordance with various embodiments. Amounting point 2602 can be used to attach landing gear legs on the movable object such that the landing gear remains outside the field of view of the scanning sensor. This design uses the space adjacent to themotor heat sinks 2604 to attach the landing gear to the movable object arms. Using this small area helps to improve the vertical alignment of landing legs. In some embodiments, a landing gear leg can be attached adjacent to each motor heat sink. For example, if the movable object is a quadcopter with four motors and corresponding heat sinks, then four landing gear mounting points can be provided with four landing gear legs. In some embodiments, at least three landing gear mounting points and associated landing gear legs may be provided regardless of the number of motors equipped on the movable object. -
FIGS. 27-29 show LiDAR fields of view in accordance with various embodiments. In the example 2700 shown inFIG. 27 , the LiDAR is positioned to scan at 35 degrees. The LiDAR's FOV is in between the twoplanes 2702. In this position the FOV of the LiDAR would intersect the traditional landing gear assembly 2704 (shown dashed to indicate where it would be located if it were provided). As shown, the traditionallanding gear assembly 2704 would partially obstruct the FOV of the scanning sensor. As such, to obtain a complete scan of an area would require additional scanning missions to be performed that account for the blind spots introduced by the traditional landing gear assembly. To address this, the angledlanding gear assembly 2706 can include angled legs, as discussed above. As discussed, the landing gear legs may be angled depending on the FOV of the scanning sensor in use. As shown inFIG. 27 , when so angled, the landing gear legs remain outside of LiDAR's field of view at the 35° position. This eliminates the obstructions caused by the traditional landing gear assembly, leading to more efficient scanning missions.FIGS. 28 and 29 show the LiDAR FOV at its 90° position. In the example 2800 ofFIG. 28 , the UAV is shown from the side view, with the LiDAR positioned to scan at 90 degrees. TheFOV 2802 of the LiDAR in this position is obstructed by the traditionallanding gear assembly 2704, similar to that discussed above with respect toFIG. 27 . However, the angledlanding gear assembly 2706 does not obstruct theFOV 2802 of the LiDAR in this position.FIG. 29 shows anisometric view 2900 of the UAV with the LiDAR in the 90-degree position. As discussed with respect toFIG. 28 , the angledlanding gear assembly 2706 does not obstruct theFOV 2802 in this position as the traditionallanding gear assembly 2704 would. -
FIGS. 30-32 show examples of angled positions of a scanning sensor coupled to a movable object, in accordance with various embodiments. In the example 3000 shown inFIG. 30 , theLiDAR 1310 can be positioned at 0 degrees relative to horizontal. As discussed above, this position can be achieved using thepivot bracket 1312 and thepayload support brackets 1302. In the example 3100 shown inFIG. 31 , theLiDAR 1310 can be positioned at 35 degrees relative to horizontal. This angle position may also be achieved using thepayload support brackets 1302 and thepivot bracket 1312, by aligning corresponding holes in the brackets for the 35-degree position. Similarly, the example 3200 shown inFIG. 32 shows theLiDAR 1310 positioned at 90 degrees relative to horizontal. As discussed above, this position may be achieved by changing the alignment of holes in thepivot bracket 1312 to corresponding holes in thepayload support bracket 1302. In some embodiments, rather than holes which provide predefined angular positions, thepayload support brackets 1302 may include slots, which enable the user to select various angular positions. -
FIG. 33 shows example 3300 scanning patterns that may be implemented by LiDAR sensors that may be used in various embodiments. A LiDAR system is an active sensing system that emits light beams and measures a two-way travel time (i.e. time-of-flight) for the reflected light detected by the LiDAR sensor. The collected sensor data may generally be used to measure a range or a distance to an object which has reflected the light emitted by the LiDAR. Further, the object's position in a three-dimensional space (e.g., recorded with x-, y-, and z-coordinates, or latitude, longitude, and elevation values, or other coordinate systems, etc.) may be determined using (1) the detected two-way travel time of the emitted light beam, (2) the scanning angle of the light beam in reference to the three-dimensional space, and/or (3) the absolute location of the LiDAR sensor detected using a GPS, GNSS, INS or IMU sensor, etc. - Different LiDAR sensors may be associated with different scan patterns, scan frequencies, and/or scan angles. The scan patterns of a LiDAR sensor can be virtually any waveform by way of utilizing different scanning mechanisms (e.g., using a constant-velocity rotating polygon mirror or an oscillating mirror). Some examples of scan patterns include parallel scan lines, which may be generated by a rotating polygon mirror, or sawtooth scan lines which may be generated by an oscillating mirror. Other examples may include a sinusoidal scan pattern 3302,
sawtooth scan pattern 3304,elliptical scan pattern 3306,spiral scan pattern 3308, or flowershape scan pattern 3310, or uniform scan pattern 3312 (which may be a series of concentric scans, such as circular, oval, or other scan shapes). - LiDAR data may be collected or recorded as discrete points or as a full waveform. Discrete points identify and record points at each peak location in the waveform curve. A full waveform records a distribution of returned energy and thus captures more information compared to discrete points. Whether collected as discrete points or full waveform, LiDAR data are available as discrete points, which is known as a LiDAR point cloud. LiDAR point cloud is usually stored as .las format (or .laz format, which is a highly compressed version of .las). Each lidar point data and its metadata may include various data attributes, such as associated coordinate values, an intensity value representing the amount of light energy recorded by the sensor, or classification data representing the type of object the laser return reflected off of (such as classified as ground or non-ground, as different altitudes, or as different material features), etc.
- Many features can be performed in, using, or with the assistance of hardware, software, firmware, or combinations thereof. Consequently, features may be implemented using a processing system (e.g., including one or more processors). Exemplary processors can include, without limitation, one or more general purpose microprocessors (for example, single or multi-core processors), application-specific integrated circuits, application-specific instruction-set processors, graphics processing units, physics processing units, digital signal processing units, coprocessors, network processing units, audio processing units, encryption processing units, and the like.
- Features can be implemented in, using, or with the assistance of a computer program product which is a storage medium (media) or computer readable medium (media) having instructions stored thereon/in which can be used to program a processing system to perform any of the features presented herein. The storage medium can include, but is not limited to, any type of disk including floppy disks, optical discs, DVD, CD-ROMs, microdrive, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, DRAMs, VRAMs, flash memory devices, magnetic or optical cards, nanosystems (including molecular memory ICs), or any type of media or device suitable for storing instructions and/or data.
- Stored on any one of the machine readable medium (media), features can be incorporated in software and/or firmware for controlling the hardware of a processing system, and for enabling a processing system to interact with other mechanism utilizing the results. Such software or firmware may include, but is not limited to, application code, device drivers, operating systems and execution environments/containers.
- Features of the invention may also be implemented in hardware using, for example, hardware components such as application specific integrated circuits (ASICs) and field-programmable gate array (FPGA) devices. Implementation of the hardware state machine so as to perform the functions described herein will be apparent to persons skilled in the relevant art.
- Additionally, the present invention may be conveniently implemented using one or more conventional general purpose or specialized digital computer, computing device, machine, or microprocessor, including one or more processors, memory and/or computer readable storage media programmed according to the teachings of the present disclosure. Appropriate software coding can readily be prepared by skilled programmers based on the teachings of the present disclosure, as will be apparent to those skilled in the software art.
- While various embodiments have been described above, it should be understood that they have been presented by way of example, and not limitation. It will be apparent to persons skilled in the relevant art that various changes in form and detail can be made therein without departing from the spirit and scope of the invention.
- The present invention has been described above with the aid of functional building blocks illustrating the performance of specified functions and relationships thereof. The boundaries of these functional building blocks have often been arbitrarily defined herein for the convenience of the description. Alternate boundaries can be defined so long as the specified functions and relationships thereof are appropriately performed. Any such alternate boundaries are thus within the scope and spirit of the invention.
- The foregoing description has been provided for the purposes of illustration and description. It is not intended to be exhaustive or to limit the invention to the precise forms disclosed. The breadth and scope should not be limited by any of the above-described exemplary embodiments. Many modifications and variations will be apparent to the practitioner skilled in the art. The modifications and variations include any relevant combination of the disclosed features. The embodiments were chosen and described in order to best explain the principles of the invention and its practical application, thereby enabling others skilled in the art to understand the invention for various embodiments and with various modifications that are suited to the particular use contemplated. It is intended that the scope of the invention be defined by the following claims and their equivalence.
- In the various embodiments described above, unless specifically noted otherwise, disjunctive language such as the phrase “at least one of A, B, or C,” is intended to be understood to mean either A, B, or C, or any combination thereof (e.g., A, B, and/or C). As such, disjunctive language is not intended to, nor should it be understood to, imply that a given embodiment requires at least one of A, at least one of B, or at least one of C to each be present.
Claims (20)
1. An unmanned aerial vehicle (UAV), comprising:
a propulsion system;
a main body coupled to the propulsion system; and
a payload assembly coupled to the main body via a mounting assembly, wherein the payload assembly includes a payload comprising a scanning sensor and a positioning sensor, the payload assembly configured to orient the scanning sensor at a plurality of angles relative to the main body.
2. The UAV of claim 1 , wherein the payload assembly comprises a plurality of payload support brackets configured to couple the payload assembly to the mounting assembly, the plurality of payload support brackets configured to provide the plurality of angles relative to the main body at which the payload can be oriented.
3. The UAV of claim 2 , wherein the payload assembly comprises a pivot bracket configured to couple the scanning sensor and the positioning sensor, the pivot bracket configured to be aligned with the plurality of angles provided by the plurality of payload support brackets for changing a scanning angle of the scanning sensor.
4. The UAV of claim 3 , wherein the scanning sensor is mounted to a side of the pivot bracket and the positioning sensor is mounted to another side of the pivot bracket.
5. The UAV of claim 1 , wherein the plurality of angles includes angles corresponding at least to angles of 0 degrees, 35 degrees, or 90 degrees relative to the main body.
6. The UAV of claim 2 , wherein the plurality of payload support brackets are connected to the mounting assembly using a dovetail quick release connection.
7. The UAV of claim 6 , wherein the plurality of payload support brackets are connected to a base plate of the mounting assembly, the base plate having a plurality of dovetail grooves.
8. The UAV of claim 7 , wherein the base plate is coupled to the mounting assembly using a plurality of dampers.
9. The UAV of claim 9 , wherein the landing gear bracket include compressible materials configured to absorb or dissipate energy of an impulse force when landing.
10. The UAV of claim 9 , wherein each landing gear assembly is coupled to the main body on an arm of the main body adjacent to a motor heat sink.
11. The UAV of claim 1 , wherein the mounting assembly comprises a dampened plate assembly configured to couple the payload assembly to the main body, the dampened plate assembly comprising a first plate coupled to the main body and a second plate coupled to the first plate via a plurality of dampers, wherein a fastener is inserted through the dampened plate assembly and the payload assembly.
12. The UAV of claim 18 , wherein a reflective member is coupled to the mounting assembly via the fastener, wherein the reflective member is positioned to overlap with at least a portion of a field of view (FOV) of the scanning sensor to cause the FOV of the scanning sensor to be broadened to include a second FOV comprising a reflection off of the reflective member.
13. The UAV of claim 19 , wherein the reflective member includes a mirror or a plate including a reflective coating.
14. The UAV of claim 1 , wherein the mounting assembly includes a plate assembly, the plate assembly comprising a first plate coupled to the main body via a plurality of expansion brackets and a second plate coupled to the first plate via a plurality of dampers, wherein a portion of the payload assembly is inserted through a portion of the first plate, and wherein the portion of the payload assembly is coupled to the second plate using a fastener.
15. The UAV of claim 21, wherein the plurality of expansion brackets includes at least two pairs of expansion brackets coupled to the main body, wherein each pair of expansion brackets are coupled to each other via an alignment bracket to maintain a parallel back plane of the pair of expansion brackets.
16. The UAV of claim 1 , wherein the scanning sensor is a light detection and ranging (LiDAR) sensor.
17. The UAV of claim 23, wherein the LiDAR sensor implements a scanning pattern, the scanning pattern including at least one of a spiral pattern or a flower pattern.
18. The UAV of claim 1 , wherein the scanning sensor is fixed at one of the plurality of angles during a scanning mission.
19. An unmanned aerial vehicle (UAV), comprising:
a propulsion system;
a main body coupled to the propulsion system;
a payload assembly coupled to the main body via a mounting assembly, wherein the payload assembly includes a payload comprising a scanning sensor and a positioning sensor, the payload assembly configured to orient the scanning sensor at a plurality of angles relative to the main body; and
at least two landing gear assemblies, each landing gear assembly including landing gear legs coupled to the main body using a landing gear bracket, wherein the landing gear bracket couples the landing gear legs at fixed angles to clear the landing gear legs from a field of view (FOV) of the scanning sensor.
20. An unmanned aerial vehicle (UAV), comprising:
a propulsion system;
a main body coupled to the propulsion system; and
a payload assembly coupled to the main body via a mounting assembly, wherein the payload assembly includes a payload comprising a scanning sensor coupled to a positioning sensor via a pivot bracket, the payload assembly configured to orient the scanning sensor at a plurality of angles relative to the main body using the pivot bracket, and wherein the payload assembly comprises a positioning sensor enclosure covering the positioning sensor, the positioning sensor enclosure mounted to a side of the pivot bracket mounting the positioning sensor that is opposite to another side of the pivot bracket mounting the scanning sensor.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US17/162,358 US20210341614A1 (en) | 2018-10-29 | 2021-01-29 | Movable object for performing real-time mapping |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201862752273P | 2018-10-29 | 2018-10-29 | |
PCT/US2019/058219 WO2020092179A1 (en) | 2018-10-29 | 2019-10-25 | A movable object for performing real-time mapping |
US17/162,358 US20210341614A1 (en) | 2018-10-29 | 2021-01-29 | Movable object for performing real-time mapping |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/US2019/058219 Continuation WO2020092179A1 (en) | 2018-10-29 | 2019-10-25 | A movable object for performing real-time mapping |
Publications (1)
Publication Number | Publication Date |
---|---|
US20210341614A1 true US20210341614A1 (en) | 2021-11-04 |
Family
ID=70326830
Family Applications (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/664,743 Active US10983201B2 (en) | 2018-10-29 | 2019-10-25 | User interface for displaying point clouds generated by a lidar device on a UAV |
US17/162,358 Abandoned US20210341614A1 (en) | 2018-10-29 | 2021-01-29 | Movable object for performing real-time mapping |
US17/211,509 Active US11698449B2 (en) | 2018-10-29 | 2021-03-24 | User interface for displaying point clouds generated by a LiDAR device on a UAV |
US17/229,409 Abandoned US20210241514A1 (en) | 2018-10-29 | 2021-04-13 | Techniques for real-time mapping in a movable object environment |
US17/231,860 Pending US20210239815A1 (en) | 2018-10-29 | 2021-04-15 | Movable object performing real-time mapping using a payload assembly |
US18/202,382 Pending US20230296745A1 (en) | 2018-10-29 | 2023-05-26 | User interface for displaying point clouds generated by a lidar device on a uav |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/664,743 Active US10983201B2 (en) | 2018-10-29 | 2019-10-25 | User interface for displaying point clouds generated by a lidar device on a UAV |
Family Applications After (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US17/211,509 Active US11698449B2 (en) | 2018-10-29 | 2021-03-24 | User interface for displaying point clouds generated by a LiDAR device on a UAV |
US17/229,409 Abandoned US20210241514A1 (en) | 2018-10-29 | 2021-04-13 | Techniques for real-time mapping in a movable object environment |
US17/231,860 Pending US20210239815A1 (en) | 2018-10-29 | 2021-04-15 | Movable object performing real-time mapping using a payload assembly |
US18/202,382 Pending US20230296745A1 (en) | 2018-10-29 | 2023-05-26 | User interface for displaying point clouds generated by a lidar device on a uav |
Country Status (5)
Country | Link |
---|---|
US (6) | US10983201B2 (en) |
EP (3) | EP3793899A4 (en) |
JP (1) | JP2022502784A (en) |
CN (3) | CN113015677A (en) |
WO (2) | WO2020092179A1 (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024203103A1 (en) * | 2023-03-30 | 2024-10-03 | ソニーグループ株式会社 | Information processing device, information processing method, and mobile body |
Families Citing this family (31)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US12123950B2 (en) | 2016-02-15 | 2024-10-22 | Red Creamery, LLC | Hybrid LADAR with co-planar scanning and imaging field-of-view |
KR102476404B1 (en) * | 2017-07-18 | 2022-12-12 | 엘지이노텍 주식회사 | Tof module and subject recogniging apparatus using the same |
CN107797129B (en) * | 2017-10-13 | 2020-06-05 | 重庆市勘测院 | Point cloud data acquisition method and device under no GNSS signal |
US10878589B2 (en) * | 2019-05-02 | 2020-12-29 | Samsung Electronics Co., Ltd. | Time-of-flight depth measurement using modulation frequency adjustment |
US10937202B2 (en) * | 2019-07-22 | 2021-03-02 | Scale AI, Inc. | Intensity data visualization |
US11556000B1 (en) | 2019-08-22 | 2023-01-17 | Red Creamery Llc | Distally-actuated scanning mirror |
WO2021124629A1 (en) * | 2019-12-17 | 2021-06-24 | 三菱電機株式会社 | Measurement vehicle, base station, and remote management system |
US20210247506A1 (en) * | 2020-02-12 | 2021-08-12 | Aptiv Technologies Limited | System and method of correcting orientation errors |
US10983681B1 (en) * | 2020-04-07 | 2021-04-20 | Gm Cruise Holdings Llc | Image identification system |
US11468609B2 (en) * | 2020-05-11 | 2022-10-11 | Cognex Corporation | Methods and apparatus for generating point cloud histograms |
CN116783619B (en) * | 2020-05-11 | 2024-10-29 | 康耐视公司 | Method and device for generating point cloud histogram |
CA3180630A1 (en) | 2020-05-29 | 2021-12-02 | Alexander Harvey | Methods and systems for construct identification and analysis |
DE102020206940A1 (en) | 2020-06-03 | 2021-12-09 | Robert Bosch Gesellschaft mit beschränkter Haftung | Method of rendering a view of a three-dimensional scene |
CN115699134A (en) * | 2020-06-27 | 2023-02-03 | 深圳市大疆创新科技有限公司 | Techniques for using compact payload mapping in a movable object environment |
JP7572663B2 (en) | 2020-07-31 | 2024-10-24 | 日本電気通信システム株式会社 | Operation plan generation device, learning device, operation plan generation method, learning method, and program |
JP7563921B2 (en) | 2020-09-01 | 2024-10-08 | 清水建設株式会社 | Information processing device, information processing method, and program |
WO2022077829A1 (en) * | 2020-10-12 | 2022-04-21 | SZ DJI Technology Co., Ltd. | Large scope point cloud data generation and optimization |
WO2022077218A1 (en) * | 2020-10-13 | 2022-04-21 | SZ DJI Technology Co., Ltd. | Online point cloud processing of lidar and camera data |
CN115243053B (en) | 2021-04-22 | 2024-04-16 | 腾讯科技(深圳)有限公司 | Point cloud encoding and decoding method and related equipment |
WO2023287829A1 (en) * | 2021-07-12 | 2023-01-19 | Cyngn, Inc. | Adaptive motion compensation of perception channels |
US20230184944A1 (en) * | 2021-12-09 | 2023-06-15 | Here Global B.V. | Method, apparatus, and system for location sharing using a lidar-based location signature |
CN114202586A (en) * | 2021-12-13 | 2022-03-18 | 哈尔滨工业大学芜湖机器人产业技术研究院 | 3D laser SLAM method and mobile robot based on octree chart and three-dimensional normal distribution optimization matching |
EP4455723A1 (en) * | 2021-12-23 | 2024-10-30 | Pioneer Corporation | Information processing device, control method, program, and storage medium |
US20230242250A1 (en) * | 2022-01-31 | 2023-08-03 | Skydio, Inc. | Aerial Vehicle Path Determination |
CN114777758B (en) * | 2022-03-21 | 2024-10-22 | 江苏盛海智能科技有限公司 | Initial position determining method and terminal based on laser radar map building positioning |
CN114967716B (en) * | 2022-04-02 | 2024-05-03 | 中国人民解放军海军航空大学 | Fixed wing aircraft attitude control method based on quaternion spherical linear interpolation |
CN115236688A (en) * | 2022-05-19 | 2022-10-25 | 北京申信达成科技有限公司 | Unmanned aerial vehicle laser radar measurement system based on 5G, beidou and GNSS |
CN115267815B (en) * | 2022-06-10 | 2024-06-14 | 合肥工业大学 | Road side laser radar group optimization layout method based on point cloud modeling |
US12131531B2 (en) * | 2022-06-23 | 2024-10-29 | Lockheed Martin Corporation | Real time light-detection and ranging point decimation |
US20230415891A1 (en) * | 2022-06-24 | 2023-12-28 | General Atomics Aeronautical Systems, Inc. | Relative navigation for aerial recovery of aircraft |
CN114815903A (en) * | 2022-06-29 | 2022-07-29 | 沃飞长空科技(成都)有限公司 | Flight route visual display method and device, aircraft and storage medium |
Family Cites Families (49)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN1062257A (en) | 1991-12-25 | 1992-06-24 | 郑钟豪 | Make the method for switch, potentiometer in the circuit board |
US5376759A (en) * | 1993-06-24 | 1994-12-27 | Northern Telecom Limited | Multiple layer printed circuit board |
US6665063B2 (en) * | 2001-09-04 | 2003-12-16 | Rosemount Aerospace Inc. | Distributed laser obstacle awareness system |
JP4650752B2 (en) * | 2005-12-16 | 2011-03-16 | 株式会社Ihi | Self-position identification method and apparatus and three-dimensional shape measurement method and apparatus |
US8087315B2 (en) * | 2006-10-10 | 2012-01-03 | Honeywell International Inc. | Methods and systems for attaching and detaching a payload device to and from, respectively, a gimbal system without requiring use of a mechanical tool |
FR2961601B1 (en) | 2010-06-22 | 2012-07-27 | Parrot | METHOD FOR EVALUATING THE HORIZONTAL SPEED OF A DRONE, IN PARTICULAR A DRONE SUITABLE FOR AUTOPILOT STATIONARY FLIGHT |
EP2511656A1 (en) | 2011-04-14 | 2012-10-17 | Hexagon Technology Center GmbH | Measuring system for determining the 3D coordinates of an object surface |
US9300980B2 (en) * | 2011-11-10 | 2016-03-29 | Luca Rossato | Upsampling and downsampling of motion maps and other auxiliary maps in a tiered signal quality hierarchy |
US9129524B2 (en) | 2012-03-29 | 2015-09-08 | Xerox Corporation | Method of determining parking lot occupancy from digital camera images |
US9157743B2 (en) | 2012-07-18 | 2015-10-13 | Honeywell International Inc. | Systems and methods for correlating reduced evidence grids |
US9046600B2 (en) * | 2012-12-05 | 2015-06-02 | Toyota Motor Engineering & Manufacturing North America, Inc. | Method and apparatus for intensity calibration of multi-beam lidar sensors |
WO2015051501A1 (en) * | 2013-10-08 | 2015-04-16 | SZ DJI Technology Co., Ltd | Apparatus and methods for stabilization and vibration reduction |
US9751639B2 (en) * | 2013-12-02 | 2017-09-05 | Field Of View Llc | System to control camera triggering and visualize aerial imaging missions |
CN103941748B (en) | 2014-04-29 | 2016-05-25 | 百度在线网络技术(北京)有限公司 | Autonomous navigation method and system and Map building method and system |
US9630710B2 (en) * | 2014-10-29 | 2017-04-25 | Qualcomm Incorporated | Unmanned aerial vehicle |
CN105518490A (en) * | 2014-12-04 | 2016-04-20 | 深圳市大疆创新科技有限公司 | Object detection method and device, remote control moving equipment, and aircraft |
US10163255B2 (en) * | 2015-01-07 | 2018-12-25 | Geopogo, Inc. | Three-dimensional geospatial visualization |
US9678199B2 (en) | 2015-01-30 | 2017-06-13 | Qualcomm Incorporated | Propulsion device lidar system and method |
CN204489196U (en) | 2015-02-12 | 2015-07-22 | 深圳大学 | The many rotor wing unmanned aerial vehicles of a kind of fuels and energy |
US9592908B2 (en) * | 2015-03-18 | 2017-03-14 | Amazon Technologies, Inc. | Adjustable landing gear assembly for unmanned aerial vehicles |
EP3078935A1 (en) | 2015-04-10 | 2016-10-12 | The European Atomic Energy Community (EURATOM), represented by the European Commission | Method and device for real-time mapping and localization |
CN104851127B (en) * | 2015-05-15 | 2017-07-04 | 北京理工大学深圳研究院 | It is a kind of based on interactive building point cloud model texture mapping method and device |
US20160349746A1 (en) * | 2015-05-29 | 2016-12-01 | Faro Technologies, Inc. | Unmanned aerial vehicle having a projector and being tracked by a laser tracker |
US10336451B2 (en) * | 2015-06-30 | 2019-07-02 | Gopro, Inc. | Coupling assembly for a removable propeller |
JP6268657B2 (en) * | 2015-07-02 | 2018-01-31 | エスゼット ディージェイアイ オスモ テクノロジー カンパニー リミテッドSZ DJI Osmo Technology Co., Ltd. | Support mechanism and system |
WO2017041304A1 (en) * | 2015-09-11 | 2017-03-16 | SZ DJI Technology Co., Ltd. | Carrier for unmanned aerial vehicle |
US10613546B2 (en) * | 2015-12-02 | 2020-04-07 | Qualcomm Incorporated | Stochastic map-aware stereo vision sensor model |
WO2017155970A1 (en) | 2016-03-11 | 2017-09-14 | Kaarta, Inc. | Laser scanner with real-time, online ego-motion estimation |
US9845161B2 (en) * | 2016-04-22 | 2017-12-19 | Sharper Shape Oy | System and method for calculating weight distribution of drone |
WO2017183001A1 (en) * | 2016-04-22 | 2017-10-26 | Turflynx, Lda. | Automated topographic mapping system" |
CN106022381B (en) * | 2016-05-25 | 2020-05-22 | 厦门大学 | Automatic extraction method of street lamp pole based on vehicle-mounted laser scanning point cloud |
US9996944B2 (en) | 2016-07-06 | 2018-06-12 | Qualcomm Incorporated | Systems and methods for mapping an environment |
CN106225790B (en) * | 2016-07-13 | 2018-11-02 | 百度在线网络技术(北京)有限公司 | A kind of determination method and device of unmanned vehicle positioning accuracy |
CN205931287U (en) * | 2016-08-04 | 2017-02-08 | 数字鹰(泰州)农业科技有限公司 | Unmanned aerial vehicle field of vision expanding unit of making a video recording |
US10066946B2 (en) | 2016-08-26 | 2018-09-04 | Here Global B.V. | Automatic localization geometry detection |
EP3306344A1 (en) | 2016-10-07 | 2018-04-11 | Leica Geosystems AG | Flying sensor |
CN106767820B (en) * | 2016-12-08 | 2017-11-14 | 立得空间信息技术股份有限公司 | A kind of indoor moving positioning and drafting method |
EP3500494A4 (en) * | 2016-12-12 | 2019-10-02 | SZ DJI Technology Co., Ltd. | Method and system for stabilizing a payload |
CN108227749A (en) | 2016-12-14 | 2018-06-29 | 昊翔电能运动科技(昆山)有限公司 | Unmanned plane and its tracing system |
US10445928B2 (en) * | 2017-02-11 | 2019-10-15 | Vayavision Ltd. | Method and system for generating multidimensional maps of a scene using a plurality of sensors of various types |
CN115649439A (en) | 2017-02-24 | 2023-01-31 | 深圳市大疆创新科技有限公司 | Many cloud platforms subassembly |
CA3054667A1 (en) * | 2017-02-26 | 2018-08-30 | Yougetitback Limited | System and method for detection of mobile device fault conditions |
DE112018000899T5 (en) * | 2017-03-17 | 2019-10-31 | Honda Motor Co., Ltd. | Joint 3D object detection and orientation estimation via multimodal fusion |
EP3594922A4 (en) | 2017-03-29 | 2021-03-31 | Pioneer Corporation | Server device, terminal device, communication system, information receiving method, information sending method, program for receiving information, program for sending information, recording medium, and data structure |
CN107640327A (en) | 2017-05-03 | 2018-01-30 | 天宇科技有限公司 | Unmanned plane and the device for including the unmanned plane |
CN107301654B (en) * | 2017-06-12 | 2020-04-03 | 西北工业大学 | Multi-sensor high-precision instant positioning and mapping method |
CN110891862B (en) * | 2017-08-10 | 2023-07-11 | 深圳零零无限科技有限公司 | System and method for obstacle avoidance in a flight system |
CN108181636B (en) * | 2018-01-12 | 2020-02-18 | 中国矿业大学 | Environment modeling and map building device and method for petrochemical plant inspection robot |
US10649459B2 (en) | 2018-04-26 | 2020-05-12 | Zoox, Inc. | Data segmentation using masks |
-
2019
- 2019-10-25 EP EP19880137.5A patent/EP3793899A4/en not_active Withdrawn
- 2019-10-25 CN CN201980071156.XA patent/CN113015677A/en active Pending
- 2019-10-25 CN CN201980071644.0A patent/CN112955713A/en active Pending
- 2019-10-25 WO PCT/US2019/058219 patent/WO2020092179A1/en unknown
- 2019-10-25 JP JP2021517992A patent/JP2022502784A/en not_active Abandoned
- 2019-10-25 EP EP19879548.6A patent/EP3803273A4/en not_active Withdrawn
- 2019-10-25 WO PCT/US2019/058218 patent/WO2020092178A1/en unknown
- 2019-10-25 US US16/664,743 patent/US10983201B2/en active Active
- 2019-10-28 EP EP19879446.3A patent/EP3735626A1/en not_active Withdrawn
- 2019-10-28 CN CN201980071197.9A patent/CN113196197A/en active Pending
-
2021
- 2021-01-29 US US17/162,358 patent/US20210341614A1/en not_active Abandoned
- 2021-03-24 US US17/211,509 patent/US11698449B2/en active Active
- 2021-04-13 US US17/229,409 patent/US20210241514A1/en not_active Abandoned
- 2021-04-15 US US17/231,860 patent/US20210239815A1/en active Pending
-
2023
- 2023-05-26 US US18/202,382 patent/US20230296745A1/en active Pending
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2024203103A1 (en) * | 2023-03-30 | 2024-10-03 | ソニーグループ株式会社 | Information processing device, information processing method, and mobile body |
Also Published As
Publication number | Publication date |
---|---|
JP2022502784A (en) | 2022-01-11 |
EP3735626A1 (en) | 2020-11-11 |
US20210239815A1 (en) | 2021-08-05 |
EP3803273A4 (en) | 2021-11-17 |
WO2020092179A1 (en) | 2020-05-07 |
CN112955713A (en) | 2021-06-11 |
US20210239814A1 (en) | 2021-08-05 |
US20230296745A1 (en) | 2023-09-21 |
US20210241514A1 (en) | 2021-08-05 |
US10983201B2 (en) | 2021-04-20 |
EP3803273A1 (en) | 2021-04-14 |
US20200132822A1 (en) | 2020-04-30 |
CN113196197A (en) | 2021-07-30 |
EP3793899A1 (en) | 2021-03-24 |
US11698449B2 (en) | 2023-07-11 |
EP3793899A4 (en) | 2021-07-07 |
CN113015677A (en) | 2021-06-22 |
WO2020092178A1 (en) | 2020-05-07 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20210341614A1 (en) | Movable object for performing real-time mapping | |
US11721225B2 (en) | Techniques for sharing mapping data between an unmanned aerial vehicle and a ground vehicle | |
US20240159557A1 (en) | Techniques for collaborative map construction between an unmanned aerial vehicle and a ground vehicle | |
US11263761B2 (en) | Systems and methods for visual target tracking | |
US11032527B2 (en) | Unmanned aerial vehicle surface projection | |
WO2020088414A1 (en) | A movable object performing real-time mapping using a payload assembly | |
US20220113421A1 (en) | Online point cloud processing of lidar and camera data | |
WO2022077790A1 (en) | Representation data generation of three-dimensional mapping data | |
US20210404840A1 (en) | Techniques for mapping using a compact payload in a movable object environment | |
US20230177707A1 (en) | Post-processing of mapping data for improved accuracy and noise-reduction | |
Chien | Stereo-camera occupancy grid mapping | |
JP7072311B1 (en) | Movement route generation method and program of moving object, management server, management system | |
Alsadik et al. | Simulating a Hybrid Acquisition System for UAV Platforms. Drones 2022, 6, 314 | |
Sambolek et al. | Determining the Geolocation of a Person Detected in an Image Taken with a Drone |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: DJI TECHNOLOGY, INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ACOSTA, JOSHUA;MENON, ARJUN SUKUMAR;PABLO QUEVEDO, FERNANDO;AND OTHERS;SIGNING DATES FROM 20191107 TO 20191120;REEL/FRAME:055113/0046 |
|
STPP | Information on status: patent application and granting procedure in general |
Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION |
|
STCB | Information on status: application discontinuation |
Free format text: EXPRESSLY ABANDONED -- DURING EXAMINATION |