WO2021025364A1 - Method and system using lidar and camera to enhance depth information about image feature point - Google Patents

Method and system using lidar and camera to enhance depth information about image feature point Download PDF

Info

Publication number
WO2021025364A1
WO2021025364A1 PCT/KR2020/009992 KR2020009992W WO2021025364A1 WO 2021025364 A1 WO2021025364 A1 WO 2021025364A1 KR 2020009992 W KR2020009992 W KR 2020009992W WO 2021025364 A1 WO2021025364 A1 WO 2021025364A1
Authority
WO
WIPO (PCT)
Prior art keywords
image
depth information
feature point
point
scan data
Prior art date
Application number
PCT/KR2020/009992
Other languages
French (fr)
Korean (ko)
Inventor
이동환
김덕화
Original Assignee
네이버랩스 주식회사
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by 네이버랩스 주식회사 filed Critical 네이버랩스 주식회사
Publication of WO2021025364A1 publication Critical patent/WO2021025364A1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/50Depth or shape recovery
    • G06T7/55Depth or shape recovery from multiple images
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO 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/00Systems using the reflection or reradiation of electromagnetic waves other than radio waves, e.g. lidar systems
    • G01S17/02Systems using the reflection of electromagnetic waves other than radio waves
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO 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/00Systems using the reflection or reradiation of electromagnetic waves other than radio waves, e.g. lidar systems
    • G01S17/86Combinations of lidar systems with systems other than lidar, radar or sonar, e.g. with direction finders
    • GPHYSICS
    • G01MEASURING; TESTING
    • G01SRADIO 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/00Systems using the reflection or reradiation of electromagnetic waves other than radio waves, e.g. lidar systems
    • G01S17/88Lidar systems specially adapted for specific applications
    • G01S17/89Lidar systems specially adapted for specific applications for mapping or imaging
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T15/003D [Three Dimensional] image rendering
    • G06T15/06Ray-tracing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T15/003D [Three Dimensional] image rendering
    • G06T15/10Geometric effects
    • G06T15/20Perspective computation
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T7/00Image analysis
    • G06T7/10Segmentation; Edge detection
    • G06T7/11Region-based segmentation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N13/00Stereoscopic video systems; Multi-view video systems; Details thereof
    • H04N13/20Image signal generators
    • H04N13/204Image signal generators using stereoscopic image cameras
    • H04N13/254Image signal generators using stereoscopic image cameras in combination with electromagnetic radiation sources for illuminating objects
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N13/00Stereoscopic video systems; Multi-view video systems; Details thereof
    • H04N13/20Image signal generators
    • H04N13/271Image signal generators wherein the generated image signals comprise depth maps or disparity maps
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/10Image acquisition modality
    • G06T2207/10028Range image; Depth image; 3D point clouds

Definitions

  • the following description relates to a technology for generating a three-dimensional structure using an image.
  • Mobile robots must not only be able to grasp their location within a given environment, but also must be able to map their surrounding screens by themselves when they are placed in a new environment that they have not experienced before.
  • Mapping of a mobile robot means generating pre-data required for autonomous driving of the mobile robot.
  • a robot positioning a position using a lidar needs 3D precise data
  • a robot positioning a position based on an image needs data composed of image-based 3D feature points.
  • Korean Patent Laid-Open Publication No. 10-2011-0001932 (published on January 06, 2011) identifies the location of obstacles in an indoor space while moving the robot in an arbitrary direction.
  • a technology for creating an indoor map by displaying the location of an obstacle on a map is disclosed.
  • It provides a method and system that can generate a three-dimensional structure for map creation using LiDAR and a camera.
  • a method and system capable of accurately obtaining the depth of a corresponding image by using lidar scan data with an image acquired by a camera are provided.
  • SLAM Simultaneous Localization And Map-Building
  • a method executed on a computer system comprising at least one processor configured to execute computer readable instructions contained in a memory, the method comprising, by the at least one processor, a camera and a lidar ( Obtaining an image for map creation and LiDAR scan data through a LiDAR) sensor; And acquiring, by the at least one processor, depth information of a feature point extracted from the image by using the lidar scan data together with the image.
  • the image and lidar scan data of the same time zone may be acquired using a timestamp.
  • the method may further include generating, by the at least one processor, a 3D map to which a pose is tagged using the lidar scan data.
  • a point cloud map to which a pose is tagged may be generated by performing Simultaneous Localization And Map-Building (SLAM) using the lidar scan data.
  • SLAM Simultaneous Localization And Map-Building
  • the obtaining of depth information of a feature point extracted from the image may include: extracting a feature point having a feature that is invariant to rotation and scale from the image; Configuring a point cloud by accumulating the lidar scan data acquired at the same time as the image; And determining a point existing on an extension line connecting the lens of the camera and the feature point in the point cloud as a three-dimensional coordinate of the feature point.
  • the step of obtaining depth information of the feature point extracted from the image further comprises extracting a point cloud of a view frustum corresponding to the pose information of the image from the point cloud,
  • the three-dimensional coordinates of the feature point may be determined in the extracted point cloud of the view area.
  • the three-dimensional coordinates of the feature point may be determined by changing the coordinates of the image and the point cloud into a spherical coordinate system.
  • the determining of the three-dimensional coordinates of the feature points includes finding an intersection point between the line of sight and the object in the direction of the line of sight passing through the feature points using ray casting, and determining the three-dimensional coordinates of the feature points. You can decide.
  • the determining of the three-dimensional coordinates of the feature point may include finding the three-dimensional coordinates of the feature point in the point cloud through NNS (nearest neigbor search) using a multidimensional tree structure (KD-tree). .
  • the method may further include, by the at least one processor, refining depth information of the redundantly extracted feature points using a plurality of images having depth information.
  • It provides a non-transitory computer-readable recording medium in which a program for executing the method in a computer is recorded.
  • a computer system comprising at least one processor configured to execute computer-readable instructions contained in a memory, wherein the at least one processor includes an image and a lidar for mapping through a camera and a LiDAR sensor.
  • a data acquisition unit that acquires scan data;
  • a depth information acquisition unit that acquires depth information of a feature point extracted from the image by using the lidar scan data together with the image.
  • depth information of a three-dimensional structure may be improved by obtaining a depth of an image as a real date using lidar scan data.
  • an optimized 3D structure may be obtained by refining a depth value using a lidar-based SLAM and an image.
  • FIG. 1 is a block diagram illustrating an example of an internal configuration of a computer system according to an embodiment of the present invention.
  • FIG. 2 is a diagram illustrating an example of components that may be included in a processor of a computer system according to an embodiment of the present invention.
  • FIG. 3 is a flowchart illustrating an example of a method for enhancing depth information that can be performed by a computer system according to an embodiment of the present invention.
  • FIG. 4 is a view for explaining an example of a pose tagging process through the LIDA SLAM in an embodiment of the present invention.
  • FIG. 5 is a view for explaining an example of a process of obtaining depth information of a feature point of an image according to an embodiment of the present invention.
  • FIG. 6 is an exemplary diagram for explaining a process of extracting a feature point of an image according to an embodiment of the present invention.
  • FIG. 7 is an exemplary diagram for explaining a point cloud configured by LiDAR scan data in an embodiment of the present invention.
  • FIG. 8 is an exemplary diagram for explaining a view area culling process for a LiDAR point cloud according to an embodiment of the present invention.
  • FIG. 9 is an exemplary view for explaining a process of changing the coordinates of feature points and point clouds of an image into a spherical coordinate system in an embodiment of the present invention.
  • FIG. 10 is an exemplary diagram for explaining a ray casting-based depth association process according to an embodiment of the present invention.
  • FIG. 11 shows an example of a multidimensional tree structure according to an embodiment of the present invention.
  • NMS nearest neigbor search
  • Embodiments of the present invention relate to a technology for generating a three-dimensional structure using an image.
  • Embodiments including those specifically disclosed in the present specification can obtain a 3D structure required for image-based positioning using images and lidars, and through this, various aspects such as accuracy, precision, optimization, and generation speed of the map can be obtained. To achieve significant advantages.
  • FIG. 1 is a block diagram showing an example of a computer system according to an embodiment of the present invention.
  • the depth information enhancement system according to embodiments of the present invention may be implemented by the computer system 100 illustrated through FIG. 1.
  • the computer system 100 is a component for executing the method for improving depth information according to embodiments of the present invention, and includes a memory 110, a processor 120, a communication interface 130, and input/output. It may include an interface 140.
  • the memory 110 is a computer-readable recording medium and may include a permanent mass storage device such as a random access memory (RAM), read only memory (ROM), and a disk drive.
  • a non-destructive large-capacity recording device such as a ROM and a disk drive may be included in the computer system 100 as a separate permanent storage device separated from the memory 110.
  • an operating system and at least one program code may be stored in the memory 110.
  • These software components may be loaded into the memory 110 from a computer-readable recording medium separate from the memory 110.
  • Such a separate computer-readable recording medium may include a computer-readable recording medium such as a floppy drive, disk, tape, DVD/CD-ROM drive, and memory card.
  • software components may be loaded into the memory 110 through a communication interface 130 other than a computer-readable recording medium.
  • software components may be loaded into the memory 110 of the computer system 100 based on a computer program installed by files received over the network 160.
  • the processor 120 may be configured to process instructions of a computer program by performing basic arithmetic, logic, and input/output operations. Instructions may be provided to the processor 120 by the memory 110 or the communication interface 130. For example, the processor 120 may be configured to execute a command received according to a program code stored in a recording device such as the memory 110.
  • the communication interface 130 may provide a function for the computer system 100 to communicate with other devices through the network 160. For example, a request, command, data, file, etc., generated by the processor 120 of the computer system 100 according to a program code stored in a recording device such as the memory 110, is transmitted to the network according to the control of the communication interface 130. 160) can be delivered to other devices. Conversely, signals, commands, data, files, etc. from other devices may be received by the computer system 100 through the communication interface 130 of the computer system 100 via the network 160. Signals, commands, data, etc. received through the communication interface 130 may be transmitted to the processor 120 or the memory 110, and files, etc. may be further included in the computer system 100 (as described above). Permanent storage).
  • the communication method is not limited, and not only a communication method using a communication network (for example, a mobile communication network, wired Internet, wireless Internet, broadcasting network) that the network 160 may include, but also short-range wired/wireless communication between devices may be included.
  • the network 160 includes a personal area network (PAN), a local area network (LAN), a campus area network (CAN), a metropolitan area network (MAN), a wide area network (WAN), and a broadband network (BBN). , Internet, and the like.
  • the network 160 may include any one or more of a network topology including a bus network, a star network, a ring network, a mesh network, a star-bus network, a tree or a hierarchical network, etc. Not limited.
  • the input/output interface 140 may be a means for an interface with the input/output device 150.
  • the input device may include a device such as a microphone, keyboard, camera, or mouse
  • the output device may include a device such as a display and a speaker.
  • the input/output interface 140 may be a means for interfacing with a device in which input and output functions are integrated into one, such as a touch screen.
  • the input/output device 150 may be configured with the computer system 100 and one device.
  • the computer system 100 may include fewer or more components than the components of FIG. 1. However, there is no need to clearly show most of the prior art components.
  • the computer system 100 may be implemented to include at least some of the input/output devices 150 described above, or other components such as a transceiver, a global positioning system (GPS) module, a camera, various sensors, and a database. May include more.
  • GPS global positioning system
  • the computer system 100 may be implemented in the form of a mobile robot for creating a map, and a camera module, a lidar sensor, an acceleration sensor or a gyro sensor, various physical buttons, and buttons using a touch panel required for mapping , Input/output ports, and the like may be implemented to be further included in the computer system 100.
  • the present invention relates to an image-based positioning (visual localization) technology, and is a technology applicable to both indoor and outdoor maps.
  • the 3D structure may include 3D coordinates corresponding to a specific pixel of the image, and may also include a depth value of the image.
  • knowing the three-dimensional structure is equivalent to knowing the three-dimensional coordinates and depth values of an image.
  • a 3D structure can be obtained using an RGB image through a technology such as SfM (structure from motion).
  • SfM structure from motion
  • the RGB-D image sensor Although it is possible to use an RGB-D image sensor with a depth sensor attached, the RGB-D image sensor has a disadvantage in that the noise of the depth value is very severe, and the range that can be sensed for the depth is limited. It cannot be used for outdoor mapping.
  • Embodiments of the present invention relate to a method of accurately obtaining the depth of an image using lidar scan data together with an image.
  • FIG. 2 is a diagram showing an example of components that can be included in a processor of a computer system according to an embodiment of the present invention
  • FIG. 3 is depth information that can be performed by a computer system according to an embodiment of the present invention. It is a flow chart showing an example of the improvement method.
  • the processor 120 may include a data acquisition unit 201, a map generation unit 202, a depth information acquisition unit 203, and a depth information refiner 204.
  • Components of the processor 120 may be expressions of different functions performed by the processor 120 according to a control command provided by at least one program code.
  • the data acquisition unit 201 may be used as a functional representation that the processor 120 operates to control the computer system 100 to acquire data from a camera and a lidar.
  • the processor 120 and components of the processor 120 may perform steps S310 to S340 included in the method of improving depth information of FIG. 3.
  • the processor 120 and the components of the processor 120 may be implemented to execute an instruction according to the code of the operating system included in the memory 110 and the at least one program code described above.
  • at least one program code may correspond to a code of a program implemented to process the depth information enhancement method.
  • the depth information enhancement method may not occur in the illustrated order, and some of the steps may be omitted or an additional process may be further included.
  • the processor 120 may load a program code stored in a program file for a method of improving depth information into the memory 110.
  • a program file for a method for improving depth information may be stored in a permanent storage device separate from the memory 110, and the processor 120 stores program codes from a program file stored in a permanent storage device through a bus.
  • Computer system 100 can be controlled to be loaded onto 110.
  • each of the data acquisition unit 201, the map generation unit 202, the depth information acquisition unit 203, and the depth information refiner 204 included in the processor 120 and the processor 120 is a memory 110 It may be different functional expressions of the processor 120 for executing the subsequent steps (S310 to S340) by executing an instruction of a corresponding part of the program code loaded in the.
  • the processor 120 and components of the processor 120 may directly process an operation according to a control command or control the computer system 100.
  • the data acquisition unit 201 may acquire an image for creating a map through the camera and acquire lidar scan data through a lidar sensor.
  • a 3D structure may be generated by reconstructing 3D points for pixels corresponding to the camera from the camera image and lidar scan data.
  • the data acquisition unit 201 may acquire an image and lidar scan data together through a mobile robot for creating an indoor or outdoor map.
  • the depth information obtained from the lidar sensor is very accurate as an actual measurement value, so it can be used not only for indoor maps but also for outdoor maps.
  • the data acquisition unit 201 may simultaneously obtain a camera image and lidar scan data for each timestamp. In other words, the data acquisition unit 201 may acquire an image and lidar scan data in the same time zone using the time stamp.
  • the map generator 202 may generate a 3D map to which a pose is tagged by using the lidar scan data acquired in step S310.
  • Visual localization may be performed based on pose information (including a 3-axis position value and a 3-axis direction value) of an image generated by the map generator 202.
  • FIG. 4 is a view for explaining an example of a pose tagging process through the LIDA SLAM in an embodiment of the present invention.
  • the map generator 202 may obtain pose information of images by performing a lidar SLAM using lidar scan data, and poses of the images are tagged as point cloud maps. cloud map).
  • a 3D map is created.
  • a point cloud map in which the poses of each image are tagged is created on the 3D structure of the map according to pose tagging through the LIDA SLAM.
  • the pose information of the image and the 3D structure made of the lidar sensor can be used to obtain a 3D point corresponding to each pixel of the image.
  • the depth information acquisition unit 203 may acquire depth information of a feature point extracted from the corresponding image by using the image and lidar scan data in the same time zone.
  • the depth information acquisition unit 203 may obtain depth information of the image by calculating a vector from the lens of the camera to a specific pixel of the image using the parameter of the camera. According to the present invention, it is possible to create a more accurate map by accurately obtaining depth information of an image using the lidar scan data. A process of obtaining depth information using lidar scan data will be described in detail below.
  • the depth information refiner 204 may refine depth information by using a plurality of images having depth information. This is to solve the problem that the feature points extracted from one image are redundantly extracted from the next image, and depth information can be optimized by modifying the previously calculated 3D points using the 3D points of each feature point and the poses of the images. have.
  • the depth information refiner 204 refines the depth value of the duplicated feature point by determining the camera parameter and the absolute coordinate corresponding to the given 3D point using an optimization technique such as a bundle adjustment method. can do.
  • the depth information refiner 204 uses the pixel error of the images based on the three-dimensional points of the plurality of images and the feature points extracted from each image, and the relationship to pose the points and images in a direction to optimize the error. Can be estimated.
  • FIG. 5 is a view for explaining an example of a process of obtaining depth information of a feature point of an image according to an embodiment of the present invention.
  • the depth information acquisition unit 203 may extract a keypoint corresponding to a specific pixel from an image.
  • the feature point refers to a pixel having a characteristic that is invariant to rotation and scale on an image.
  • the depth information acquisition unit 203 includes Scale-Invariant Feature Transform (SIFT) and Features (FAST). From Accelerated Segment Test), BRIEF (Binary Robust Independent Elementary Features), ORB (Oriented FAST and Rotated BRIEF), the feature points can be extracted from the image using widely used feature point extraction algorithms.
  • SIFT Scale-Invariant Feature Transform
  • FAST Features
  • FIG. 6 shows an example of a result of extracting a feature point, and a feature point 601 that is invariant in rotation and size on the image 600 can be identified.
  • the depth information acquisition unit 203 may configure a point cloud by accumulating lidar scan data acquired within a specific time based on the time point at which the image was acquired.
  • the depth information acquisition unit 203 may configure a lidar point cloud using lidar scan data acquired at the same time point, that is, at the time point at which the image is acquired.
  • FIG. 7 shows an example of a lidar point cloud 700 configured with lidar scan data acquired at the same time for the image 600 of FIG. 6.
  • the depth information acquisition unit 203 may extract a point cloud of a view frustum corresponding to the pose information of the image from the point cloud configured in step S502.
  • the depth information acquisition unit 203 may extract only a point cloud suitable for a corresponding view by using the pose information of the image without using all the point clouds to optimize the computation time.
  • FIG. 8 is an exemplary diagram for explaining a view area culling process for a LiDAR point cloud according to an embodiment of the present invention.
  • the depth information acquisition unit 203 filters the low point cloud 700 configured by the lidar scan data acquired at the same time as the image according to the field of view (FOV) of the camera to provide image pose information.
  • a culled point cloud 800 according to the view area of may be obtained.
  • the depth information acquisition unit 203 determines a point existing on the extension line connecting the lens of the camera and the feature point extracted from the image in the point cloud extracted in step S503. It can be used as a 3D coordinate corresponding to information.
  • the depth information acquisition unit 203 converts the image coordinate p and the point cloud map of the feature point into a spherical coordinate system as shown in FIG. 9. Can be changed to.
  • Rectangular coordinate system (x,y,z) Changing to is the same as in Equation 1.
  • the depth information acquisition unit 203 Ignore The nearest point can be used as a 3D point of a feature point by using only.
  • the depth information acquisition unit 203 may acquire depth information by performing depth association based on ray casting.
  • the ray projection method examines a view ray passing through a pixel point in an image, and checks whether a scene object intersects the line of sight to find the closest intersection point to the pixel for each pixel.
  • the ray projection method is for detecting the view plane, and assuming that the line of sight starts from the lens of the camera, the closest object blocking the line of sight path passing through one pixel point of the image is found. . That is, if the surface of an object is facing a light source and light hits this surface, the light is either unblocked or creates a shadow.
  • the shading of the surface can be calculated using a widely known shading technique.
  • One of the shading techniques, the depth buffer algorithm processes surfaces one at a time and calculates depth values for all projection points. The calculated depth of the surface is compared with the previously stored depth value to determine the surface visible from the pixel.
  • These ray projections process each pixel in the image, one by one, and calculate the depth of any surface on the projection path leading to that pixel.
  • the depth information acquisition unit 203 performs NNS (nearest neigbor search) using a multidimensional tree structure (KD-tree) to quickly find a point to be used as a 3D point of a feature point in the point cloud extracted in step S503. can do.
  • NNS nearest neigbor search
  • KD-tree multidimensional tree structure
  • 11 shows an example of a multidimensional tree structure for NNS. 11 illustrates a two-dimensional space division for convenience of description.
  • the multi-dimensional tree structure is an extension of the binary search tree (BST) to a multi-dimensional space, and is used to compare the tree levels in turn.
  • the multidimensional tree structure has a sub-hierarchical structure that divides an area along one axis at a time and changes the axis in a circular manner at each sub-level.
  • the X axis is first divided with respect to the Y plane, and then the Y axis is divided with respect to the X plane. Assuming that the dividing plane is selected in the order of X ⁇ Y, all points with x coordinates less than or equal to x 00 selected from the highest root can be configured as left nodes, and points larger than x coordinates can be configured as right nodes.
  • the points of the lower node are divided using y coordinate values y 01 and y 11 .
  • the first subscript indicates the position of the node within the same level starting from 0 for the leftmost node
  • the second subscript indicates the level where the node is located.
  • FIG. 12 shows a process of finding a point closest to the pixel coordinate P using the tree structure of FIG. 11.
  • moving from a node including P to a neighboring node starts by finding a point closest to P.
  • a sphere centered on P can be used to find the smallest of the squared values of the distance between two points. If the node information overlaps the sphere centered on P, the squared distance between P and the point on the node is calculated and the lowest value. Save it. After repeating the search for all nodes overlapping with the sphere centered on P is completed, the smallest value among the stored values may be determined as the nearest neighbor point to P.
  • the depth information acquisition unit 203 may more quickly find the 3D point of the feature point in the point cloud through the NNS using the multidimensional tree structure (KD-tree).
  • a more accurate map can be created by generating a three-dimensional structure using a lidar and a camera, and in particular, the depth of an image is determined using lidar scan data obtained through a lidar sensor. Since it can be obtained as an actual value, the depth information of the three-dimensional structure can be improved.
  • the apparatus described above may be implemented as a hardware component, a software component, and/or a combination of a hardware component and a software component.
  • the devices and components described in the embodiments are a processor, a controller, an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable gate array (FPGA), a programmable gate array (PLU). It may be implemented using one or more general purpose computers or special purpose computers, such as a logic unit), a microprocessor, or any other device capable of executing and responding to instructions.
  • the processing device may execute an operating system (OS) and one or more software applications executed on the operating system.
  • OS operating system
  • software applications executed on the operating system.
  • the processing device may access, store, manipulate, process, and generate data in response to the execution of software.
  • the processing device is a plurality of processing elements and/or multiple types of processing elements. It can be seen that it may include.
  • the processing device may include a plurality of processors or one processor and one controller.
  • other processing configurations are possible, such as a parallel processor.
  • the software may include a computer program, code, instructions, or a combination of one or more of these, configuring the processing unit to behave as desired or processed independently or collectively. You can command the device.
  • Software and/or data may be embodyed in any type of machine, component, physical device, computer storage medium or device to be interpreted by the processing device or to provide instructions or data to the processing device. have.
  • the software may be distributed over networked computer systems and stored or executed in a distributed manner. Software and data may be stored on one or more computer-readable recording media.
  • the method according to the embodiment may be implemented in the form of program instructions that can be executed through various computer means and recorded in a computer-readable medium.
  • the medium may be one that continuously stores a program executable by a computer, or temporarily stores a program for execution or download.
  • the medium may be a variety of recording means or storage means in a form in which a single or several pieces of hardware are combined, but is not limited to a medium directly connected to a computer system, but may be distributed on a network.
  • Examples of media include magnetic media such as hard disks, floppy disks, and magnetic tapes, optical recording media such as CD-ROMs and DVDs, magnetic-optical media such as floptical disks, and And a ROM, RAM, flash memory, and the like, and may be configured to store program instructions.
  • examples of other media include an app store that distributes applications, a site that supplies or distributes various software, and a recording medium or a storage medium managed by a server.

Landscapes

  • Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Electromagnetism (AREA)
  • Radar, Positioning & Navigation (AREA)
  • Remote Sensing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Graphics (AREA)
  • Multimedia (AREA)
  • Computer Vision & Pattern Recognition (AREA)
  • Computing Systems (AREA)
  • Geometry (AREA)
  • Length Measuring Devices By Optical Means (AREA)
  • Image Analysis (AREA)

Abstract

Disclosed are a method and system that use LiDAR and a camera to enhance depth information about an image feature point. The method for enhancing depth information about an image feature point includes the steps of: acquiring, through a camera and a LiDAR sensor, an image and LiDAR scan data for creating a map; and using the LiDAR scan data together with the image to acquire depth information about a feature point extracted from the image.

Description

라이다와 카메라를 이용하여 이미지 특징점의 깊이 정보를 향상시키는 방법 및 시스템Method and system for improving depth information of image feature points using lidar and camera
아래의 설명은 이미지를 이용하여 3차원 구조(structure)를 생성하는 기술에 관한 것이다.The following description relates to a technology for generating a three-dimensional structure using an image.
이동로봇은 주어진 환경 내에서 자신의 위치를 파악할 수 있어야 할 뿐만 아니라, 이전에 경험하지 못한 새로운 환경에 놓이는 경우 스스로 그 주변 화면에 대한 지도를 작성할 수 있어야 한다.Mobile robots must not only be able to grasp their location within a given environment, but also must be able to map their surrounding screens by themselves when they are placed in a new environment that they have not experienced before.
이동로봇의 지도 작성이란, 이동로봇의 자율 주행에 필요한 사전 데이터를 생성하는 것을 의미한다. 라이다를 사용하여 위치를 측위하는 로봇은 3차원 정밀 데이터가 필요하고, 이미지를 기반으로 위치를 측위하는 로봇은 이미지 기반의 3차원 특징점으로 구성된 데이터가 필요하다.Mapping of a mobile robot means generating pre-data required for autonomous driving of the mobile robot. A robot positioning a position using a lidar needs 3D precise data, and a robot positioning a position based on an image needs data composed of image-based 3D feature points.
이동로봇의 지도 작성 기술의 일례로, 한국 공개특허공보 제10-2011-0001932호(공개일 2011년 01월 06일)에는 로봇을 임의 방향으로 이동시키면서 실내 공간에 존재하는 장애물의 위치를 파악하여 장애물의 위치를 지도 상에 표시함으로써 실내 지도를 작성하는 기술이 개시되어 있다.As an example of a mobile robot mapping technology, Korean Patent Laid-Open Publication No. 10-2011-0001932 (published on January 06, 2011) identifies the location of obstacles in an indoor space while moving the robot in an arbitrary direction. A technology for creating an indoor map by displaying the location of an obstacle on a map is disclosed.
라이다(LiDAR)와 카메라를 이용하여 지도 작성을 위한 3차원 구조를 생성할 수 있는 방법 및 시스템을 제공한다.It provides a method and system that can generate a three-dimensional structure for map creation using LiDAR and a camera.
카메라로 획득한 이미지와 함께 라이다 스캔 데이터를 이용하여 해당 이미지의 깊이(depth)를 정밀하게 구할 수 있는 방법 및 시스템을 제공한다.A method and system capable of accurately obtaining the depth of a corresponding image by using lidar scan data with an image acquired by a camera are provided.
라이다 기반 SLAM(Simultaneous Localization And Map-Building)과 이미지를 이용하여 깊이 값을 정제할 수 있는 방법 및 시스템을 제공한다.Provides a method and system for refining the depth value using a lidar-based SLAM (Simultaneous Localization And Map-Building) and an image.
컴퓨터 시스템에서 실행되는 방법에 있어서, 상기 컴퓨터 시스템은 메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서를 포함하고, 상기 방법은, 상기 적어도 하나의 프로세서에 의해, 카메라와 라이다(LiDAR) 센서를 통해 지도 작성을 위한 이미지와 라이다 스캔 데이터를 획득하는 단계; 및 상기 적어도 하나의 프로세서에 의해, 상기 이미지와 함께 상기 라이다 스캔 데이터를 이용하여 상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 단계를 포함하는 방법을 제공한다.A method executed on a computer system, the computer system comprising at least one processor configured to execute computer readable instructions contained in a memory, the method comprising, by the at least one processor, a camera and a lidar ( Obtaining an image for map creation and LiDAR scan data through a LiDAR) sensor; And acquiring, by the at least one processor, depth information of a feature point extracted from the image by using the lidar scan data together with the image.
일 측면에 따르면, 상기 이미지와 라이다 스캔 데이터를 획득하는 단계는, 타임스탬프(timestamp)를 이용하여 동시간대의 상기 이미지와 상기 라이다 스캔 데이터를 획득할 수 있다.According to an aspect, in the acquiring of the image and lidar scan data, the image and lidar scan data of the same time zone may be acquired using a timestamp.
다른 측면에 따르면, 상기 방법은, 상기 적어도 하나의 프로세서에 의해, 상기 라이다 스캔 데이터를 이용하여 포즈(pose)가 태깅된 3차원 지도를 생성하는 단계를 더 포함할 수 있다.According to another aspect, the method may further include generating, by the at least one processor, a 3D map to which a pose is tagged using the lidar scan data.
또 다른 측면에 따르면, 상기 생성하는 단계는, 상기 라이다 스캔 데이터를 이용하여 SLAM(Simultaneous Localization And Map-Building)을 수행함으로써 포즈가 태깅된 포인트 클라우드 맵(point cloud map)을 생성할 수 있다.According to another aspect, in the generating step, a point cloud map to which a pose is tagged may be generated by performing Simultaneous Localization And Map-Building (SLAM) using the lidar scan data.
또 다른 측면에 따르면, 상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 단계는, 상기 이미지에서 회전(rotation)과 크기(scale)에 불변하는 특성을 가진 특징점을 추출하는 단계; 상기 이미지와 동시간대에 획득한 상기 라이다 스캔 데이터를 축적하여 포인트 클라우드를 구성하는 단계; 및 상기 포인트 클라우드에서 상기 카메라의 렌즈와 상기 특징점을 잇는 연장선 상에 존재하는 포인트를 상기 특징점의 3차원 좌표로 결정하는 단계를 포함할 수 있다.According to another aspect, the obtaining of depth information of a feature point extracted from the image may include: extracting a feature point having a feature that is invariant to rotation and scale from the image; Configuring a point cloud by accumulating the lidar scan data acquired at the same time as the image; And determining a point existing on an extension line connecting the lens of the camera and the feature point in the point cloud as a three-dimensional coordinate of the feature point.
또 다른 측면에 따르면, 상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 단계는, 상기 포인트 클라우드에서 상기 이미지의 포즈 정보에 대응되는 뷰 영역(view frustum)의 포인트 클라우드를 추출하는 단계를 더 포함하고, 상기 특징점의 3차원 좌표로 결정하는 단계는, 상기 추출된 뷰 영역의 포인트 클라우드에서 상기 특징점의 3차원 좌표를 결정할 수 있다.According to another aspect, the step of obtaining depth information of the feature point extracted from the image further comprises extracting a point cloud of a view frustum corresponding to the pose information of the image from the point cloud, In the determining of the three-dimensional coordinates of the feature point, the three-dimensional coordinates of the feature point may be determined in the extracted point cloud of the view area.
또 다른 측면에 따르면, 상기 특징점의 3차원 좌표로 결정하는 단계는, 상기 이미지의 좌표와 상기 포인트 클라우드를 구형 좌표계(spherical coordinate)로 변경하여 상기 특징점의 3차원 좌표를 결정할 수 있다.According to another aspect, in the determining of the three-dimensional coordinates of the feature point, the three-dimensional coordinates of the feature point may be determined by changing the coordinates of the image and the point cloud into a spherical coordinate system.
또 다른 측면에 따르면, 상기 특징점의 3차원 좌표로 결정하는 단계는, 광선 투사법(ray casting)을 이용하여 상기 특징점을 통과하는 시선 방향에서 시선과 객체 간의 교점을 찾아 상기 특징점의 3차원 좌표를 결정할 수 있다.According to another aspect, the determining of the three-dimensional coordinates of the feature points includes finding an intersection point between the line of sight and the object in the direction of the line of sight passing through the feature points using ray casting, and determining the three-dimensional coordinates of the feature points. You can decide.
또 다른 측면에 따르면, 상기 특징점의 3차원 좌표로 결정하는 단계는, 다차원 트리 구조(KD-tree)를 이용한 NNS(nearest neigbor search)을 통해 상기 포인트 클라우드에서 상기 특징점의 3차원 좌표를 찾을 수 있다.According to another aspect, the determining of the three-dimensional coordinates of the feature point may include finding the three-dimensional coordinates of the feature point in the point cloud through NNS (nearest neigbor search) using a multidimensional tree structure (KD-tree). .
또 다른 측면에 따르면, 상기 방법은, 상기 적어도 하나의 프로세서에 의해, 깊이 정보를 가진 복수의 이미지를 이용하여 중복 추출된 특징점의 깊이 정보를 정제하는 단계를 더 포함할 수 있다.According to another aspect, the method may further include, by the at least one processor, refining depth information of the redundantly extracted feature points using a plurality of images having depth information.
상기 방법을 상기 컴퓨터 시스템에 실행시키기 위해 비-일시적인 컴퓨터 판독가능한 기록 매체에 저장되는 컴퓨터 프로그램을 제공한다.There is provided a computer program stored in a non-transitory computer-readable recording medium for executing the method on the computer system.
상기 방법을 컴퓨터에 실행시키기 위한 프로그램이 기록되어 있는 비-일시적인 컴퓨터 판독 가능한 기록 매체를 제공한다.It provides a non-transitory computer-readable recording medium in which a program for executing the method in a computer is recorded.
컴퓨터 시스템에 있어서, 메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서를 포함하고, 상기 적어도 하나의 프로세서는, 카메라와 라이다(LiDAR) 센서를 통해 지도 작성을 위한 이미지와 라이다 스캔 데이터를 획득하는 데이터 획득부; 및 상기 이미지와 함께 상기 라이다 스캔 데이터를 이용하여 상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 깊이 정보 획득부를 포함하는 컴퓨터 시스템을 제공한다.A computer system comprising at least one processor configured to execute computer-readable instructions contained in a memory, wherein the at least one processor includes an image and a lidar for mapping through a camera and a LiDAR sensor. A data acquisition unit that acquires scan data; And a depth information acquisition unit that acquires depth information of a feature point extracted from the image by using the lidar scan data together with the image.
본 발명의 실시예들에 따르면, 라이다와 카메라를 이용하여 3차원 구조를 생성함으로써 더욱 정확한 지도를 작성할 수 있다.According to embodiments of the present invention, it is possible to create a more accurate map by creating a 3D structure using a lidar and a camera.
본 발명의 실시예들에 따르면, 라이다 스캔 데이터를 이용하여 이미지의 깊이를 실측치(real date)로 얻을 수 있어 3차원 구조의 깊이 정보를 향상시킬 수 있다.According to embodiments of the present invention, depth information of a three-dimensional structure may be improved by obtaining a depth of an image as a real date using lidar scan data.
본 발명의 실시예들에 따르면, 라이다 기반 SLAM과 이미지를 이용하여 깊이 값을 정제함으로써 최적화된 3차원 구조를 얻을 수 있다.According to embodiments of the present invention, an optimized 3D structure may be obtained by refining a depth value using a lidar-based SLAM and an image.
도 1은 본 발명의 일실시예에 있어서 컴퓨터 시스템의 내부 구성의 일례를 설명하기 위한 블록도이다.1 is a block diagram illustrating an example of an internal configuration of a computer system according to an embodiment of the present invention.
도 2는 본 발명의 일실시예에 따른 컴퓨터 시스템의 프로세서가 포함할 수 있는 구성요소의 예를 도시한 도면이다.2 is a diagram illustrating an example of components that may be included in a processor of a computer system according to an embodiment of the present invention.
도 3은 본 발명의 일실시예에 따른 컴퓨터 시스템이 수행할 수 있는 깊이 정보 향상 방법의 예를 도시한 순서도이다.3 is a flowchart illustrating an example of a method for enhancing depth information that can be performed by a computer system according to an embodiment of the present invention.
도 4는 본 발명의 일실시예에 있어서 라이다 SLAM을 통한 포즈 태깅 과정의 일례를 설명하기 위한 도면이다.4 is a view for explaining an example of a pose tagging process through the LIDA SLAM in an embodiment of the present invention.
도 5는 본 발명의 일실시예에 있어서 이미지의 특징점의 깊이 정보를 획득하는 과정의 일례를 설명하기 위한 도면이다.5 is a view for explaining an example of a process of obtaining depth information of a feature point of an image according to an embodiment of the present invention.
도 6은 본 발명의 일실시예에 있어서 이미지의 특징점을 추출하는 과정을 설명하기 위한 예시 도면이다.6 is an exemplary diagram for explaining a process of extracting a feature point of an image according to an embodiment of the present invention.
도 7은 본 발명의 일실시예에 있어서 라이다 스캔 데이터에 의해 구성된 포인트 클라우드를 설명하기 위한 예시 도면이다.7 is an exemplary diagram for explaining a point cloud configured by LiDAR scan data in an embodiment of the present invention.
도 8은 본 발명의 일실시예에 있어서 라이다 포인트 클라우드에 대한 뷰 영역 컬링(culling) 과정을 설명하기 위한 예시 도면이다.8 is an exemplary diagram for explaining a view area culling process for a LiDAR point cloud according to an embodiment of the present invention.
도 9는 본 발명의 일실시예에 있어서 이미지의 특징점 좌표와 포인트 클라우드를 구형 좌표계로 변경하는 과정을 설명하기 위한 예시 도면이다.9 is an exemplary view for explaining a process of changing the coordinates of feature points and point clouds of an image into a spherical coordinate system in an embodiment of the present invention.
도 10은 본 발명의 일실시예에 있어서 광선 투사법(ray casting) 기반 깊이 연계(association) 과정을 설명하기 위한 예시 도면이다.10 is an exemplary diagram for explaining a ray casting-based depth association process according to an embodiment of the present invention.
도 11은 본 발명의 일실시예에 있어서 다차원 트리 구조의 예시를 도시한 것이다.11 shows an example of a multidimensional tree structure according to an embodiment of the present invention.
도 12는 본 발명의 일실시예에 있어서 NNS(nearest neigbor search) 과정을 설명하기 위한 예시 도면이다.12 is an exemplary diagram for explaining a nearest neigbor search (NNS) process according to an embodiment of the present invention.
이하, 본 발명의 실시예를 첨부된 도면을 참조하여 상세하게 설명한다.Hereinafter, embodiments of the present invention will be described in detail with reference to the accompanying drawings.
본 발명의 실시예들은 이미지를 이용하여 3차원 구조(structure)를 생성하는 기술에 관한 것이다.Embodiments of the present invention relate to a technology for generating a three-dimensional structure using an image.
본 명세서에서 구체적으로 개시되는 것들을 포함하는 실시예들은 이미지와 라이다를 이용하여 이미지 기반 측위를 위해 필요한 3차원 구조를 얻을 수 있고, 이를 통해 지도의 정확성, 정밀성, 최적화, 생성 속도 등 여러 측면에 있어서 상당한 장점들을 달성한다.Embodiments including those specifically disclosed in the present specification can obtain a 3D structure required for image-based positioning using images and lidars, and through this, various aspects such as accuracy, precision, optimization, and generation speed of the map can be obtained. To achieve significant advantages.
도 1은 본 발명의 일실시예에 따른 컴퓨터 시스템의 예를 도시한 블록도이다. 예를 들어, 본 발명의 실시예들에 따른 깊이 정보 향상 시스템은 도 1을 통해 도시된 컴퓨터 시스템(100)에 의해 구현될 수 있다.1 is a block diagram showing an example of a computer system according to an embodiment of the present invention. For example, the depth information enhancement system according to embodiments of the present invention may be implemented by the computer system 100 illustrated through FIG. 1.
도 1에 도시된 바와 같이 컴퓨터 시스템(100)은 본 발명의 실시예들에 따른 깊이 정보 향상 방법을 실행하기 위한 구성요소로서, 메모리(110), 프로세서(120), 통신 인터페이스(130) 그리고 입출력 인터페이스(140)를 포함할 수 있다.As shown in FIG. 1, the computer system 100 is a component for executing the method for improving depth information according to embodiments of the present invention, and includes a memory 110, a processor 120, a communication interface 130, and input/output. It may include an interface 140.
메모리(110)는 컴퓨터에서 판독 가능한 기록매체로서, RAM(random access memory), ROM(read only memory) 및 디스크 드라이브와 같은 비소멸성 대용량 기록장치(permanent mass storage device)를 포함할 수 있다. 여기서 ROM과 디스크 드라이브와 같은 비소멸성 대용량 기록장치는 메모리(110)와는 구분되는 별도의 영구 저장 장치로서 컴퓨터 시스템(100)에 포함될 수도 있다. 또한, 메모리(110)에는 운영체제와 적어도 하나의 프로그램 코드가 저장될 수 있다. 이러한 소프트웨어 구성요소들은 메모리(110)와는 별도의 컴퓨터에서 판독 가능한 기록매체로부터 메모리(110)로 로딩될 수 있다. 이러한 별도의 컴퓨터에서 판독 가능한 기록매체는 플로피 드라이브, 디스크, 테이프, DVD/CD-ROM 드라이브, 메모리 카드 등의 컴퓨터에서 판독 가능한 기록매체를 포함할 수 있다. 다른 실시예에서 소프트웨어 구성요소들은 컴퓨터에서 판독 가능한 기록매체가 아닌 통신 인터페이스(130)를 통해 메모리(110)에 로딩될 수도 있다. 예를 들어, 소프트웨어 구성요소들은 네트워크(160)를 통해 수신되는 파일들에 의해 설치되는 컴퓨터 프로그램에 기반하여 컴퓨터 시스템(100)의 메모리(110)에 로딩될 수 있다.The memory 110 is a computer-readable recording medium and may include a permanent mass storage device such as a random access memory (RAM), read only memory (ROM), and a disk drive. Here, a non-destructive large-capacity recording device such as a ROM and a disk drive may be included in the computer system 100 as a separate permanent storage device separated from the memory 110. In addition, an operating system and at least one program code may be stored in the memory 110. These software components may be loaded into the memory 110 from a computer-readable recording medium separate from the memory 110. Such a separate computer-readable recording medium may include a computer-readable recording medium such as a floppy drive, disk, tape, DVD/CD-ROM drive, and memory card. In another embodiment, software components may be loaded into the memory 110 through a communication interface 130 other than a computer-readable recording medium. For example, software components may be loaded into the memory 110 of the computer system 100 based on a computer program installed by files received over the network 160.
프로세서(120)는 기본적인 산술, 로직 및 입출력 연산을 수행함으로써, 컴퓨터 프로그램의 명령을 처리하도록 구성될 수 있다. 명령은 메모리(110) 또는 통신 인터페이스(130)에 의해 프로세서(120)로 제공될 수 있다. 예를 들어 프로세서(120)는 메모리(110)와 같은 기록 장치에 저장된 프로그램 코드에 따라 수신되는 명령을 실행하도록 구성될 수 있다.The processor 120 may be configured to process instructions of a computer program by performing basic arithmetic, logic, and input/output operations. Instructions may be provided to the processor 120 by the memory 110 or the communication interface 130. For example, the processor 120 may be configured to execute a command received according to a program code stored in a recording device such as the memory 110.
통신 인터페이스(130)은 네트워크(160)를 통해 컴퓨터 시스템(100)이 다른 장치와 서로 통신하기 위한 기능을 제공할 수 있다. 일례로, 컴퓨터 시스템(100)의 프로세서(120)가 메모리(110)와 같은 기록 장치에 저장된 프로그램 코드에 따라 생성한 요청이나 명령, 데이터, 파일 등이 통신 인터페이스(130)의 제어에 따라 네트워크(160)를 통해 다른 장치들로 전달될 수 있다. 역으로, 다른 장치로부터의 신호나 명령, 데이터, 파일 등이 네트워크(160)를 거쳐 컴퓨터 시스템(100)의 통신 인터페이스(130)를 통해 컴퓨터 시스템(100)으로 수신될 수 있다. 통신 인터페이스(130)를 통해 수신된 신호나 명령, 데이터 등은 프로세서(120)나 메모리(110)로 전달될 수 있고, 파일 등은 컴퓨터 시스템(100)이 더 포함할 수 있는 저장 매체(상술한 영구 저장 장치)로 저장될 수 있다.The communication interface 130 may provide a function for the computer system 100 to communicate with other devices through the network 160. For example, a request, command, data, file, etc., generated by the processor 120 of the computer system 100 according to a program code stored in a recording device such as the memory 110, is transmitted to the network according to the control of the communication interface 130. 160) can be delivered to other devices. Conversely, signals, commands, data, files, etc. from other devices may be received by the computer system 100 through the communication interface 130 of the computer system 100 via the network 160. Signals, commands, data, etc. received through the communication interface 130 may be transmitted to the processor 120 or the memory 110, and files, etc. may be further included in the computer system 100 (as described above). Permanent storage).
통신 방식은 제한되지 않으며, 네트워크(160)가 포함할 수 있는 통신망(일례로, 이동통신망, 유선 인터넷, 무선 인터넷, 방송망)을 활용하는 통신 방식뿐만 아니라 기기들간의 근거리 유선/무선 통신 역시 포함될 수 있다. 예를 들어, 네트워크(160)는, PAN(personal area network), LAN(local area network), CAN(campus area network), MAN(metropolitan area network), WAN(wide area network), BBN(broadband network), 인터넷 등의 네트워크 중 하나 이상의 임의의 네트워크를 포함할 수 있다. 또한, 네트워크(160)는 버스 네트워크, 스타 네트워크, 링 네트워크, 메쉬 네트워크, 스타-버스 네트워크, 트리 또는 계층적(hierarchical) 네트워크 등을 포함하는 네트워크 토폴로지 중 임의의 하나 이상을 포함할 수 있으나, 이에 제한되지 않는다.The communication method is not limited, and not only a communication method using a communication network (for example, a mobile communication network, wired Internet, wireless Internet, broadcasting network) that the network 160 may include, but also short-range wired/wireless communication between devices may be included. have. For example, the network 160 includes a personal area network (PAN), a local area network (LAN), a campus area network (CAN), a metropolitan area network (MAN), a wide area network (WAN), and a broadband network (BBN). , Internet, and the like. In addition, the network 160 may include any one or more of a network topology including a bus network, a star network, a ring network, a mesh network, a star-bus network, a tree or a hierarchical network, etc. Not limited.
입출력 인터페이스(140)는 입출력 장치(150)와의 인터페이스를 위한 수단일 수 있다. 예를 들어, 입력 장치는 마이크, 키보드, 카메라 또는 마우스 등의 장치를, 그리고 출력 장치는 디스플레이, 스피커와 같은 장치를 포함할 수 있다. 다른 예로 입출력 인터페이스(140)는 터치스크린과 같이 입력과 출력을 위한 기능이 하나로 통합된 장치와의 인터페이스를 위한 수단일 수도 있다. 입출력 장치(150)는 컴퓨터 시스템(100)과 하나의 장치로 구성될 수도 있다.The input/output interface 140 may be a means for an interface with the input/output device 150. For example, the input device may include a device such as a microphone, keyboard, camera, or mouse, and the output device may include a device such as a display and a speaker. As another example, the input/output interface 140 may be a means for interfacing with a device in which input and output functions are integrated into one, such as a touch screen. The input/output device 150 may be configured with the computer system 100 and one device.
또한, 다른 실시예들에서 컴퓨터 시스템(100)은 도 1의 구성요소들보다 더 적은 혹은 더 많은 구성요소들을 포함할 수도 있다. 그러나, 대부분의 종래기술적 구성요소들을 명확하게 도시할 필요성은 없다. 예를 들어, 컴퓨터 시스템(100)은 상술한 입출력 장치(150) 중 적어도 일부를 포함하도록 구현되거나 또는 트랜시버(transceiver), GPS(Global Positioning System) 모듈, 카메라, 각종 센서, 데이터베이스 등과 같은 다른 구성요소들을 더 포함할 수도 있다. 보다 구체적인 예로, 컴퓨터 시스템(100)이 지도 작성을 위한 이동로봇 형태로 구현될 수 있으며, 지도 작성에 필요한 카메라 모듈, 라이다 센서, 가속도 센서나 자이로 센서, 각종 물리적인 버튼, 터치패널을 이용한 버튼, 입출력 포트 등의 다양한 구성요소들이 컴퓨터 시스템(100)에 더 포함되도록 구현될 수 있다.Further, in other embodiments, the computer system 100 may include fewer or more components than the components of FIG. 1. However, there is no need to clearly show most of the prior art components. For example, the computer system 100 may be implemented to include at least some of the input/output devices 150 described above, or other components such as a transceiver, a global positioning system (GPS) module, a camera, various sensors, and a database. May include more. As a more specific example, the computer system 100 may be implemented in the form of a mobile robot for creating a map, and a camera module, a lidar sensor, an acceleration sensor or a gyro sensor, various physical buttons, and buttons using a touch panel required for mapping , Input/output ports, and the like may be implemented to be further included in the computer system 100.
본 발명은 이미지 기반 측위(visual localization) 기술에 관한 것으로, 실내 지도는 물론이고 실외 지도에 모두 적용 가능한 기술이다.The present invention relates to an image-based positioning (visual localization) technology, and is a technology applicable to both indoor and outdoor maps.
이미지 기반 측위를 위해서는 해당되는 지역의 3차원 구조를 알아야 한다. 여기서, 3차원 구조는 이미지의 특정 픽셀에 대응되는 3차원 좌표를 포함할 수 있고, 또한 이미지의 깊이 값을 포함할 수 있다. 다시 말해, 3차원 구조를 안다는 것은 이미지의 3차원 좌표와 깊이 값을 안다는 것과 동일한 의미이다.For image-based positioning, it is necessary to know the 3D structure of the corresponding area. Here, the 3D structure may include 3D coordinates corresponding to a specific pixel of the image, and may also include a depth value of the image. In other words, knowing the three-dimensional structure is equivalent to knowing the three-dimensional coordinates and depth values of an image.
일반적으로, SfM(structure from motion)과 같은 기술을 통해 RGB 이미지를 이용하여 3차원 구조를 얻을 수 있다. 그러나, 이미지만을 이용하는 경우 스케일 값을 얻을 수 없고 깊이 값의 경우 추정 값에 불과하여 정확도가 떨어진다.In general, a 3D structure can be obtained using an RGB image through a technology such as SfM (structure from motion). However, in the case of using only an image, a scale value cannot be obtained, and in the case of a depth value, it is only an estimated value, so accuracy is poor.
깊이 센서가 부착된 RGB-D 이미지 센서를 이용하는 것이 가능하기는 하나, RGB-D 이미지 센서의 경우 깊이 값의 잡음이 매우 심하다는 단점이 있고, 깊이에 대해 센싱 가능한 범위(range)가 제한적이기 때문에 실외 지도 작성에는 사용이 불가능하다.Although it is possible to use an RGB-D image sensor with a depth sensor attached, the RGB-D image sensor has a disadvantage in that the noise of the depth value is very severe, and the range that can be sensed for the depth is limited. It cannot be used for outdoor mapping.
본 발명의 실시예들은 이미지와 함께 라이다 스캔 데이터를 이용하여 이미지의 깊이를 정밀하게 구하는 방법에 관한 것이다.Embodiments of the present invention relate to a method of accurately obtaining the depth of an image using lidar scan data together with an image.
도 2는 본 발명의 일실시예에 따른 컴퓨터 시스템의 프로세서가 포함할 수 있는 구성요소의 예를 도시한 도면이고, 도 3은 본 발명의 일실시예에 따른 컴퓨터 시스템이 수행할 수 있는 깊이 정보 향상 방법의 예를 도시한 순서도이다.FIG. 2 is a diagram showing an example of components that can be included in a processor of a computer system according to an embodiment of the present invention, and FIG. 3 is depth information that can be performed by a computer system according to an embodiment of the present invention. It is a flow chart showing an example of the improvement method.
도 2에 도시된 바와 같이, 프로세서(120)는 데이터 획득부(201), 지도 생성부(202), 깊이 정보 획득부(203), 및 깊이 정보 정제부(204)를 포함할 수 있다. 이러한 프로세서(120)의 구성요소들은 적어도 하나의 프로그램 코드에 의해 제공되는 제어 명령에 따라 프로세서(120)에 의해 수행되는 서로 다른 기능들(different functions)의 표현들일 수 있다. 예를 들어, 프로세서(120)가 카메라와 라이다로부터 데이터를 획득하도록 컴퓨터 시스템(100)을 제어하기 위해 동작하는 기능적 표현으로서 데이터 획득부(201)가 사용될 수 있다.As shown in FIG. 2, the processor 120 may include a data acquisition unit 201, a map generation unit 202, a depth information acquisition unit 203, and a depth information refiner 204. Components of the processor 120 may be expressions of different functions performed by the processor 120 according to a control command provided by at least one program code. For example, the data acquisition unit 201 may be used as a functional representation that the processor 120 operates to control the computer system 100 to acquire data from a camera and a lidar.
프로세서(120) 및 프로세서(120)의 구성요소들은 도 3의 깊이 정보 향상 방법이 포함하는 단계들(S310 내지 S340)을 수행할 수 있다. 예를 들어, 프로세서(120) 및 프로세서(120)의 구성요소들은 메모리(110)가 포함하는 운영체제의 코드와 상술한 적어도 하나의 프로그램 코드에 따른 명령(instruction)을 실행하도록 구현될 수 있다. 여기서, 적어도 하나의 프로그램 코드는 깊이 정보 향상 방법을 처리하기 위해 구현된 프로그램의 코드에 대응될 수 있다.The processor 120 and components of the processor 120 may perform steps S310 to S340 included in the method of improving depth information of FIG. 3. For example, the processor 120 and the components of the processor 120 may be implemented to execute an instruction according to the code of the operating system included in the memory 110 and the at least one program code described above. Here, at least one program code may correspond to a code of a program implemented to process the depth information enhancement method.
깊이 정보 향상 방법은 도시된 순서대로 발생하지 않을 수 있으며, 단계들 중 일부가 생략되거나 추가의 과정이 더 포함될 수 있다.The depth information enhancement method may not occur in the illustrated order, and some of the steps may be omitted or an additional process may be further included.
프로세서(120)는 깊이 정보 향상 방법을 위한 프로그램 파일에 저장된 프로그램 코드를 메모리(110)에 로딩할 수 있다. 예를 들어, 깊이 정보 향상 방법을 위한 프로그램 파일은 메모리(110)와는 구분되는 영구 저장 장치에 저장되어 있을 수 있고, 프로세서(120)는 버스를 통해 영구 저장 장치에 저장된 프로그램 파일로부터 프로그램 코드가 메모리(110)에 로딩되도록 컴퓨터 시스템(100)을 제어할 수 있다. 이때, 프로세서(120) 및 프로세서(120)가 포함하는 데이터 획득부(201), 지도 생성부(202), 깊이 정보 획득부(203), 및 깊이 정보 정제부(204) 각각은 메모리(110)에 로딩된 프로그램 코드 중 대응하는 부분의 명령을 실행하여 이후 단계들(S310 내지 S340)을 실행하기 위한 프로세서(120)의 서로 다른 기능적 표현들일 수 있다. 단계들(S310 내지 S340)의 실행을 위해, 프로세서(120) 및 프로세서(120)의 구성요소들은 직접 제어 명령에 따른 연산을 처리하거나 또는 컴퓨터 시스템(100)을 제어할 수 있다.The processor 120 may load a program code stored in a program file for a method of improving depth information into the memory 110. For example, a program file for a method for improving depth information may be stored in a permanent storage device separate from the memory 110, and the processor 120 stores program codes from a program file stored in a permanent storage device through a bus. Computer system 100 can be controlled to be loaded onto 110. At this time, each of the data acquisition unit 201, the map generation unit 202, the depth information acquisition unit 203, and the depth information refiner 204 included in the processor 120 and the processor 120 is a memory 110 It may be different functional expressions of the processor 120 for executing the subsequent steps (S310 to S340) by executing an instruction of a corresponding part of the program code loaded in the. In order to execute the steps S310 to S340, the processor 120 and components of the processor 120 may directly process an operation according to a control command or control the computer system 100.
단계(S310)에서 데이터 획득부(201)는 카메라를 통해 지도 작성을 위한 이미지를 획득함과 동시에 라이다 센서를 통해 라이다 스캔 데이터를 획득할 수 있다. 본원은 카메라 이미지와 라이다 스캔 데이터로부터 카메라에 해당하는 픽셀들에 대한 3차원 포인트를 재건함으로써 3차원 구조를 생성할 수 있다. 이를 위해, 데이터 획득부(201)는 실내 혹은 실외의 지도 작성을 위한 이동로봇을 통해 이미지와 라이다 스캔 데이터를 함께 획득할 수 있다. 라이다 센서로부터 획득하는 깊이 정보는 실측치로서 매우 정확하다는 점에서 실내 지도는 물론이고, 실외 지도 작성에서 활용 가능하다. 이때, 데이터 획득부(201)는 타임스탬프(timestamp) 별로 카메라 이미지와 라이다 스캔 데이터를 동시에 얻을 수 있다. 다시 말해, 데이터 획득부(201)는 타임스탬프를 이용하여 동시간대의 이미지와 라이다 스캔 데이터를 획득할 수 있다.In step S310, the data acquisition unit 201 may acquire an image for creating a map through the camera and acquire lidar scan data through a lidar sensor. In the present application, a 3D structure may be generated by reconstructing 3D points for pixels corresponding to the camera from the camera image and lidar scan data. To this end, the data acquisition unit 201 may acquire an image and lidar scan data together through a mobile robot for creating an indoor or outdoor map. The depth information obtained from the lidar sensor is very accurate as an actual measurement value, so it can be used not only for indoor maps but also for outdoor maps. In this case, the data acquisition unit 201 may simultaneously obtain a camera image and lidar scan data for each timestamp. In other words, the data acquisition unit 201 may acquire an image and lidar scan data in the same time zone using the time stamp.
단계(S320)에서 지도 생성부(202)는 단계(S310)에서 획득한 라이다 스캔 데이터를 이용하여 포즈(pose)가 태깅된 3차원 지도를 생성할 수 있다. 지도 생성부(202)에서 생성된 이미지의 포즈 정보(3축 위치 값과 3축 방향 값을 포함함)를 바탕으로 VL(visual localization)을 수행할 수 있다.In step S320, the map generator 202 may generate a 3D map to which a pose is tagged by using the lidar scan data acquired in step S310. Visual localization (VL) may be performed based on pose information (including a 3-axis position value and a 3-axis direction value) of an image generated by the map generator 202.
도 4는 본 발명의 일실시예에 있어서 라이다 SLAM을 통한 포즈 태깅 과정의 일례를 설명하기 위한 도면이다.4 is a view for explaining an example of a pose tagging process through the LIDA SLAM in an embodiment of the present invention.
일례로, 도 4를 참조하면 지도 생성부(202)는 라이다 스캔 데이터를 이용하여 라이다 SLAM을 수행함으로써 이미지들의 포즈 정보를 획득할 수 있고 이미지들의 포즈가 태깅된 데이터로서 포인트 클라우드 맵(point cloud map)을 생성할 수 있다. 라이다 SLAM을 수행함에 따라 3차원 지도가 만들어지게 되는데, 이때 라이다 SLAM을 통한 포즈 태깅에 따라 지도의 3차원 구조 상에서 각 이미지의 포즈가 태깅된 포인트 클라우드 맵이 만들어진다.As an example, referring to FIG. 4, the map generator 202 may obtain pose information of images by performing a lidar SLAM using lidar scan data, and poses of the images are tagged as point cloud maps. cloud map). As the LIDA SLAM is performed, a 3D map is created. In this case, a point cloud map in which the poses of each image are tagged is created on the 3D structure of the map according to pose tagging through the LIDA SLAM.
이러한 이미지의 포즈 정보와 라이다 센서로 만들어진 3차원 구조는 이미지의 각 픽셀에 해당하는 3차원 포인트를 얻기 위해 이용될 수 있다.The pose information of the image and the 3D structure made of the lidar sensor can be used to obtain a 3D point corresponding to each pixel of the image.
다시 도 3에서, 단계(S330)에서 깊이 정보 획득부(203)는 동시간대의 이미지와 라이다 스캔 데이터를 이용하여 해당 이미지에서 추출된 특징점의 깊이 정보를 획득할 수 있다. 이때, 깊이 정보 획득부(203)는 카메라의 파라미터를 이용하여 카메라의 렌즈로부터 이미지의 특정 픽셀까지의 벡터를 계산하는 방식을 통해 이미지의 깊이 정보를 획득할 수 있다. 본 발명은 라이다 스캔 데이터를 이용하여 이미지의 깊이 정보를 정밀하게 구함으로써 더욱 정확한 지도 작성이 가능하다. 라이다 스캔 데이터를 이용한 깊이 정보 획득 과정은 이하에서 구체적으로 설명하기로 한다.In FIG. 3 again, in step S330, the depth information acquisition unit 203 may acquire depth information of a feature point extracted from the corresponding image by using the image and lidar scan data in the same time zone. In this case, the depth information acquisition unit 203 may obtain depth information of the image by calculating a vector from the lens of the camera to a specific pixel of the image using the parameter of the camera. According to the present invention, it is possible to create a more accurate map by accurately obtaining depth information of an image using the lidar scan data. A process of obtaining depth information using lidar scan data will be described in detail below.
단계(S340)에서 깊이 정보 정제부(204)는 깊이 정보를 가진 복수의 이미지를 이용하여 깊이 정보를 정제할 수 있다. 하나의 이미지에서 추출된 특징점이 다음 이미지에서 중복으로 추출되는 문제를 해결하기 위한 것으로 각 특징점의 3차원 포인트 및 이미지들의 포즈를 이용하여 기존에 계산된 3차원 포인트를 수정함으로써 깊이 정보를 최적화할 수 있다. 일례로, 깊이 정보 정제부(204)는 일괄 조정법(bundle adjustment)과 같은 최적화 기법을 이용하여 카메라의 파라미터와 주어진 3차원 포인트에 대응되는 절대 좌표를 결정함으로써 중복으로 추출된 특징점의 깊이 값을 정제할 수 있다. 이때, 깊이 정보 정제부(204)는 복수의 이미지들과 각 이미지에서 추출된 특징점의 3차원 포인트 및 그 관계를 바탕으로 이미지들의 픽셀 에러를 활용하여 에러를 최적화하는 방향으로 포인트와 이미지들의 포즈를 추정할 수 있다.In step S340, the depth information refiner 204 may refine depth information by using a plurality of images having depth information. This is to solve the problem that the feature points extracted from one image are redundantly extracted from the next image, and depth information can be optimized by modifying the previously calculated 3D points using the 3D points of each feature point and the poses of the images. have. For example, the depth information refiner 204 refines the depth value of the duplicated feature point by determining the camera parameter and the absolute coordinate corresponding to the given 3D point using an optimization technique such as a bundle adjustment method. can do. At this time, the depth information refiner 204 uses the pixel error of the images based on the three-dimensional points of the plurality of images and the feature points extracted from each image, and the relationship to pose the points and images in a direction to optimize the error. Can be estimated.
도 5는 본 발명의 일실시예에 있어서 이미지의 특징점의 깊이 정보를 획득하는 과정의 일례를 설명하기 위한 도면이다.5 is a view for explaining an example of a process of obtaining depth information of a feature point of an image according to an embodiment of the present invention.
도 5를 참조하면, 단계(S501)에서 깊이 정보 획득부(203)는 이미지에서 특정 픽셀에 해당하는 특징점(keypoint)을 추출할 수 있다. 이때, 특징점은 이미지 상에서 회전(rotation)과 크기(scale)에 불변하는 특성을 가진 픽셀을 의미하는 것으로, 예를 들어 깊이 정보 획득부(203)는 SIFT(Scale-Invariant Feature Transform), FAST(Features from Accelerated Segment Test), BRIEF(Binary Robust Independent Elementary Features), ORB(Oriented FAST and Rotated BRIEF) 등 널리 이용되고 있는 특징점 추출 알고리즘을 이용하여 이미지에서 특징점을 추출할 수 있다.Referring to FIG. 5, in step S501, the depth information acquisition unit 203 may extract a keypoint corresponding to a specific pixel from an image. In this case, the feature point refers to a pixel having a characteristic that is invariant to rotation and scale on an image. For example, the depth information acquisition unit 203 includes Scale-Invariant Feature Transform (SIFT) and Features (FAST). From Accelerated Segment Test), BRIEF (Binary Robust Independent Elementary Features), ORB (Oriented FAST and Rotated BRIEF), the feature points can be extracted from the image using widely used feature point extraction algorithms.
도 6은 특징점 추출 결과 예시를 도시한 것으로, 이미지(600) 상에서 회전과 크기에 불변하는 특징점(601)을 확인할 수 있다.6 shows an example of a result of extracting a feature point, and a feature point 601 that is invariant in rotation and size on the image 600 can be identified.
다시 도 5에서, 단계(S502)에서 깊이 정보 획득부(203)는 이미지를 획득한 시점을 기준으로 특정 시간 내에 획득한 라이다 스캔 데이터를 축적함으로써 포인트 클라우드를 구성할 수 있다. 깊이 정보 획득부(203)는 동일 시점, 즉 이미지를 획득한 시점에 함께 획득한 라이다 스캔 데이터로 라이다 포인트 클라우드를 구성할 수 있다.In FIG. 5 again, in step S502, the depth information acquisition unit 203 may configure a point cloud by accumulating lidar scan data acquired within a specific time based on the time point at which the image was acquired. The depth information acquisition unit 203 may configure a lidar point cloud using lidar scan data acquired at the same time point, that is, at the time point at which the image is acquired.
도 7은 도 6의 이미지(600)에 대해 동시간대에 획득한 라이다 스캔 데이터로 구성된 라이다 포인트 클라우드(700)의 예시를 나타낸 것이다.FIG. 7 shows an example of a lidar point cloud 700 configured with lidar scan data acquired at the same time for the image 600 of FIG. 6.
다시 도 5에서, 단계(S503)에서 깊이 정보 획득부(203)는 단계(S502)에서 구성된 포인트 클라우드에서 이미지의 포즈 정보에 대응되는 뷰 영역(view frustum)의 포인트 클라우드를 추출할 수 있다. 깊이 정보 획득부(203)는 연산 시간의 최적화를 위하여 모든 포인트 클라우드를 사용하지 않고 이미지의 포즈 정보를 이용하여 해당 뷰에 맞는 포인트 클라우드만을 추출할 수 있다.In FIG. 5 again, in step S503, the depth information acquisition unit 203 may extract a point cloud of a view frustum corresponding to the pose information of the image from the point cloud configured in step S502. The depth information acquisition unit 203 may extract only a point cloud suitable for a corresponding view by using the pose information of the image without using all the point clouds to optimize the computation time.
도 8은 본 발명의 일실시예에 있어서 라이다 포인트 클라우드에 대한 뷰 영역 컬링(culling) 과정을 설명하기 위한 예시 도면이다.8 is an exemplary diagram for explaining a view area culling process for a LiDAR point cloud according to an embodiment of the present invention.
도 8을 참조하면, 깊이 정보 획득부(203)는 이미지와 동시간대에 획득한 라이다 스캔 데이터에 의해 구성된 로우 포인트 클라우드(700)를 카메라의 FOV(field of view)에 맞추어 필터링함으로써 이미지 포즈 정보의 뷰 영역에 맞추어 컬링된 포인트 클라우드(800)를 획득할 수 있다.Referring to FIG. 8, the depth information acquisition unit 203 filters the low point cloud 700 configured by the lidar scan data acquired at the same time as the image according to the field of view (FOV) of the camera to provide image pose information. A culled point cloud 800 according to the view area of may be obtained.
다시 도 5에서, 단계(S504)에서 깊이 정보 획득부(203)는 단계(S503)에서 추출된 포인트 클라우드에서 카메라의 렌즈와 이미지에서 추출된 특징점을 잇는 연장선 상에 존재하는 포인트를 해당 특징점의 깊이 정보에 해당되는 3차원 좌표로 활용할 수 있다.In FIG. 5 again, in step S504, the depth information acquisition unit 203 determines a point existing on the extension line connecting the lens of the camera and the feature point extracted from the image in the point cloud extracted in step S503. It can be used as a 3D coordinate corresponding to information.
이를 위해 먼저, 깊이 정보 획득부(203)는 도 9에 도시한 바와 같이 특징점의 이미지 좌표(p) 및 포인트 클라우드 맵을 구형 좌표계(spherical coordinate)
Figure PCTKR2020009992-appb-img-000001
로 변경할 수 있다.
To this end, first, the depth information acquisition unit 203 converts the image coordinate p and the point cloud map of the feature point into a spherical coordinate system as shown in FIG. 9.
Figure PCTKR2020009992-appb-img-000001
Can be changed to.
직교 좌표계(x,y,z)를 구형 좌표계
Figure PCTKR2020009992-appb-img-000002
로 변경하는 것은 수학식 1과 같다.
Rectangular coordinate system (x,y,z)
Figure PCTKR2020009992-appb-img-000002
Changing to is the same as in Equation 1.
[수학식 1][Equation 1]
Figure PCTKR2020009992-appb-img-000003
Figure PCTKR2020009992-appb-img-000003
Figure PCTKR2020009992-appb-img-000004
Figure PCTKR2020009992-appb-img-000004
Figure PCTKR2020009992-appb-img-000005
Figure PCTKR2020009992-appb-img-000005
구형 좌표계
Figure PCTKR2020009992-appb-img-000006
를 직교 좌표계(x,y,z)로 변경하는 것은 수학식 2와 같다.
Spherical coordinate system
Figure PCTKR2020009992-appb-img-000006
To change to the Cartesian coordinate system (x,y,z) is shown in Equation 2.
[수학식 2][Equation 2]
Figure PCTKR2020009992-appb-img-000007
Figure PCTKR2020009992-appb-img-000007
Figure PCTKR2020009992-appb-img-000008
Figure PCTKR2020009992-appb-img-000008
Figure PCTKR2020009992-appb-img-000009
Figure PCTKR2020009992-appb-img-000009
이때, 깊이 정보 획득부(203)는
Figure PCTKR2020009992-appb-img-000010
은 무시하고
Figure PCTKR2020009992-appb-img-000011
만을 이용하여 가장 인접한 포인트를 특징점의 3차원 포인트로 활용할 수 있다.
At this time, the depth information acquisition unit 203
Figure PCTKR2020009992-appb-img-000010
Ignore
Figure PCTKR2020009992-appb-img-000011
The nearest point can be used as a 3D point of a feature point by using only.
깊이 정보 획득부(203)는 광선 투사법(ray casting)을 기반으로 깊이 연계(association)를 수행함으로써 깊이 정보를 획득할 수 있다. 광선 투사법은 이미지의 한 픽셀 지점을 통과하는 시선 방향(view ray)을 검사하는 것으로, 장면 객체(scene object)가 시선과 교차하는지 확인하여 각 픽셀에 대해 픽셀과 가장 가까운 교점을 찾는 것이다.The depth information acquisition unit 203 may acquire depth information by performing depth association based on ray casting. The ray projection method examines a view ray passing through a pixel point in an image, and checks whether a scene object intersects the line of sight to find the closest intersection point to the pixel for each pixel.
도 10을 참조하면, 광선 투사법은 가시면(view plane)을 검출하기 위한 것으로, 카메라의 렌즈에서부터 시선이 출발한다고 가정하고 이미지의 한 픽셀 지점을 통과하는 시선 경로를 막고 있는 가장 가까운 물체를 찾는 것이다. 즉, 어떤 물체의 표면이 광원을 향하고 있을 때 빛이 이 표면에 닿는다면 빛은 차단되지 않았거나 그림자를 만들거나 둘 중 하나이다. 이때, 표면의 음영은 널리 알려진 음영 처리 기법을 사용하여 계산할 수 있다. 음영 처리 기법 중 하나인 깊이 버퍼 알고리즘은 표면을 한번에 하나씩 처리하고 모든 투영점에 대해 깊이 값을 계산한다. 계산된 표면의 깊이는 해당 픽셀에서 보이는 면을 판단하기 위해 앞서 저장된 깊이 값과 비교한다. 이러한 광선 투사법은 이미지의 픽셀을 중심으로 하나씩 처리하며 해당 픽셀에 이르는 투영 경로 상의 모든 표면의 깊이를 계산할 수 있다.Referring to FIG. 10, the ray projection method is for detecting the view plane, and assuming that the line of sight starts from the lens of the camera, the closest object blocking the line of sight path passing through one pixel point of the image is found. . That is, if the surface of an object is facing a light source and light hits this surface, the light is either unblocked or creates a shadow. In this case, the shading of the surface can be calculated using a widely known shading technique. One of the shading techniques, the depth buffer algorithm, processes surfaces one at a time and calculates depth values for all projection points. The calculated depth of the surface is compared with the previously stored depth value to determine the surface visible from the pixel. These ray projections process each pixel in the image, one by one, and calculate the depth of any surface on the projection path leading to that pixel.
더 나아가, 포인트 클라우드를 이용하여 특징점의 깊이 정보를 획득하기 위해서는 포인트를 빠르게 찾는 것이 중요하다.Furthermore, it is important to quickly find a point in order to acquire depth information of a feature point using a point cloud.
깊이 정보 획득부(203)는 단계(S503)에서 추출된 포인트 클라우드에서 특징점의 3차원 포인트로 활용하고자 하는 포인트를 빠르게 찾기 위해 다차원 트리 구조(KD-tree)를 이용한 NNS(nearest neigbor search)을 수행할수 있다.The depth information acquisition unit 203 performs NNS (nearest neigbor search) using a multidimensional tree structure (KD-tree) to quickly find a point to be used as a 3D point of a feature point in the point cloud extracted in step S503. can do.
도 11은 NNS을 위한 다차원 트리 구조의 예시를 도시한 것이다. 도 11은 설명의 편의를 위해 2차원 공간 분할을 나타낸 것이다.11 shows an example of a multidimensional tree structure for NNS. 11 illustrates a two-dimensional space division for convenience of description.
다차원 트리 구조는 BST(binary search tree)를 다차원 공간으로 확장한 것으로, 트리의 레벨 차원을 번걸아가며 비교하기 위해 사용된다. 다차원 트리 구조는 한번에 한 축을 따라 영역을 분할하고 각 하위 단계에서 순환 방식으로 축을 변경한 하위 계층 구조를 가진다.The multi-dimensional tree structure is an extension of the binary search tree (BST) to a multi-dimensional space, and is used to compare the tree levels in turn. The multidimensional tree structure has a sub-hierarchical structure that divides an area along one axis at a time and changes the axis in a circular manner at each sub-level.
도 11을 참조하면, Y 평면에 대해 X축을 먼저 분할한 다음 X 평면에 대해 Y축을 분할한다. 분할 평면이 X→Y 순으로 선택되는 것으로 가정하면, 최상위 루트에서 선택한 x 00보다 작거나 같은 x 좌표를 갖는 모든 포인트는 왼쪽 노드로 구성하고 x 좌표보다 큰 포인트는 오른쪽 노드로 구성할 수 있다. 하위 노드의 포인트는 y 좌표 값 y 01 및 y 11을 사용하여 분할된다. 좌표값의 첨자 중 첫번째 첨자는 가장 왼쪽 노드에 대해 0부터 시작하여 같은 레벨 내에서 노드의 위치를 나타내고, 두 번째 첨자는 노드가 있는 레벨을 나타낸다.Referring to FIG. 11, the X axis is first divided with respect to the Y plane, and then the Y axis is divided with respect to the X plane. Assuming that the dividing plane is selected in the order of X→Y, all points with x coordinates less than or equal to x 00 selected from the highest root can be configured as left nodes, and points larger than x coordinates can be configured as right nodes. The points of the lower node are divided using y coordinate values y 01 and y 11 . Among the subscripts of the coordinate values, the first subscript indicates the position of the node within the same level starting from 0 for the leftmost node, and the second subscript indicates the level where the node is located.
도 12는 도 11의 트리 구조를 이용하여 픽셀 좌표 P와 가장 가까운 포인트를 찾는 과정을 나타낸 것이다.12 shows a process of finding a point closest to the pixel coordinate P using the tree structure of FIG. 11.
도 12를 참조하면, P를 포함하는 노드에서 인근 노드로 이동해가며 P에서 가장 가까운 포인트를 찾는 것부터 시작한다. 두 포인트 사이의 거리의 제곱 값 중 최소 값을 찾기 위해 P를 중심으로 하는 구를 사용할 수 있으며, 노드 정보가 P를 중심으로 하는 구와 겹치면 P와 해당 노드 상의 포인트의 제곱 거리를 계산하고 가장 낮은 값을 저장한다. P를 중심으로 하는 구와 겹치는 모든 노드에 대한 검색이 완료될 때까지 반복한 후 저장된 값 중 가장 작은 값을 P와 가장 가까운 이웃 포인트로 결정할 수 있다.Referring to FIG. 12, moving from a node including P to a neighboring node starts by finding a point closest to P. A sphere centered on P can be used to find the smallest of the squared values of the distance between two points. If the node information overlaps the sphere centered on P, the squared distance between P and the point on the node is calculated and the lowest value. Save it. After repeating the search for all nodes overlapping with the sphere centered on P is completed, the smallest value among the stored values may be determined as the nearest neighbor point to P.
따라서, 깊이 정보 획득부(203)는 다차원 트리 구조(KD-tree)를 이용한 NNS을 통해 포인트 클라우드에서 특징점의 3차원 포인트를 보다 빠르게 찾을 수 있다.Accordingly, the depth information acquisition unit 203 may more quickly find the 3D point of the feature point in the point cloud through the NNS using the multidimensional tree structure (KD-tree).
이처럼 본 발명의 실시예들에 따르면, 라이다와 카메라를 이용하여 3차원 구조를 생성함으로써 더욱 정확한 지도를 작성할 수 있으며, 특히 라이다 센서를 통해 획득한 라이다 스캔 데이터를 이용하여 이미지의 깊이를 실측치로 얻을 수 있어 3차원 구조의 깊이 정보를 향상시킬 수 있다.As described above, according to embodiments of the present invention, a more accurate map can be created by generating a three-dimensional structure using a lidar and a camera, and in particular, the depth of an image is determined using lidar scan data obtained through a lidar sensor. Since it can be obtained as an actual value, the depth information of the three-dimensional structure can be improved.
이상에서 설명된 장치는 하드웨어 구성요소, 소프트웨어 구성요소, 및/또는 하드웨어 구성요소 및 소프트웨어 구성요소의 조합으로 구현될 수 있다. 예를 들어, 실시예들에서 설명된 장치 및 구성요소는, 프로세서, 콘트롤러, ALU(arithmetic logic unit), 디지털 신호 프로세서(digital signal processor), 마이크로컴퓨터, FPGA(field programmable gate array), PLU(programmable logic unit), 마이크로프로세서, 또는 명령(instruction)을 실행하고 응답할 수 있는 다른 어떠한 장치와 같이, 하나 이상의 범용 컴퓨터 또는 특수 목적 컴퓨터를 이용하여 구현될 수 있다. 처리 장치는 운영 체제(OS) 및 상기 운영 체제 상에서 수행되는 하나 이상의 소프트웨어 어플리케이션을 수행할 수 있다. 또한, 처리 장치는 소프트웨어의 실행에 응답하여, 데이터를 접근, 저장, 조작, 처리 및 생성할 수도 있다. 이해의 편의를 위하여, 처리 장치는 하나가 사용되는 것으로 설명된 경우도 있지만, 해당 기술분야에서 통상의 지식을 가진 자는, 처리 장치가 복수 개의 처리 요소(processing element) 및/또는 복수 유형의 처리 요소를 포함할 수 있음을 알 수 있다. 예를 들어, 처리 장치는 복수 개의 프로세서 또는 하나의 프로세서 및 하나의 콘트롤러를 포함할 수 있다. 또한, 병렬 프로세서(parallel processor)와 같은, 다른 처리 구성(processing configuration)도 가능하다.The apparatus described above may be implemented as a hardware component, a software component, and/or a combination of a hardware component and a software component. For example, the devices and components described in the embodiments are a processor, a controller, an arithmetic logic unit (ALU), a digital signal processor, a microcomputer, a field programmable gate array (FPGA), a programmable gate array (PLU). It may be implemented using one or more general purpose computers or special purpose computers, such as a logic unit), a microprocessor, or any other device capable of executing and responding to instructions. The processing device may execute an operating system (OS) and one or more software applications executed on the operating system. In addition, the processing device may access, store, manipulate, process, and generate data in response to the execution of software. For the convenience of understanding, although it is sometimes described that one processing device is used, one of ordinary skill in the art, the processing device is a plurality of processing elements and/or multiple types of processing elements. It can be seen that it may include. For example, the processing device may include a plurality of processors or one processor and one controller. In addition, other processing configurations are possible, such as a parallel processor.
소프트웨어는 컴퓨터 프로그램(computer program), 코드(code), 명령(instruction), 또는 이들 중 하나 이상의 조합을 포함할 수 있으며, 원하는 대로 동작하도록 처리 장치를 구성하거나 독립적으로 또는 결합적으로(collectively) 처리 장치를 명령할 수 있다. 소프트웨어 및/또는 데이터는, 처리 장치에 의하여 해석되거나 처리 장치에 명령 또는 데이터를 제공하기 위하여, 어떤 유형의 기계, 구성요소(component), 물리적 장치, 컴퓨터 저장 매체 또는 장치에 구체화(embody)될 수 있다. 소프트웨어는 네트워크로 연결된 컴퓨터 시스템 상에 분산되어서, 분산된 방법으로 저장되거나 실행될 수도 있다. 소프트웨어 및 데이터는 하나 이상의 컴퓨터 판독 가능 기록 매체에 저장될 수 있다.The software may include a computer program, code, instructions, or a combination of one or more of these, configuring the processing unit to behave as desired or processed independently or collectively. You can command the device. Software and/or data may be embodyed in any type of machine, component, physical device, computer storage medium or device to be interpreted by the processing device or to provide instructions or data to the processing device. have. The software may be distributed over networked computer systems and stored or executed in a distributed manner. Software and data may be stored on one or more computer-readable recording media.
실시예에 따른 방법은 다양한 컴퓨터 수단을 통하여 수행될 수 있는 프로그램 명령 형태로 구현되어 컴퓨터 판독 가능 매체에 기록될 수 있다. 이때, 매체는 컴퓨터로 실행 가능한 프로그램을 계속 저장하거나, 실행 또는 다운로드를 위해 임시 저장하는 것일 수도 있다. 또한, 매체는 단일 또는 수 개의 하드웨어가 결합된 형태의 다양한 기록수단 또는 저장수단일 수 있는데, 어떤 컴퓨터 시스템에 직접 접속되는 매체에 한정되지 않고, 네트워크 상에 분산 존재하는 것일 수도 있다. 매체의 예시로는, 하드 디스크, 플로피 디스크 및 자기 테이프와 같은 자기 매체, CD-ROM 및 DVD와 같은 광기록 매체, 플롭티컬 디스크(floptical disk)와 같은 자기-광 매체(magneto-optical medium), 및 ROM, RAM, 플래시 메모리 등을 포함하여 프로그램 명령어가 저장되도록 구성된 것이 있을 수 있다. 또한, 다른 매체의 예시로, 어플리케이션을 유통하는 앱 스토어나 기타 다양한 소프트웨어를 공급 내지 유통하는 사이트, 서버 등에서 관리하는 기록매체 내지 저장매체도 들 수 있다.The method according to the embodiment may be implemented in the form of program instructions that can be executed through various computer means and recorded in a computer-readable medium. In this case, the medium may be one that continuously stores a program executable by a computer, or temporarily stores a program for execution or download. In addition, the medium may be a variety of recording means or storage means in a form in which a single or several pieces of hardware are combined, but is not limited to a medium directly connected to a computer system, but may be distributed on a network. Examples of media include magnetic media such as hard disks, floppy disks, and magnetic tapes, optical recording media such as CD-ROMs and DVDs, magnetic-optical media such as floptical disks, and And a ROM, RAM, flash memory, and the like, and may be configured to store program instructions. In addition, examples of other media include an app store that distributes applications, a site that supplies or distributes various software, and a recording medium or a storage medium managed by a server.
이상과 같이 실시예들이 비록 한정된 실시예와 도면에 의해 설명되었으나, 해당 기술분야에서 통상의 지식을 가진 자라면 상기의 기재로부터 다양한 수정 및 변형이 가능하다. 예를 들어, 설명된 기술들이 설명된 방법과 다른 순서로 수행되거나, 및/또는 설명된 시스템, 구조, 장치, 회로 등의 구성요소들이 설명된 방법과 다른 형태로 결합 또는 조합되거나, 다른 구성요소 또는 균등물에 의하여 대치되거나 치환되더라도 적절한 결과가 달성될 수 있다.As described above, although the embodiments have been described by the limited embodiments and the drawings, various modifications and variations are possible from the above description to those of ordinary skill in the art. For example, the described techniques are performed in a different order from the described method, and/or components such as a system, structure, device, circuit, etc. described are combined or combined in a form different from the described method, or other components Alternatively, even if substituted or substituted by an equivalent, an appropriate result can be achieved.
그러므로, 다른 구현들, 다른 실시예들 및 특허청구범위와 균등한 것들도 후술하는 특허청구범위의 범위에 속한다.Therefore, other implementations, other embodiments, and claims and equivalents fall within the scope of the claims to be described later.

Claims (20)

  1. 컴퓨터 시스템에서 실행되는 방법에 있어서,In the method executed on a computer system,
    상기 컴퓨터 시스템은 메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서를 포함하고,The computer system includes at least one processor configured to execute computer readable instructions contained in a memory,
    상기 방법은,The above method,
    상기 적어도 하나의 프로세서에 의해, 카메라와 라이다(LiDAR) 센서를 통해 지도 작성을 위한 이미지와 라이다 스캔 데이터를 획득하는 단계; 및Acquiring, by the at least one processor, an image for map creation and LiDAR scan data through a camera and a LiDAR sensor; And
    상기 적어도 하나의 프로세서에 의해, 상기 이미지와 함께 상기 라이다 스캔 데이터를 이용하여 상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 단계Obtaining, by the at least one processor, depth information of a feature point extracted from the image by using the lidar scan data together with the image
    를 포함하는 방법.How to include.
  2. 제1항에 있어서,The method of claim 1,
    상기 이미지와 라이다 스캔 데이터를 획득하는 단계는,The step of obtaining the image and lidar scan data,
    타임스탬프(timestamp)를 이용하여 동시간대의 상기 이미지와 상기 라이다 스캔 데이터를 획득하는 것Acquiring the image and the lidar scan data in the same time zone using a timestamp
    을 특징으로 하는 방법.The method characterized by.
  3. 제1항에 있어서,The method of claim 1,
    상기 방법은,The above method,
    상기 적어도 하나의 프로세서에 의해, 상기 라이다 스캔 데이터를 이용하여 포즈(pose)가 태깅된 3차원 지도를 생성하는 단계Generating, by the at least one processor, a 3D map to which a pose is tagged using the lidar scan data
    를 더 포함하는 방법.How to further include.
  4. 제3항에 있어서,The method of claim 3,
    상기 생성하는 단계는,The generating step,
    상기 라이다 스캔 데이터를 이용하여 SLAM(Simultaneous Localization And Map-Building)을 수행함으로써 포즈가 태깅된 포인트 클라우드 맵(point cloud map)을 생성하는 것Creating a point cloud map to which poses are tagged by performing SLAM (Simultaneous Localization And Map-Building) using the lidar scan data
    을 특징으로 하는 방법.The method characterized by.
  5. 제1항에 있어서,The method of claim 1,
    상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 단계는,The step of obtaining depth information of the feature point extracted from the image,
    상기 이미지에서 회전(rotation)과 크기(scale)에 불변하는 특성을 가진 특징점을 추출하는 단계;Extracting feature points having characteristics that are invariant to rotation and scale from the image;
    상기 이미지와 동시간대에 획득한 상기 라이다 스캔 데이터를 축적하여 포인트 클라우드를 구성하는 단계; 및Configuring a point cloud by accumulating the lidar scan data acquired at the same time as the image; And
    상기 포인트 클라우드에서 상기 카메라의 렌즈와 상기 특징점을 잇는 연장선 상에 존재하는 포인트를 상기 특징점의 3차원 좌표로 결정하는 단계Determining a point existing on an extension line connecting the lens of the camera and the feature point in the point cloud as a three-dimensional coordinate of the feature point
    를 포함하는 방법.How to include.
  6. 제5항에 있어서,The method of claim 5,
    상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 단계는,The step of obtaining depth information of the feature point extracted from the image,
    상기 포인트 클라우드에서 상기 이미지의 포즈 정보에 대응되는 뷰 영역(view frustum)의 포인트 클라우드를 추출하는 단계Extracting a point cloud of a view frustum corresponding to the pose information of the image from the point cloud
    를 더 포함하고,Including more,
    상기 특징점의 3차원 좌표로 결정하는 단계는,The step of determining the three-dimensional coordinates of the feature point,
    상기 추출된 뷰 영역의 포인트 클라우드에서 상기 특징점의 3차원 좌표를 결정하는 것Determining the three-dimensional coordinates of the feature point in the extracted point cloud of the view area
    을 특징으로 하는 방법.The method characterized by.
  7. 제5항에 있어서,The method of claim 5,
    상기 특징점의 3차원 좌표로 결정하는 단계는,The step of determining the three-dimensional coordinates of the feature point,
    상기 이미지의 좌표와 상기 포인트 클라우드를 구형 좌표계(spherical coordinate)로 변경하여 상기 특징점의 3차원 좌표를 결정하는 것Changing the coordinates of the image and the point cloud into a spherical coordinate system to determine the three-dimensional coordinates of the feature point
    을 특징으로 하는 방법.The method characterized by.
  8. 제5항에 있어서,The method of claim 5,
    상기 특징점의 3차원 좌표로 결정하는 단계는,The step of determining the three-dimensional coordinates of the feature point,
    광선 투사법(ray casting)을 이용하여 상기 특징점을 통과하는 시선 방향에서 시선과 객체 간의 교점을 찾아 상기 특징점의 3차원 좌표를 결정하는 것Using ray casting to determine the three-dimensional coordinates of the feature point by finding the intersection between the line of sight and the object in the direction of the line of sight passing through the feature point
    을 특징으로 하는 방법.The method characterized by.
  9. 제5항에 있어서,The method of claim 5,
    상기 특징점의 3차원 좌표로 결정하는 단계는,The step of determining the three-dimensional coordinates of the feature point,
    다차원 트리 구조(KD-tree)를 이용한 NNS(nearest neigbor search)을 통해 상기 포인트 클라우드에서 상기 특징점의 3차원 좌표를 찾는 것Finding the three-dimensional coordinates of the feature point in the point cloud through NNS (nearest neigbor search) using a multidimensional tree structure (KD-tree)
    을 특징으로 하는 방법.The method characterized by.
  10. 제1항에 있어서,The method of claim 1,
    상기 방법은,The above method,
    상기 적어도 하나의 프로세서에 의해, 깊이 정보를 가진 복수의 이미지를 이용하여 중복 추출된 특징점의 깊이 정보를 정제하는 단계Refining, by the at least one processor, depth information of duplicated feature points using a plurality of images having depth information
    를 더 포함하는 방법.How to further include.
  11. 제1항 내지 제10항 중 어느 한 항의 방법을 상기 컴퓨터 시스템에 실행시키기 위해 비-일시적인 컴퓨터 판독가능한 기록 매체에 저장되는 컴퓨터 프로그램.A computer program stored on a non-transitory computer readable recording medium for executing the method of any one of claims 1 to 10 on the computer system.
  12. 제1항 내지 제10항 중 어느 한 항의 방법을 컴퓨터에 실행시키기 위한 프로그램이 기록되어 있는 비-일시적인 컴퓨터 판독 가능한 기록 매체.A non-transitory computer-readable recording medium in which a program for executing the method of any one of claims 1 to 10 on a computer is recorded.
  13. 컴퓨터 시스템에 있어서,In a computer system,
    메모리에 포함된 컴퓨터 판독가능한 명령들을 실행하도록 구성된 적어도 하나의 프로세서At least one processor configured to execute computer readable instructions contained in memory
    를 포함하고,Including,
    상기 적어도 하나의 프로세서는,The at least one processor,
    카메라와 라이다(LiDAR) 센서를 통해 지도 작성을 위한 이미지와 라이다 스캔 데이터를 획득하는 데이터 획득부; 및A data acquisition unit that acquires an image for map creation and LiDAR scan data through a camera and a LiDAR sensor; And
    상기 이미지와 함께 상기 라이다 스캔 데이터를 이용하여 상기 이미지에서 추출된 특징점의 깊이 정보를 획득하는 깊이 정보 획득부A depth information acquisition unit that acquires depth information of a feature point extracted from the image by using the lidar scan data together with the image
    를 포함하는 컴퓨터 시스템.Computer system comprising a.
  14. 제13항에 있어서,The method of claim 13,
    상기 적어도 하나의 프로세서는,The at least one processor,
    상기 라이다 스캔 데이터를 이용하여 포즈가 태깅된 3차원 지도를 생성하는 지도 생성부A map generator that generates a 3D map with a pose tagging using the lidar scan data
    를 더 포함하는 컴퓨터 시스템.Computer system further comprising a.
  15. 제13항에 있어서,The method of claim 13,
    상기 적어도 하나의 프로세서는,The at least one processor,
    깊이 정보를 가진 복수의 이미지를 이용하여 중복 추출된 특징점의 깊이 정보를 정제하는 깊이 정보 정제부A depth information refiner that refines the depth information of the duplicated feature points using a plurality of images with depth information
    를 더 포함하는 컴퓨터 시스템.Computer system further comprising a.
  16. 제13항에 있어서,The method of claim 13,
    상기 데이터 획득부는,The data acquisition unit,
    타임스탬프(timestamp)를 이용하여 동시간대의 상기 이미지와 상기 라이다 스캔 데이터를 획득하는 것Acquiring the image and the lidar scan data in the same time zone using a timestamp
    을 특징으로 하는 컴퓨터 시스템.Computer system, characterized in that.
  17. 제13항에 있어서,The method of claim 13,
    상기 깊이 정보 획득부는,The depth information acquisition unit,
    상기 이미지에서 회전과 크기에 불변하는 특성을 가진 특징점을 추출하고,Extracting feature points having characteristics that are invariant to rotation and size from the image,
    상기 이미지와 동시간대에 획득한 상기 라이다 스캔 데이터를 축적하여 포인트 클라우드를 구성하고,Accumulate the lidar scan data acquired at the same time as the image to form a point cloud,
    상기 포인트 클라우드에서 상기 카메라의 렌즈와 상기 특징점을 잇는 연장선 상에 존재하는 포인트를 상기 특징점의 3차원 좌표로 결정하는 것Determining a point existing on an extension line connecting the lens of the camera and the feature point in the point cloud as a three-dimensional coordinate of the feature point
    을 특징으로 하는 컴퓨터 시스템.Computer system, characterized in that.
  18. 제17항에 있어서,The method of claim 17,
    상기 깊이 정보 획득부는,The depth information acquisition unit,
    상기 포인트 클라우드에서 상기 이미지의 포즈 정보에 대응되는 뷰 영역의 포인트 클라우드를 추출하여 상기 추출된 뷰 영역의 포인트 클라우드에서 상기 특징점의 3차원 좌표를 결정하는 것Extracting a point cloud of a view area corresponding to the pose information of the image from the point cloud and determining the three-dimensional coordinates of the feature point from the extracted point cloud of the view area
    을 특징으로 하는 컴퓨터 시스템.Computer system, characterized in that.
  19. 제17항에 있어서,The method of claim 17,
    상기 깊이 정보 획득부는,The depth information acquisition unit,
    광선 투사법을 이용하여 상기 특징점을 통과하는 시선 방향에서 시선과 객체 간의 교점을 찾아 상기 특징점의 3차원 좌표를 결정하는 것Using a ray projection method to determine the three-dimensional coordinates of the feature point by finding the intersection point between the line of sight and the object in the direction of the line of sight passing through the feature point
    을 특징으로 하는 컴퓨터 시스템.Computer system, characterized in that.
  20. 제17항에 있어서,The method of claim 17,
    상기 깊이 정보 획득부는,The depth information acquisition unit,
    다차원 트리 구조(KD-tree)를 이용한 NNS(nearest neigbor search)을 통해 상기 포인트 클라우드에서 상기 특징점의 3차원 좌표를 찾는 것Finding the three-dimensional coordinates of the feature point in the point cloud through NNS (nearest neigbor search) using a multidimensional tree structure (KD-tree)
    을 특징으로 하는 컴퓨터 시스템.Computer system, characterized in that.
PCT/KR2020/009992 2019-08-02 2020-07-29 Method and system using lidar and camera to enhance depth information about image feature point WO2021025364A1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
KR1020190094509A KR20210015516A (en) 2019-08-02 2019-08-02 Method and system for improving depth information of feature points using camera and lidar
KR10-2019-0094509 2019-08-02

Publications (1)

Publication Number Publication Date
WO2021025364A1 true WO2021025364A1 (en) 2021-02-11

Family

ID=74503461

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/KR2020/009992 WO2021025364A1 (en) 2019-08-02 2020-07-29 Method and system using lidar and camera to enhance depth information about image feature point

Country Status (2)

Country Link
KR (1) KR20210015516A (en)
WO (1) WO2021025364A1 (en)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113075683A (en) * 2021-03-05 2021-07-06 上海交通大学 Environment three-dimensional reconstruction method, device and system
WO2023004956A1 (en) * 2021-07-30 2023-02-02 西安交通大学 Laser slam method and system in high-dynamic environment, and device and storage medium

Families Citing this family (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102577907B1 (en) * 2021-03-02 2023-09-14 네이버랩스 주식회사 Method and system of generating 3d map

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR101948728B1 (en) * 2018-09-28 2019-02-15 네이버랩스 주식회사 Method and system for collecting data
KR20190070514A (en) * 2017-12-13 2019-06-21 연세대학교 산학협력단 Apparatus for Building Grid Map and Method there of
KR20190082068A (en) * 2017-12-29 2019-07-09 바이두 온라인 네트웍 테크놀러지 (베이징) 캄파니 리미티드 Method and apparatus for fusing point cloud data
KR20190082070A (en) * 2017-12-29 2019-07-09 바이두 온라인 네트웍 테크놀러지 (베이징) 캄파니 리미티드 Methods and apparatuses for map generation and moving entity localization
KR20190089196A (en) * 2016-11-29 2019-07-30 블랙모어 센서스 앤드 애널리틱스 인코포레이티드 Method and system for classifying objects in a point cloud data set

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20190089196A (en) * 2016-11-29 2019-07-30 블랙모어 센서스 앤드 애널리틱스 인코포레이티드 Method and system for classifying objects in a point cloud data set
KR20190070514A (en) * 2017-12-13 2019-06-21 연세대학교 산학협력단 Apparatus for Building Grid Map and Method there of
KR20190082068A (en) * 2017-12-29 2019-07-09 바이두 온라인 네트웍 테크놀러지 (베이징) 캄파니 리미티드 Method and apparatus for fusing point cloud data
KR20190082070A (en) * 2017-12-29 2019-07-09 바이두 온라인 네트웍 테크놀러지 (베이징) 캄파니 리미티드 Methods and apparatuses for map generation and moving entity localization
KR101948728B1 (en) * 2018-09-28 2019-02-15 네이버랩스 주식회사 Method and system for collecting data

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN113075683A (en) * 2021-03-05 2021-07-06 上海交通大学 Environment three-dimensional reconstruction method, device and system
WO2023004956A1 (en) * 2021-07-30 2023-02-02 西安交通大学 Laser slam method and system in high-dynamic environment, and device and storage medium

Also Published As

Publication number Publication date
KR20210015516A (en) 2021-02-10

Similar Documents

Publication Publication Date Title
WO2021025364A1 (en) Method and system using lidar and camera to enhance depth information about image feature point
KR102347239B1 (en) Method and system for improving depth information of feature points using camera and lidar
US11127203B2 (en) Leveraging crowdsourced data for localization and mapping within an environment
CN110322500B (en) Optimization method and device for instant positioning and map construction, medium and electronic equipment
Wendel et al. Natural landmark-based monocular localization for MAVs
Sola et al. Fusing monocular information in multicamera SLAM
JP6658001B2 (en) Position estimation device, program, position estimation method
WO2016053067A1 (en) 3-dimensional model generation using edges
WO2015005577A1 (en) Camera pose estimation apparatus and method
WO2019240452A1 (en) Method and system for automatically collecting and updating information related to point of interest in real space
WO2021015435A1 (en) Apparatus and method for generating three-dimensional map by using aerial photograph
KR20200118677A (en) Method and system for updating map for pose estimation based on images
WO2021212477A1 (en) Point cloud data correction method, and related device
CN112348886B (en) Visual positioning method, terminal and server
WO2021125578A1 (en) Position recognition method and system based on visual information processing
WO2021075772A1 (en) Object detection method and device using multiple area detection
KR20210019221A (en) Method and system for generating depth information of street view image using 2d map
US11504608B2 (en) 6DoF inside-out tracking game controller
JP2019020778A (en) Information processing device and information processing method
Huttunen et al. A monocular camera gyroscope
WO2021182793A1 (en) Method and apparatus for calibrating different types of sensors using single checkerboard
WO2021206200A1 (en) Device and method for processing point cloud information
WO2021111613A1 (en) Three-dimensional map creation device, three-dimensional map creation method, and three-dimensional map creation program
KR20210051002A (en) Method and apparatus for estimating pose, computer-readable storage medium and computer program for controlling the holder device
WO2023068562A1 (en) Method and device for determining plane for mapping object onto three-dimensional space

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 20850306

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

32PN Ep: public notification in the ep bulletin as address of the adressee cannot be established

Free format text: NOTING OF LOSS OF RIGHTS PURSUANT TO RULE 112(1) EPC (EPO FORM 1205A DATED 30.06.2022)

122 Ep: pct application non-entry in european phase

Ref document number: 20850306

Country of ref document: EP

Kind code of ref document: A1