EP3568970B1 - Optimal scanning trajectories for 3d scenes - Google Patents
Optimal scanning trajectories for 3d scenes Download PDFInfo
- Publication number
- EP3568970B1 EP3568970B1 EP17830063.8A EP17830063A EP3568970B1 EP 3568970 B1 EP3568970 B1 EP 3568970B1 EP 17830063 A EP17830063 A EP 17830063A EP 3568970 B1 EP3568970 B1 EP 3568970B1
- Authority
- EP
- European Patent Office
- Prior art keywords
- camera
- moveable
- trajectory
- scene
- generating
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Active
Links
- 238000000034 method Methods 0.000 claims description 56
- 238000003860 storage Methods 0.000 claims description 31
- 230000015654 memory Effects 0.000 claims description 16
- 238000004891 communication Methods 0.000 description 16
- 239000007787 solid Substances 0.000 description 13
- 238000010586 diagram Methods 0.000 description 9
- 239000011159 matrix material Substances 0.000 description 9
- 238000005516 engineering process Methods 0.000 description 8
- 238000004422 calculation algorithm Methods 0.000 description 6
- 230000003247 decreasing effect Effects 0.000 description 6
- 239000000654 additive Substances 0.000 description 5
- 230000000996 additive effect Effects 0.000 description 5
- 230000007613 environmental effect Effects 0.000 description 5
- 230000006870 function Effects 0.000 description 5
- 238000012545 processing Methods 0.000 description 5
- 238000005259 measurement Methods 0.000 description 4
- 230000003287 optical effect Effects 0.000 description 4
- 230000000007 visual effect Effects 0.000 description 4
- 238000013500 data storage Methods 0.000 description 3
- 238000009826 distribution Methods 0.000 description 3
- 230000008569 process Effects 0.000 description 3
- 238000009827 uniform distribution Methods 0.000 description 3
- 238000004458 analytical method Methods 0.000 description 2
- 230000008901 benefit Effects 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 238000001514 detection method Methods 0.000 description 2
- 230000003467 diminishing effect Effects 0.000 description 2
- 238000005457 optimization Methods 0.000 description 2
- 238000004566 IR spectroscopy Methods 0.000 description 1
- 230000009471 action Effects 0.000 description 1
- 238000013459 approach Methods 0.000 description 1
- 238000013473 artificial intelligence Methods 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 238000003490 calendering Methods 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000004590 computer program Methods 0.000 description 1
- 238000007405 data analysis Methods 0.000 description 1
- 238000007689 inspection Methods 0.000 description 1
- 230000003993 interaction Effects 0.000 description 1
- 238000007726 management method Methods 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 230000007246 mechanism Effects 0.000 description 1
- 230000005055 memory storage Effects 0.000 description 1
- 238000003032 molecular docking Methods 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 238000009304 pastoral farming Methods 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 230000002085 persistent effect Effects 0.000 description 1
- 230000000644 propagated effect Effects 0.000 description 1
- 238000007670 refining Methods 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 230000002441 reversible effect Effects 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
- 239000013589 supplement Substances 0.000 description 1
- 230000001360 synchronised effect Effects 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 230000007723 transport mechanism Effects 0.000 description 1
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/18—Closed-circuit television [CCTV] systems, i.e. systems in which the video signal is not broadcast
- H04N7/183—Closed-circuit television [CCTV] systems, i.e. systems in which the video signal is not broadcast for receiving images from a single remote source
- H04N7/185—Closed-circuit television [CCTV] systems, i.e. systems in which the video signal is not broadcast for receiving images from a single remote source from a mobile camera, e.g. for remote control
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N23/00—Cameras or camera modules comprising electronic image sensors; Control thereof
- H04N23/60—Control of cameras or camera modules
- H04N23/64—Computer-aided capture of images, e.g. transfer from script file into camera, check of taken image quality, advice or proposal for image composition or decision on when to take image
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T19/00—Manipulating 3D models or images for computer graphics
- G06T19/003—Navigation within 3D models or images
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T7/00—Image analysis
- G06T7/70—Determining position or orientation of objects or cameras
- G06T7/73—Determining position or orientation of objects or cameras using feature-based methods
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N13/00—Stereoscopic video systems; Multi-view video systems; Details thereof
- H04N13/10—Processing, recording or transmission of stereoscopic or multi-view image signals
- H04N13/189—Recording image signals; Reproducing recorded image signals
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N23/00—Cameras or camera modules comprising electronic image sensors; Control thereof
- H04N23/60—Control of cameras or camera modules
- H04N23/66—Remote control of cameras or camera parts, e.g. by remote control devices
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N23/00—Cameras or camera modules comprising electronic image sensors; Control thereof
- H04N23/60—Control of cameras or camera modules
- H04N23/66—Remote control of cameras or camera parts, e.g. by remote control devices
- H04N23/661—Transmitting camera control signals through networks, e.g. control via the Internet
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N23/00—Cameras or camera modules comprising electronic image sensors; Control thereof
- H04N23/60—Control of cameras or camera modules
- H04N23/695—Control of camera direction for changing a field of view, e.g. pan, tilt or based on tracking of objects
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N7/00—Television systems
- H04N7/18—Closed-circuit television [CCTV] systems, i.e. systems in which the video signal is not broadcast
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B64—AIRCRAFT; AVIATION; COSMONAUTICS
- B64U—UNMANNED AERIAL VEHICLES [UAV]; EQUIPMENT THEREFOR
- B64U2101/00—UAVs specially adapted for particular uses or applications
- B64U2101/30—UAVs specially adapted for particular uses or applications for imaging, photography or videography
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B64—AIRCRAFT; AVIATION; COSMONAUTICS
- B64U—UNMANNED AERIAL VEHICLES [UAV]; EQUIPMENT THEREFOR
- B64U2201/00—UAVs characterised by their flight controls
- B64U2201/20—Remote controls
-
- B—PERFORMING OPERATIONS; TRANSPORTING
- B64—AIRCRAFT; AVIATION; COSMONAUTICS
- B64U—UNMANNED AERIAL VEHICLES [UAV]; EQUIPMENT THEREFOR
- B64U50/00—Propulsion; Power supply
- B64U50/30—Supply or distribution of electrical power
- B64U50/37—Charging when not in flight
Definitions
- Unmanned aerial vehicles typically have a camera that captures images as it travels a path designed by its operator.
- the UAV may be maneuvered by the operator along a trajectory that enables the camera to capture the scene from a variety of camera positions having different vantage points.
- the scene would be observed in great detail, such that the reconstruction is as accurate and detailed as possible.
- constraints may make such an approach impossible (e.g., limited flight time, storage capacity constraints, etc.).
- a tradeoff may exist between the amount of data that may be collected by the camera and the costs associated with collecting the data.
- US 2015/0112516 A1 discloses technologies for controlling a flight path of a UAV based image capture system for solid modeling.
- images of the structure to be modeled may be captured and surface hypotheses formed for unobserved surfaces based on the captured images.
- a normal vector and a viewing cone may be computed for each hypothesized surface.
- a set of desired locations may be determined based on the viewing cones for the entire structure to be modeled and a least impact path for the UAV determined based on the desired locations and desired flight parameters.
- US 2016/0004795 A1 discloses an UAV system for solar site assessment including generating a three-dimensional model of a solar site based at least in part on data captured by a UAV, importing one or more solar paths into the three-dimensional model based at least in part on a geo-location of the solar site, and determining, one or more solar collection estimates corresponding to one or more locations in the solar site based at least in part on the three-dimensional model and the one or more solar paths.
- US 2010/0268409 A1 discloses a method for inspecting structures that includes using a plurality of independent unmanned mobile vehicles.
- the unmanned mobile vehicles are equipped with a control and guidance system for enabling each unmanned mobile vehicle to operate autonomously.
- Each unmanned mobile vehicle may be programmed with an operating program that defines a path of travel for it, relative to a structure to be inspected.
- the unmanned mobile vehicles are deployed so that they cooperatively form a swarm that travels about the structure. At least one of said unmanned mobile vehicles is used to obtain inspection data of a portion of the structure as it executes its respective operating program.
- Examples of the present disclosure describe systems and methods for generating optimal scanning trajectories for unmanned aerial vehicles (UAVs) that capture 3D scenes using one or more cameras.
- UAVs unmanned aerial vehicles
- a drone or other moveable camera may be used to gather information about the scene.
- the moveable camera may travel an initial trajectory that may be used to gather an initial dataset.
- the initial dataset may be analyzed to generate an optimal scanning trajectory that may then be used by the moveable camera to gather subsequent data. Further analysis of the initial and subsequent data may be performed in order to further refine or optimize a trajectory for scanning the scene. Further iterations and optimizations may be performed, continually refining and improving the flight trajectory based on newly-acquired information about the scene.
- Generating an optimal trajectory may comprise generating a reconstruction of the scene based on previously-acquired data relating to the scene.
- One or more surface points may be generated within the reconstruction.
- a camera position graph may be generated, wherein the camera position graph comprises one or more camera position nodes and edges.
- a subgradient may be determined, wherein the subgradient provides an additive approximation for the marginal reward associated with each camera position node in the camera position graph. The subgradient may then be used to generate an optimal flight trajectory based on the reward and cost associated with the camera position nodes and edges in the camera position graph.
- aspects of the disclosure are described more fully below with reference to the accompanying drawings, which form a part hereof, and which show specific exemplary aspects.
- different aspects of the disclosure may be implemented in many different forms and should not be construed as limited to the aspects set forth herein; rather, these aspects are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the aspects to those skilled in the art.
- aspects may be practiced as methods, systems or devices. Accordingly, aspects may take the form of a hardware implementation, an entirely software implementation or an implementation combining software and hardware aspects. The following detailed description is, therefore, not to be taken in a limiting sense.
- the present disclosure generally relates to generating scanning trajectories for moveable cameras that are configured to scan a scene.
- the data collected from the scan may subsequently be used to create a 3D scene.
- a moveable camera e.g., a drone, UAV, or any other manually- or automatically-positioned camera
- This data then may be used to generate an optimal scanning trajectory for the moveable camera.
- the optimal scanning trajectory may be used to capture additional information relating to the scene.
- the process may be iterative, such that subsequent optimal trajectories for the moveable camera may be generated based on information captured using previously-generated trajectories.
- the process may repeat until a certain threshold is met (e.g., a certain quality or accuracy target is achieved, the size of the captured dataset reaches a predetermined threshold, etc.).
- a certain threshold e.g., a certain quality or accuracy target is achieved, the size of the captured dataset reaches a predetermined threshold, etc.
- the collected information may be used to generate a 3D model of the scene, perform measurements or calculations, among other uses.
- a 3D scene may be a landmark, building, historical monument, or natural attraction, among others.
- a 3D scene may be the interior of a structure (e.g., a room, an office, a mall or other retail space, a vehicle, etc.), the exterior of a structure (e.g., a building, a patio or balcony, etc.), or any combination thereof.
- any type of scene may be scanned without departing from the spirit of this disclosure.
- a trajectory may be designated as "optimal" when the reward and cost associated with the trajectory have been analyzed or evaluated so as to obtain an additional or similar level of reward while incurring a similar or decreased level of cost.
- a reward associated with a trajectory may include the amount and/or quality of information captured, the ease with which the information was captured, or the amount of time required to capture the information, among others.
- a cost associated with a trajectory may include energy requirements of the moveable camera, the skill or maneuverability required in order to implement or navigate the trajectory, the amount of time required to navigate the trajectory, storage capacity requirements of the moveable camera, etc.
- one or more rewards may be evaluated in view of one or more costs, thereby determining a marginal reward.
- a "cost" may in fact be a "reward,” and vice versa.
- the storage capacity of the moveable camera may be constrained in one instance, it may be the case that the reward is measured based on the size of the resulting dataset in another instance.
- one or more factors may be evaluated as both a cost and as a reward.
- the moveable camera may be used to capture a variety of information relating to a 3D scene as it passes over the scene. In some examples, image, video, and/or audio data may be captured.
- the moveable camera may have additional hardware used to capture depth or other geometric information, including, but not limited to, Light Detection and Ranging (LIDAR) sensors, infrared (IR) emitters and/or sensors, or stereoscopic sensors.
- LIDAR Light Detection and Ranging
- IR infrared
- additional information may be gathered, such as data from one or more moveable cameras used when navigating the trajectory (e.g., GPS coordinates, barometric sensor data, attitude, pitch, roll, yaw, altitude, speed, etc.) or environmental data (e.g., climate conditions, wind speed, temperature, visibility, etc.), among other information (e.g., time, date, or information relating to the hardware, trajectory, or 3D scene, among others).
- data from one or more moveable cameras used when navigating the trajectory e.g., GPS coordinates, barometric sensor data, attitude, pitch, roll, yaw, altitude, speed, etc.
- environmental data e.g., climate conditions, wind speed, temperature, visibility, etc.
- time, date e.g., time, date, or information relating to the hardware, trajectory, or 3D scene, among others.
- Figure 1 illustrates an example system 100 for generating optimal trajectories for a moveable camera for capturing images used to create a 3D scene.
- Example system 100 comprises moveable camera 102 and computing device 104.
- Moveable camera 102 may be a UAV, a drone, or other camera. In some examples, moveable camera 102 may be positioned or controlled manually or automatically. While only one moveable camera is shown in Figure 1 , it will be appreciated that multiple moveable cameras may be used without departing from the spirit of this disclosure.
- Computing device 104 is comprised of geometric reconstruction component 106, surface point generation component 108, camera position graph generation component 110, subgradient determination component 112, and trajectory generation component 114.
- Computing device 104 may be a personal computing device, tablet computing device, mobile computing device, or distributed computing device, among others. While computing device 104 is illustrated as separate from moveable camera 102, moveable camera 102 may comprise computing device 104 and one or more of components 106-114. In another example, moveable camera 102 may comprise one or more or components 106-114, while computing device 104 comprises one or more of the other components. In another example, computing device 104 may be a distributed computing device such that multiple computing devices are used to perform the functions of components 106-114. Additionally, components 106-114 may be hardware components, software components, or some combination thereof.
- Moveable camera 102 may provide information relating to a 3D scene to computing device 104. Additionally, computing device 104 may provide one or more trajectories to moveable camera 102. In some examples, computing device 104 may provide the trajectories based on information received from moveable camera 102. In other examples, computing device 104 may provide a trajectory without having received information from moveable camera 102. The trajectory may be based on one or more parameters relating to the 3D scene, including, but not limited to, bounding dimensions for the scene (e.g., as geographical coordinates, measurements, etc.), a zone in which it is safe to operate (e.g., above or within a 3D scene, a specified distance above or away from obstacles, etc.), among others.
- bounding dimensions for the scene e.g., as geographical coordinates, measurements, etc.
- a zone in which it is safe to operate e.g., above or within a 3D scene, a specified distance above or away from obstacles, etc.
- geometric reconstruction component 106 may be used to reconstruct at least a portion of the 3D scene.
- Geometric reconstruction component 106 may use a variety of techniques to reconstruct the 3D scene based on the received information, including, but not limited to, triangulating feature points as observed in image or video data from varying angles, generating a depth map using stereo image or video data, or determining geometric data from LIDAR or IR data. The reconstruction may then be used by other components when generating an optimal trajectory for the moveable camera.
- surface point generation component 108 may generate one or more surface points using the geometric reconstruction generated by geometric reconstruction component 106.
- a surface point may be a point within a scene or geometric reconstruction that may be visible from one or more camera positions.
- a surface light field may be defined as a shape surrounding the surface point.
- a solid angle may be a region of the surface light field that represents the observable data of the surface point from a camera at a given camera position. As such, coverage of the surface point from one or more camera positions may be measured based the area of solid angles on the surface light field associated with the surface point.
- Surface points may be generated within the geometric reconstruction based on one or more rules or algorithms (e.g., such that surface points are distributed among certain detected features of the geometric reconstruction, such that a certain percentage of surface points are visible from a given camera position, etc.) or may be distributed randomly (e.g., according to a uniform distribution, a standard distribution, etc.), among others.
- the quantity of generated surface points may be determined based on a prior indication (e.g., a constant value, a value proportional to the scanned area or volume, etc.) or may be dynamically determined based on one or more characteristics or attributes of the 3D scene, moveable camera 102, or environmental conditions, among others.
- Camera position graph generation component 110 may generate a graph of one or more possible camera positions relating to the 3D scene.
- the graph may be comprised of camera position nodes and edges.
- Each camera position node may indicate a camera position, while an edge between two camera position nodes may indicate a path (and an associated cost) between the two camera position nodes.
- the graph may be generated based on a geometric reconstruction (e.g., as reconstructed by geometric reconstruction component 106) and/or one or more surface points (e.g., as generated by surface point generation component 108), based on one or more rules or algorithms (e.g., such that the camera position nodes are distributed among certain detected features of the reconstruction, such that a certain percentage of surface points are visible from a given camera position node, etc.), or may be distributed randomly (e.g., according to a uniform distribution, a standard distribution, etc.), among others.
- a geometric reconstruction e.g., as reconstructed by geometric reconstruction component 106
- one or more surface points e.g., as generated by surface point generation component 108
- rules or algorithms e.g., such that the camera position nodes are distributed among certain detected features of the reconstruction, such that a certain percentage of surface points are visible from a given camera position node, etc.
- may be distributed randomly e.g., according to a uniform distribution, a standard distribution,
- the size of the graph (e.g., the number of camera position nodes, the interconnectedness of the graph, etc.) may be determined based on a prior indication (e.g., a constant value, a value proportional to the scanned area or volume, etc.) or may be dynamically determined based on one or more characteristics or attributes of the scene, moveable camera 102, the geometric reconstruction, the associated surface points, or environmental conditions, among others.
- a prior indication e.g., a constant value, a value proportional to the scanned area or volume, etc.
- Subgradient determination component 112 may be used to determine a subgradient associated with a camera position graph (e.g., which may have been generated by camera position graph generation component 110).
- a reward associated with a camera position used to observe a surface point may not be additive. Rather the reward may be submodular, because if a nearby camera position was already used to observe the surface point, the amount of additional gathered information relating to the surface point is less than if the surface point was previously unobserved.
- the reward associated with the camera position may decrease as camera positions are added to the computed trajectory.
- a subgradient may be determined in order to provide an additive approximation of the marginal reward for each camera position node.
- subgradient determination component 112 may determine the subgradient by sorting the camera position nodes of the camera position graph by decreasing marginal reward. Sorting may comprise selecting the node with the highest marginal reward, and then continually selecting the node with the next-highest marginal reward in view of the nodes that have already been selected. The subgroup comprised of the sequence of sorted nodes may then be used to additively approximate the nodes in the camera position graph.
- Trajectory generation component 114 may generate an optimal trajectory, which may then be provided to moveable camera 102 by computing device 104. Trajectory generation component may use information received from moveable camera 102 or data generated by at least one of components 106-114, or it may provide a trajectory without having first received information or data from moveable camera 102 or at least one of components 106-114. In one example, trajectory generation component 114 may receive one or more parameters that may be used to generate a trajectory, including, but not limited to, a bounding rectangle for the scene (e.g., as geographical coordinates, measurements, etc.) or a zone in which it is safe to operate (e.g., above or within a 3D scene, a specified distance above or away from obstacles, etc.), among others. As an example, trajectory generation component 114 may generate an initial trajectory for moveable camera 102 absent any previous knowledge of the scene.
- a bounding rectangle for the scene e.g., as geographical coordinates, measurements, etc.
- trajectory generation component 114 may use information relating to the scene, such as information provided or generated by at least one of components 106-112.
- a subgradient e.g., as may be determined by subgradient determination component 112
- a camera position graph e.g., as may be generated by camera position graph generation component 110.
- an optimal trajectory may be generated by evaluating the problem as an orienteering problem that may be formulated and solved as an integer linear program (ILP).
- ILP integer linear program
- an optimal trajectory may be determined based on the camera position nodes and edges that were determined to provide an optimal level of reward in relation to the cost incurred.
- Figure 2 illustrates an example scene 200 for which an optimal trajectory for a moveable camera may be generated.
- Scene 200 is comprised of object 202 and camera position graph 204.
- object 202 may be an interior object, an exterior object, or a combination thereof.
- camera position graph 204 may be generated.
- camera position graph 204 may be generated using a camera position graph generation component, such as camera position graph generation component 110 in Figure 1 .
- Camera position graph 204 may be comprised of one or more potential camera position nodes 206A, between which one or more edges 206B may exist. As discussed above, rewards may be associated with camera position nodes 206A, while costs may be associated with edges 206B. Camera position nodes 206A may be determined such that they provide a variety of different vantage points or perspectives of object 202. As an example, they may be determined randomly (e.g., according to a uniform distribution, a standard distribution, etc.) or based on information relating to object 202 (e.g., gathered from a previous scan, received as one or more parameters, etc.), among others. Edges 206B may be determined based on similar considerations. An optimal flight trajectory for a moveable camera may then be generated by identifying a set of camera position nodes and a set of edges from camera position graph 204 according to aspects disclosed herein.
- Figure 3 illustrates an example scene 300 for which an optimal trajectory for a moveable camera may be generated.
- Scene 300 comprises object 302 and flight path 304.
- scene 300 may be an overhead view of scene 200.
- Flight path 304 may be an initial flight path generated by a computing device (e.g., computing device 104 in Figure 1 ) and provided to a moveable camera (e.g., moveable camera 102).
- the moveable camera may use flight path 304 to perform a scan of scene 300 and object 302.
- flight path 304 may be generated based on one or more indications that provide information relating to scene 300, object 302, or the moveable camera, among others.
- an indication may include a region in which the moveable camera may operate or should avoid (e.g., a safe height above scene 300, the location of obstacles to avoid, etc.), as well as a target region that the moveable camera should scan, among others.
- Data gathered by the moveable camera using flight path 304 may be used when generating an optimal trajectory.
- the data may be used by components 106-114 in Figure 1 .
- trajectories e.g., having a different pattern, different or varying altitudes, or multiple passes, among other characteristics
- Figure 4 illustrates an example scene 400 for which an optimal trajectory for a moveable camera may be generated.
- Scene 400 comprises object 402 and camera position graph 404.
- scene 400 may be a side view of scene 200.
- camera position graph 404 may be generated using a camera position graph generation component, such as camera position graph generation component 110 in Figure 1 .
- camera position graph 404 may be generated based on information collected from an initial trajectory, such as flight path 304 in Figure 3 . The collected information may be processed using aspects disclosed herein in order to generate camera position graph 404 from which an optimal set of camera position nodes and edges may be determined (e.g., using at least one of components 106-114).
- Figure 5 illustrates an example surface light field coverage diagram 500 which may be used when generating an optimal trajectory for the moveable camera.
- Surface light field coverage diagram 500 comprises surface point 502, surface light field 504, and solid angles 506-512.
- Surface point 502 may be a point within a scene.
- surface point 502 may be a surface point that was generated by surface point generation component 108 in Figure 1 using reconstructed scene information from geometric reconstruction component 106.
- Surface light field 504 may surround surface point 502. While surface light field 504 is pictured as a hemisphere, it will be appreciated that surface light field 504 may be other shape (e.g., at least a subpart of a sphere, a cylinder, etc.) without departing from the spirit of this disclosure.
- Surface light field 504 may represent possible perspectives from which surface point 502 may be observed.
- a solid angle (e.g., solid angles 506-512) of surface light field 504 may indicate a region that may be observed from a given camera position. In some examples, this region may be used when determining a reward for the camera position associated with a solid angle.
- different camera positions may provide different coverage of surface point 502. As an example, a camera position having a grazing angle (e.g., such as that of solid angle 508) may provide less coverage, and therefore a lower reward, for surface point 502 than other camera positions (e.g., that of camera position 506, which is more directly above surface point 502 and therefore may enable the moveable camera to capture more information).
- overlapping solid angles may provide a diminishing reward if both associated camera positions are used, given that both associated camera positions provide similar coverage of surface point 502.
- the solid angles 506-512 may be weighted or prioritized accordingly when each associated camera position is being evaluated (e.g., by subgradient determination component 112 and/or trajectory generation component 114 in Figure 1 ).
- coverage of one or more surface points by one or more cameras may be represented using a matrix, wherein the rows of the matrix may be associated with surface light field samples and the columns of the matrix may be associated with camera position nodes in the camera position graph. If a surface point associated with a surface light field sample is observable by a given camera position node, a value may be stored in the matrix at the appropriate row and column. Columns of the matrix may then be selected to generate a resulting matrix (representing a trajectory comprising camera position nodes associated with the selected columns), which may then be used to determine the coverage of each surface point for the selected set of camera position nodes.
- the initial matrix may be multiplied by a weighting matrix, wherein the weighting matrix is comprised of weights associated with the surface light field samples that indicate the relative value (e.g., quality, observability, etc.) of a surface light field sample with respect to the associated surface point.
- the weighting matrix is comprised of weights associated with the surface light field samples that indicate the relative value (e.g., quality, observability, etc.) of a surface light field sample with respect to the associated surface point.
- Figure 6 illustrates an example method 600 for generating an optimal trajectory for a moveable camera capturing images used to create a3D scene.
- Method 600 may be performed by a computing device such as computing device 104 in Figure 1 .
- Method 600 begins at operation 602, where a set of data gathered during an initial pass may be received.
- the data maybe received from a moveable camera, such as moveable camera 102 in Figure 1 .
- the data may have been provided by a moveable camera by performing an initial flight pass such as flight path 304 in Figure 3 .
- the received data may comprise image data, video data, audio data, data relating to depth, and/or other geometric information.
- additional information may be received, such as data generated by one or more moveable cameras that performed the initial pass (e.g., GPS coordinates, barometric sensor data, attitude, pitch, roll, yaw, altitude, speed, etc.) or environmental data (e.g., climate conditions, wind speed, temperature, visibility, etc.), among other information (e.g., time, date, or information relating to the hardware, trajectory, or 3D scene, among others).
- data generated by one or more moveable cameras that performed the initial pass e.g., GPS coordinates, barometric sensor data, attitude, pitch, roll, yaw, altitude, speed, etc.
- environmental data e.g., climate conditions, wind speed, temperature, visibility, etc.
- time, date e.g., time, date, or information relating to the hardware, trajectory, or 3D scene, among others.
- the received data may be analyzed to determine a subsequent flight trajectory.
- Data analysis may be performed by computing device 104 in Figure 1 (e.g., using at least one of components 106-114).
- analyzing the data may comprise generating a scene reconstruction using at least a portion of the received data, generating one or more surface points in the reconstructed scene, generating a camera position graph, determining a subgradient, and/or generating a trajectory.
- the subsequent trajectory may be determined by evaluating the reward of the trajectory in view of the cost.
- the subsequent flight trajectory may be provided to a moveable camera (e.g., moveable camera 102 in Figure 1 ).
- a moveable camera e.g., moveable camera 102 in Figure 1
- the subsequent trajectory may be provided using any method of communication, including, but not limited to, wireless or wired communication methods.
- the subsequent trajectory may be provided to a component on the same or different computing device as was used to determine the subsequent flight trajectory. The component may instruct or control one or more moveable cameras based on the provided flight trajectory.
- a set of data gathered during a subsequent pass may be received.
- the data may have been captured by one or more moveable cameras using the subsequent flight trajectory.
- the received data may comprise image data, video data, audio data, data relating to depth, and/or other geometric information.
- additional information may be received, such as data generated by one or more moveable cameras that performed the initial pass or environmental data, among other information.
- flow may move from operation 608 to operation 604, where the data received in operation 608 may be used at operation 604 to perform analysis and determine a subsequent flight trajectory for the moveable camera.
- other previously received data e.g., data that was gathered during the initial pass or other subsequent passes
- Flow may then continue to operations 606 and 608, where the newly-determined subsequent flight trajectory may be provided and data using the subsequent flight trajectory may be received.
- Flow may loop between operations 604, 606, and 608.
- Eventually flow may progress instead to operation 610.
- Flow may instead branch to operation 610 as a result of the satisfaction of one or more conditions (e.g., a specific number of passes have been made, subsequent flight trajectories have yielded diminishing optimization benefits, etc.).
- flow may progress from operation 608 to operation 610, where data gathering may be completed. At least a portion of the gathered data may be used to perform a variety of computations, such as generating a 3D model of the scene or performing measurements or calculations, among other uses. Flow terminates at operation 610.
- Figure 7 illustrates an example method 700 for analyzing data to generate a subsequent flight trajectory for a moveable camera.
- Method 700 may be performed by a computing device (e.g., computing device 104 in Figure 1 ).
- Method 700 begins at operation 702, where data relating to a scene may be received.
- the data may be received from a moveable camera, such as moveable camera 102 in Figure 1 .
- At operation 704 at least a portion of the received data may be used to generate a reconstruction of the scene. Generating the reconstruction may be performed by geometric reconstruction component 106 in Figure 1 .
- one or more surface points may be generated.
- surface points may be generated using surface point generation component 106 in Figure 1 .
- the one or more surface points may be generated based on the reconstructed scene that was generated in operation 704.
- a graph of possible camera positions may be generated (e.g., using camera point graph generation component 110 in Figure 1 ).
- the graph of possible camera positions may comprise one or more camera position nodes and edges among the camera position nodes as disclosed herein.
- a subgradient may be determined for the camera positions.
- the subgradient may be determined by subgradient determination component 112 in Figure 1 .
- determining a subgradient may comprise performing method 800 in Figure 8 , which will be described in greater detail below.
- the subgradient may be generated based on information received or generated in at least one of previous operations 702-708.
- the subgradient may be determined such that camera position nodes are sorted based on decreasing marginal reward, wherein each subsequent camera position node is selected based on the decreasing marginal reward for that camera position node in view of previously-selected camera position nodes.
- an optimal trajectory may be generated.
- the optimal trajectory may be generated based on at least a part of information received or generated in at least one of pervious operations 702-710.
- the trajectory may be generated using trajectory generation component 114 in Figure 1 .
- the trajectory may be generated using the camera position graph and the subgradient from operations 708 and 710, respectively.
- the subgradient may provide an additive approximation of the marginal reward associated with each camera position node in the camera position graph, which may be formulated as an orienteering problem and solved as an ILP.
- the optimal trajectory may be provided to a moveable camera.
- the trajectory may be provided to one or more moveable cameras (e.g., moveable camera 102 in Figure 1 ).
- the trajectory may be provided using any method of communication, including, but not limited to, wireless or wired communication methods.
- the trajectory may be provided to the same or different computing device as was used to determine perform at least a part of method 700.
- the component may instruct or control one or more moveable cameras based on the provided flight trajectory. Flow terminates at operation 714.
- Figure 8 illustrates an example method 800 for generating a subgradient for approximating the marginal reward of one or more camera positions.
- Method 800 may be performed by a computing device such as computing device 104 in Figure 1 .
- Method 800 begins at operation 802, where a camera position graph and a set of surface points may be received.
- the camera position graph may comprise one or more camera positions nodes and one or more edges among the camera position nodes.
- the camera position nodes in the camera position graph may be sorted based on decreasing marginal reward. Sorting may comprise selecting the camera position node with the highest marginal reward, and selecting subsequent nodes based on next-highest marginal reward in view of the camera position nodes that have already been selected.
- a marginal reward associated with a camera position may be determined by comparing the reward and the cost as defined herein.
- a surface light field e.g., surface light field 504 in Figure 5
- each surface point may be populated with a solid angle relating to each camera position node to which the surface point is visible.
- the surface light fields may then be used to determine a reward associated with each camera position, wherein the reward is based on the surface light field for each camera position node observable by the camera.
- This sequence of sorted nodes is a subgradient that may then be used to additively approximate the camera position nodes within the camera position graph.
- the subgradient may be provided.
- the subgradient may be provided to a component (e.g., trajectory generation component 114 in Figure 1 ), a computing device, or a moveable camera. Flow terminates at operation 806.
- Figure 9 illustrates an example method 900 for analyzing data to generate a subsequent flight trajectory for a moveable camera.
- Method 900 begins at operation 902, where data relating to a scene may be received. The data maybe received from a moveable camera, such as moveable camera 102 in Figure 1 . At operation 904, at least a portion of the received data may be used to generate a reconstruction of the scene. Generating the reconstruction may be performed by geometric reconstruction component 106 in Figure 1 .
- one or more surface points may be generated.
- surface points may be generated using surface point generation component 106 in Figure 1 .
- the one or more surface points may be generated based on the reconstructed scene that was generated in operation 904.
- a graph of possible camera positions may be generated (e.g., using camera point graph generation component 110 in Figure 1 ).
- the graph of possible camera positions may comprise one or more camera position nodes and edges among the camera position nodes as disclosed herein.
- a root camera position may be selected as the first camera position of the trajectory.
- the root camera position may be determined based on one or more rules or algorithms, or it may be determined randomly, among others.
- the root camera position may be determined by comparing the marginal reward associated with each camera position node in the camera position graph, wherein the marginal reward may be a comparison of the reward and cost associated with a camera position node.
- the camera position node having the next-highest marginal reward may be selected and added to the trajectory.
- the marginal reward associated with a camera position node may be determined in view of the camera position nodes that are already included in the trajectory, such that candidate camera position nodes providing similar information to camera position nodes already in the flight trajectory have a decreased marginal reward.
- a determination may be made whether a constraint is met.
- a constraint may relate to a variety of factors, including, but not limited to, the quantity or quality of information collected, the amount of energy required to navigate the currently-generated trajectory, or the amount of camera position nodes currently included in the trajectory. If it is determined at operation 914 that the constraint is not met, flow branches to operation 912, where another camera position node may be added to the trajectory as discussed above. Flow may loop between operations 912 and 914 until the constraint is met.
- the generated trajectory may be provided.
- the trajectory may be provided to one or more moveable cameras (e.g., moveable camera 102 in Figure 1 ).
- the trajectory may be provided using any method of communication, including, but not limited to, wireless or wired communication methods.
- the trajectory may be provided to the same or different computing device as was used to determine perform at least a part of method 900.
- the component may instruct or control one or more moveable cameras based on the provided flight trajectory. Flow terminates at operation 916.
- Figures 10-13 and the associated descriptions provide a discussion of a variety of operating environments in which aspects of the disclosure may be practiced.
- the devices and systems illustrated and discussed with respect to Figures 10-13 are for purposes of example and illustration and are not limiting of a vast number of electronic device configurations that may be utilized for practicing aspects of the disclosure, as described herein.
- FIG 10 is a block diagram illustrating physical components (e.g., hardware) of an electronic device 1000 with which aspects of the disclosure may be practiced.
- the components of the electronic device 1000 described below may have computer executable instructions for generating a mailto link in an electronic communication application such as described above.
- the electronic device 1000 may include at least one processing unit 1010 and a system memory 1015.
- the system memory 1015 may comprise, but is not limited to, volatile storage (e.g., random access memory), non-volatile storage (e.g., read-only memory), flash memory, or any combination of such memories.
- the system memory 1015 may include an operating system 1025 and one or more program modules 1020 suitable for parsing received responses, generating electronic messages, updating attendee lists and so on.
- the operating system 1025 may be suitable for controlling the operation of the electronic device 1000.
- embodiments of the disclosure may be practiced in conjunction with a graphics library, other operating systems, or any other application program and is not limited to any particular application or system.
- This basic configuration is illustrated in Figure 10 by those components within a dashed line 1030.
- the electronic device 1000 may have additional features or functionality.
- the electronic device 1000 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape.
- additional storage is illustrated in Figure 10 by a removable storage device 1035 and a non-removable storage device 1040.
- program modules 1020 may perform processes including, but not limited to, the aspects, as described herein.
- embodiments of the disclosure may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors.
- an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors.
- embodiments of the disclosure may be practiced via a system-on-a-chip (SOC) where each or many of the components illustrated in Figure 10 may be integrated onto a single integrated circuit.
- SOC device may include one or more processing units, graphics units, communications units, system virtualization units and various application functionality all of which are integrated (or "burned") onto the chip substrate as a single integrated circuit.
- the functionality, described herein, with respect to the capability of the client to switch protocols may be operated via application-specific logic integrated with other components of the electronic device 1000 on the single integrated circuit (chip).
- Embodiments of the disclosure may also be practiced using other technologies capable of performing logical operations such as, for example, AND, OR, and NOT, including but not limited to mechanical, optical, fluidic, and quantum technologies.
- embodiments of the disclosure may be practiced within a general purpose computer or in any other circuits or systems.
- the electronic device 1000 may also have one or more input device(s) 1045 such as a keyboard, a trackpad, a mouse, a pen, a sound or voice input device, a touch, force and/or swipe input device, etc.
- the output device(s) 1050 such as a display, speakers, a printer, etc. may also be included.
- the aforementioned devices are examples and others may be used.
- the electronic device 1000 may include one or more communication connections 1055 allowing communications with other electronic devices 1060. Examples of suitable communication connections 1055 include, but are not limited to, radio frequency (RF) transmitter, receiver, and/or transceiver circuitry; universal serial bus (USB), parallel, and/or serial ports.
- RF radio frequency
- USB universal serial bus
- Computer-readable media may include computer storage media.
- Computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, or program modules.
- the system memory 1015, the removable storage device 1035, and the non-removable storage device 1040 are all computer storage media examples (e.g., memory storage).
- Computer storage media may include RAM, ROM, electrically erasable read-only memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other article of manufacture which can be used to store information and which can be accessed by the electronic device 1000. Any such computer storage media may be part of the electronic device 1000.
- Computer storage media does not include a carrier wave or other propagated or modulated data signal.
- Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media.
- modulated data signal may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal.
- communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
- RF radio frequency
- FIGS 11A and 11B illustrate a mobile electronic device 1100, for example, a mobile telephone, a smart phone, wearable computer (such as a smart watch), a tablet computer, a laptop computer, and the like, with which embodiments of the disclosure may be practiced.
- a mobile electronic device 1100 for example, a mobile telephone, a smart phone, wearable computer (such as a smart watch), a tablet computer, a laptop computer, and the like, with which embodiments of the disclosure may be practiced.
- Figure 11A one aspect of a mobile electronic device 1100 for implementing the aspects is illustrated.
- the mobile electronic device 1100 is a handheld computer having both input elements and output elements.
- the mobile electronic device 1100 typically includes a display 1105 and one or more input buttons 1110 that allow the user to enter information into the mobile electronic device 1100.
- the display 1105 of the mobile electronic device 1100 may also function as an input device (e.g., a display that accepts touch and/or force input).
- an optional side input element 1115 allows further user input.
- the side input element 1115 may be a rotary switch, a button, or any other type of manual input element.
- mobile electronic device 1100 may incorporate more or less input elements.
- the display 1105 may not be a touch screen in some embodiments.
- the mobile electronic device 1100 is a portable phone system, such as a cellular phone.
- the mobile electronic device 1100 may also include an optional keypad 1135.
- Optional keypad 1135 may be a physical keypad or a "soft" keypad generated on the touch screen display.
- the output elements include the display 1105 for showing a graphical user interface (GUI), a visual indicator 1120 (e.g., a light emitting diode), and/or an audio transducer 1125 (e.g., a speaker).
- GUI graphical user interface
- the mobile electronic device 1100 incorporates a vibration transducer for providing the user with tactile feedback.
- the mobile electronic device 1100 incorporates input and/or output ports, such as an audio input (e.g., a microphone jack), an audio output (e.g., a headphone jack), and a video output (e.g., a HDMI port) for sending signals to or receiving signals from an external device.
- FIG 11B is a block diagram illustrating the architecture of one aspect of a mobile electronic device 1100. That is, the mobile electronic device 1100 can incorporate a system (e.g., an architecture) 1140 to implement some aspects.
- the system 1140 is implemented as a "smart phone" capable of running one or more applications (e.g., browser, e-mail, calendaring, contact managers, messaging clients, games, media clients/players, content selection and sharing applications and so on).
- the system 1140 is integrated as an electronic device, such as an integrated personal digital assistant (PDA) and wireless phone.
- PDA personal digital assistant
- One or more application programs 1150 may be loaded into the memory 1145 and run on or in association with the operating system 1155.
- Examples of the application programs include phone dialer programs, e-mail programs, personal information management (PIM) programs, word processing programs, spreadsheet programs, Internet browser programs, messaging programs, and so forth.
- PIM personal information management
- the system 1140 also includes a non-volatile storage area 1160 within the memory 1145.
- the non-volatile storage area 1160 may be used to store persistent information that should not be lost if the system 1140 is powered down.
- the application programs 1150 may use and store information in the non-volatile storage area 1160, such as email or other messages used by an email application, and the like.
- a synchronization application (not shown) also resides on the system 1140 and is programmed to interact with a corresponding synchronization application resident on a host computer to keep the information stored in the non-volatile storage area 1160 synchronized with corresponding information stored at the host computer.
- the system 1140 has a power supply 1165, which may be implemented as one or more batteries.
- the power supply 1165 may further include an external power source, such as an AC adapter or a powered docking cradle that supplements or recharges the batteries.
- the system 1140 may also include a radio interface layer 1170 that performs the function of transmitting and receiving radio frequency communications.
- the radio interface layer 1170 facilitates wireless connectivity between the system 1140 and the "outside world," via a communications carrier or service provider. Transmissions to and from the radio interface layer 1170 are conducted under control of the operating system 1155. In other words, communications received by the radio interface layer 1170 may be disseminated to the application programs 1150 via the operating system 1155, and vice versa.
- the visual indicator 1120 may be used to provide visual notifications, and/or an audio interface 1175 may be used for producing audible notifications via an audio transducer (e.g., audio transducer 1125 illustrated in Figure 11A ).
- the visual indicator 1120 is a light emitting diode (LED) and the audio transducer 1125 may be a speaker.
- LED light emitting diode
- the LED may be programmed to remain on indefinitely until the user takes action to indicate the powered-on status of the device.
- the audio interface 1175 is used to provide audible signals to and receive audible signals from the user (e.g., voice input such as described above).
- the audio interface 1175 may also be coupled to a microphone to receive audible input, such as to facilitate a telephone conversation.
- the microphone may also serve as an audio sensor to facilitate control of notifications, as will be described below.
- the system 1140 may further include a video interface 1180 that enables an operation of peripheral device 1130 (e.g., on-board camera) to record still images, video stream, and the like.
- peripheral device 1130 e.g., on-board camera
- the captured images may be provided to the artificial intelligence entity advertisement system such as described above.
- a mobile electronic device 1100 implementing the system 1140 may have additional features or functionality.
- the mobile electronic device 1100 may also include additional data storage devices (removable and/or non-removable) such as, magnetic disks, optical disks, or tape.
- additional storage is illustrated in Figure 11B by the non-volatile storage area 1160.
- Data/information generated or captured by the mobile electronic device 1100 and stored via the system 1140 may be stored locally on the mobile electronic device 1100, as described above, or the data may be stored on any number of storage media that may be accessed by the device via the radio interface layer 1170 or via a wired connection between the mobile electronic device 1100 and a separate electronic device associated with the mobile electronic device 1100, for example, a server computer in a distributed computing network, such as the Internet.
- a server computer in a distributed computing network such as the Internet.
- data/information may be accessed via the mobile electronic device 1100 via the radio interface layer 1170 or via a distributed computing network.
- data/information may be readily transferred between electronic devices for storage and use according to well-known data/information transfer and storage means, including electronic mail and collaborative data/information sharing systems.
- Figures 11A and 11B are described for purposes of illustrating the present methods and systems and is not intended to limit the disclosure to a particular sequence of steps or a particular combination of hardware or software components.
- Figure 12 illustrates one aspect of the architecture of a system 1200 in which aspects of the disclosure may be practiced.
- the system may include a general electronic device 1210 (e.g., personal computer), tablet electronic device 1215, or mobile electronic device 1220, as described above.
- Each of these devices may include a surface point component 1225 and/or a camera position graph generation component such as described.
- the surface point component may be configured to generate one or more surface points as described herein. Surface points (and, in some examples, a camera position graph) may be transmitted to the trajectory component 1235 which may provide, over the network 1230, an optimal trajectory based on the provided information.
- the trajectory component 1235 may receive various types of information or content that is stored by the store 1240 or transmitted from a directory service 1245, a web portal 1250, mailbox services 1255, instant messaging stores 1260, or social networking services 1265.
- the aspects described above may be embodied in a general electronic device 1210 (e.g., personal computer), a tablet electronic device 1215 and/or a mobile electronic device 1220 (e.g., a smart phone). Any of these embodiments of the electronic devices may obtain content from or provide data to the store 1240.
- a general electronic device 1210 e.g., personal computer
- a tablet electronic device 1215 e.g., a tablet electronic device 1215
- a mobile electronic device 1220 e.g., a smart phone
- Figure 12 is described for purposes of illustrating the present methods and systems and is not intended to limit the disclosure to a particular sequence of steps or a particular combination of hardware or software components.
- Figure 13 illustrates an example tablet electronic device 1300 that may execute one or more aspects disclosed herein.
- the aspects and functionalities described herein may operate over distributed systems (e.g., cloud-based computing systems), where application functionality, memory, data storage and retrieval and various processing functions may be operated remotely from each other over a distributed computing network, such as the Internet or an intranet.
- distributed systems e.g., cloud-based computing systems
- application functionality, memory, data storage and retrieval and various processing functions may be operated remotely from each other over a distributed computing network, such as the Internet or an intranet.
- User interfaces and information of various types may be displayed via on-board electronic device displays or via remote display units associated with one or more electronic devices.
- user interfaces and information of various types may be displayed and interacted with on a wall surface onto which user interfaces and information of various types are projected.
- Interaction with the multitude of computing systems with which embodiments of the invention may be practiced include, keystroke entry, touch screen entry, voice or other audio entry, gesture entry where an associated electronic device is equipped with detection (e.g., camera) functionality for capturing and interpreting user gestures for controlling the functionality of the electronic device, and the like.
- Figure 13 is described for purposes of illustrating the present methods and systems and is not intended to limit the disclosure to a particular sequence of steps or a particular combination of hardware or software components.
- one aspect of the technology relates to a system comprising: at least one processor; and a memory storing instructions which, when executed by the at least one processor, performs a method for recreating a three-dimensional scene using data captured from a moveable camera.
- the method comprises: receiving data captured by the moveable camera relating to the three-dimensional scene; generating a reconstruction of the three-dimensional scene based on the received data; identifying one or more surface points within the three-dimensional scene; generating a graph of a plurality of camera positions, comprising one or more nodes and one or more edges; determining, based on the graph, a subgradient of the one or more nodes; generating, based on the subgradient and the graph, an optimal trajectory for the moveable camera; and providing the optimal trajectory to the moveable camera.
- the data relating to the three-dimensional scene is received as a result of the moveable camera performing an initial pass of the three-dimensional scene.
- identifying one or more surface points within the three-dimensional scene comprises randomly generating one or more surface points based on the reconstruction.
- generating the graph is based on at least one of the reconstruction and the one or more surface points.
- determining the subgradient comprises: identifying, from the plurality of camera positions, a camera position having a first highest marginal reward; computing, based on the identified camera position, a new marginal reward for each of the plurality of camera positions; and identifying, based on a new marginal reward, a camera position having a second highest marginal reward from the plurality of camera positions.
- generating the optimal trajectory comprises evaluating a cost associated with at least one of the one or more edges and a reward associated with at least one of the one or more nodes.
- the instructions further comprise receiving additional data captured by the moveable camera relating to the three-dimensional scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the three-dimensional scene based on the optimal trajectory.
- the technology relates to a computer-implemented method for generating an optimal trajectory for a moveable camera configured to scan a scene.
- the method comprises: receiving data captured by the moveable camera relating to the scene; generating a reconstruction of the scene based on the received data; identifying one or more surface points within the reconstruction; generating a graph of a plurality of camera positions, comprising one or more nodes and one or more edges; selecting, from the plurality of camera positions, a first camera position having a highest marginal reward; adding the first camera position to the optimal trajectory; determining, based on the optimal trajectory, if a constraint is met; when the constraint is not met, computing, based on the optimal trajectory, a new marginal reward for each of the plurality of camera positions; selecting, based on a new marginal reward, a second camera position having a second highest marginal reward; adding the second camera position to the optimal trajectory; and when the constraint is met, providing the optimal trajectory to the moveable camera.
- the data relating to the scene is received as a result of the moveable camera performing an initial pass of the scene.
- identifying one or more surface points within the scene comprises randomly generating one or more surface points based on the reconstruction.
- generating the graph is based on at least one of the reconstruction and the one or more surface points.
- constraint relates to one of the amount of energy required by the moveable camera to navigate the trajectory, the amount of storage capacity required by the trajectory, and the amount of camera positions included by the trajectory.
- the method further comprises receiving additional data captured by the moveable camera relating to the scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the scene based on the optimal trajectory.
- the technology in another aspect, relates to a computer-implemented method for recreating a three-dimensional scene using data captured from a moveable camera.
- the method comprises: receiving data captured by the moveable camera relating to the three-dimensional scene; generating a reconstruction of the three-dimensional scene based on the received data; identifying one or more surface points within the three-dimensional scene; generating a graph of a plurality of camera positions, comprising one or more nodes and one or more edges; determining, based on the graph, a subgradient of the one or more nodes; generating, based on the subgradient and the graph, an optimal trajectory for the moveable camera; and providing the optimal trajectory to the moveable camera.
- the data relating to the three-dimensional scene is received as a result of the moveable camera performing an initial pass of the three-dimensional scene.
- identifying one or more surface points within the three-dimensional scene comprises randomly generating one or more surface points based on the reconstruction.
- generating the graph is based on at least one of the reconstruction and the one or more surface points.
- determining the subgradient comprises: identifying, from the plurality of camera positions, a camera position having a first highest marginal reward; computing, based on the identified camera position, a new marginal reward for each of the plurality of camera positions; and identifying, based on a new marginal reward, a camera position having a second highest marginal reward from the plurality of camera positions.
- generating the optimal trajectory comprises evaluating a cost associated with at least one of the one or more edges and a reward associated with at least one of the one or more nodes.
- the method further comprises receiving additional data captured by the moveable camera relating to the three-dimensional scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the three-dimensional scene based on the optimal trajectory.
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Remote Sensing (AREA)
- Radar, Positioning & Navigation (AREA)
- Computer Graphics (AREA)
- Computer Hardware Design (AREA)
- General Engineering & Computer Science (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Studio Devices (AREA)
- Aviation & Aerospace Engineering (AREA)
- Control Of Position, Course, Altitude, Or Attitude Of Moving Bodies (AREA)
- Length Measuring Devices By Optical Means (AREA)
Description
- Unmanned aerial vehicles (UAVs) typically have a camera that captures images as it travels a path designed by its operator. The UAV may be maneuvered by the operator along a trajectory that enables the camera to capture the scene from a variety of camera positions having different vantage points. Ideally, the scene would be observed in great detail, such that the reconstruction is as accurate and detailed as possible. However, a variety of constraints may make such an approach impossible (e.g., limited flight time, storage capacity constraints, etc.). As a result, a tradeoff may exist between the amount of data that may be collected by the camera and the costs associated with collecting the data.
- It is with respect to these and other general considerations that the aspects disclosed herein have been made. Also, although relatively specific problems may be discussed, it should be understood that the examples should not be limited to solving the specific problems identified in the background or elsewhere in this disclosure.
-
US 2015/0112516 A1 discloses technologies for controlling a flight path of a UAV based image capture system for solid modeling. Upon determining an initial movement path based on an estimate of a structure to be modeled, images of the structure to be modeled may be captured and surface hypotheses formed for unobserved surfaces based on the captured images. A normal vector and a viewing cone may be computed for each hypothesized surface. A set of desired locations may be determined based on the viewing cones for the entire structure to be modeled and a least impact path for the UAV determined based on the desired locations and desired flight parameters. -
US 2016/0004795 A1 discloses an UAV system for solar site assessment including generating a three-dimensional model of a solar site based at least in part on data captured by a UAV, importing one or more solar paths into the three-dimensional model based at least in part on a geo-location of the solar site, and determining, one or more solar collection estimates corresponding to one or more locations in the solar site based at least in part on the three-dimensional model and the one or more solar paths. -
US 2010/0268409 A1 discloses a method for inspecting structures that includes using a plurality of independent unmanned mobile vehicles. The unmanned mobile vehicles are equipped with a control and guidance system for enabling each unmanned mobile vehicle to operate autonomously. Each unmanned mobile vehicle may be programmed with an operating program that defines a path of travel for it, relative to a structure to be inspected. The unmanned mobile vehicles are deployed so that they cooperatively form a swarm that travels about the structure. At least one of said unmanned mobile vehicles is used to obtain inspection data of a portion of the structure as it executes its respective operating program. - According to aspects of the present invention there is provided a system and a computer-implemented method as defined in the accompanying claims.
- Examples of the present disclosure describe systems and methods for generating optimal scanning trajectories for unmanned aerial vehicles (UAVs) that capture 3D scenes using one or more cameras. For example, a drone or other moveable camera may be used to gather information about the scene. In an initial pass, the moveable camera may travel an initial trajectory that may be used to gather an initial dataset. The initial dataset may be analyzed to generate an optimal scanning trajectory that may then be used by the moveable camera to gather subsequent data. Further analysis of the initial and subsequent data may be performed in order to further refine or optimize a trajectory for scanning the scene. Further iterations and optimizations may be performed, continually refining and improving the flight trajectory based on newly-acquired information about the scene.
- Generating an optimal trajectory may comprise generating a reconstruction of the scene based on previously-acquired data relating to the scene. One or more surface points may be generated within the reconstruction. Further, a camera position graph may be generated, wherein the camera position graph comprises one or more camera position nodes and edges. A subgradient may be determined, wherein the subgradient provides an additive approximation for the marginal reward associated with each camera position node in the camera position graph. The subgradient may then be used to generate an optimal flight trajectory based on the reward and cost associated with the camera position nodes and edges in the camera position graph.
- This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Additional aspects, features, and/or advantages of examples will be set forth in part in the description which follows and, in part, will be apparent from the description, or may be learned by practice of the disclosure.
- Non-limiting and non-exhaustive examples are described with reference to the following figures.
-
Figure 1 illustrates an example system for generating optimal trajectories for a moveable camera that captures images used to create a 3D scene. -
Figure 2 illustrates an example scene for which an optimal trajectory for a moveable camera may be generated. -
Figure 3 illustrates an example scene for which an optimal trajectory for a moveable camera may be generated. -
Figure 4 illustrates an example scene for which an optimal trajectory for a moveable camera may be generated. -
Figure 5 illustrates an example surface light field coverage diagram which may be used when generating an optimal trajectory for a moveable camera. -
Figure 6 illustrates an example method for generating an optimal trajectory for a moveable camera capturing images used to create a 3D scene. -
Figure 7 illustrates an example method for analyzing data to generate a subsequent flight trajectory for a moveable camera. -
Figure 8 illustrates an example method for generating a subgradient for approximating the marginal reward of one or more camera positions. -
Figure 9 illustrates an example method for analyzing data to generate a subsequent flight trajectory for a moveable camera. -
Figure 10 is a block diagram illustrating example physical components of a computing device with which aspects of the disclosure may be practiced. -
Figure 11A and11B are simplified block diagrams of a mobile computing device with which aspects of the present disclosure may be practiced. -
Figure 12 is a simplified block diagram of a distributed computing system in which aspects of the present disclosure may be practiced. -
Figure 13 illustrates a tablet computing device for executing one or more aspects of the present disclosure. - Various aspects of the disclosure are described more fully below with reference to the accompanying drawings, which form a part hereof, and which show specific exemplary aspects. However, different aspects of the disclosure may be implemented in many different forms and should not be construed as limited to the aspects set forth herein; rather, these aspects are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the aspects to those skilled in the art. Aspects may be practiced as methods, systems or devices. Accordingly, aspects may take the form of a hardware implementation, an entirely software implementation or an implementation combining software and hardware aspects. The following detailed description is, therefore, not to be taken in a limiting sense.
- The present disclosure generally relates to generating scanning trajectories for moveable cameras that are configured to scan a scene. The data collected from the scan may subsequently be used to create a 3D scene. In an example, a moveable camera (e.g., a drone, UAV, or any other manually- or automatically-positioned camera) may be used to capture data relating to a 3D scene. This data then may be used to generate an optimal scanning trajectory for the moveable camera. The optimal scanning trajectory may be used to capture additional information relating to the scene. In some examples, the process may be iterative, such that subsequent optimal trajectories for the moveable camera may be generated based on information captured using previously-generated trajectories. The process may repeat until a certain threshold is met (e.g., a certain quality or accuracy target is achieved, the size of the captured dataset reaches a predetermined threshold, etc.). The collected information may be used to generate a 3D model of the scene, perform measurements or calculations, among other uses.
- A 3D scene may be a landmark, building, historical monument, or natural attraction, among others. In an example, a 3D scene may be the interior of a structure (e.g., a room, an office, a mall or other retail space, a vehicle, etc.), the exterior of a structure (e.g., a building, a patio or balcony, etc.), or any combination thereof. As will be appreciated, any type of scene may be scanned without departing from the spirit of this disclosure.
- In some examples, a trajectory may be designated as "optimal" when the reward and cost associated with the trajectory have been analyzed or evaluated so as to obtain an additional or similar level of reward while incurring a similar or decreased level of cost. In an example, a reward associated with a trajectory may include the amount and/or quality of information captured, the ease with which the information was captured, or the amount of time required to capture the information, among others. In another example, a cost associated with a trajectory may include energy requirements of the moveable camera, the skill or maneuverability required in order to implement or navigate the trajectory, the amount of time required to navigate the trajectory, storage capacity requirements of the moveable camera, etc. In some examples, one or more rewards may be evaluated in view of one or more costs, thereby determining a marginal reward. As will be appreciated, other rewards or costs may be evaluated without departing from the spirit of this disclosure. Additionally, in some examples, a "cost" may in fact be a "reward," and vice versa. As an example, while the storage capacity of the moveable camera may be constrained in one instance, it may be the case that the reward is measured based on the size of the resulting dataset in another instance. In another example, one or more factors may be evaluated as both a cost and as a reward.
- The moveable camera may be used to capture a variety of information relating to a 3D scene as it passes over the scene. In some examples, image, video, and/or audio data may be captured. The moveable camera may have additional hardware used to capture depth or other geometric information, including, but not limited to, Light Detection and Ranging (LIDAR) sensors, infrared (IR) emitters and/or sensors, or stereoscopic sensors. In other examples, additional information may be gathered, such as data from one or more moveable cameras used when navigating the trajectory (e.g., GPS coordinates, barometric sensor data, attitude, pitch, roll, yaw, altitude, speed, etc.) or environmental data (e.g., climate conditions, wind speed, temperature, visibility, etc.), among other information (e.g., time, date, or information relating to the hardware, trajectory, or 3D scene, among others).
-
Figure 1 illustrates anexample system 100 for generating optimal trajectories for a moveable camera for capturing images used to create a 3D scene.Example system 100 comprisesmoveable camera 102 andcomputing device 104.Moveable camera 102 may be a UAV, a drone, or other camera. In some examples,moveable camera 102 may be positioned or controlled manually or automatically. While only one moveable camera is shown inFigure 1 , it will be appreciated that multiple moveable cameras may be used without departing from the spirit of this disclosure. -
Computing device 104 is comprised ofgeometric reconstruction component 106, surfacepoint generation component 108, camera positiongraph generation component 110,subgradient determination component 112, andtrajectory generation component 114.Computing device 104 may be a personal computing device, tablet computing device, mobile computing device, or distributed computing device, among others. Whilecomputing device 104 is illustrated as separate frommoveable camera 102,moveable camera 102 may comprisecomputing device 104 and one or more of components 106-114. In another example,moveable camera 102 may comprise one or more or components 106-114, while computingdevice 104 comprises one or more of the other components. In another example,computing device 104 may be a distributed computing device such that multiple computing devices are used to perform the functions of components 106-114. Additionally, components 106-114 may be hardware components, software components, or some combination thereof. -
Moveable camera 102 may provide information relating to a 3D scene tocomputing device 104. Additionally,computing device 104 may provide one or more trajectories tomoveable camera 102. In some examples,computing device 104 may provide the trajectories based on information received frommoveable camera 102. In other examples,computing device 104 may provide a trajectory without having received information frommoveable camera 102. The trajectory may be based on one or more parameters relating to the 3D scene, including, but not limited to, bounding dimensions for the scene (e.g., as geographical coordinates, measurements, etc.), a zone in which it is safe to operate (e.g., above or within a 3D scene, a specified distance above or away from obstacles, etc.), among others. - When evaluating information received from
moveable camera 102,geometric reconstruction component 106 may be used to reconstruct at least a portion of the 3D scene.Geometric reconstruction component 106 may use a variety of techniques to reconstruct the 3D scene based on the received information, including, but not limited to, triangulating feature points as observed in image or video data from varying angles, generating a depth map using stereo image or video data, or determining geometric data from LIDAR or IR data. The reconstruction may then be used by other components when generating an optimal trajectory for the moveable camera. - In some examples, surface
point generation component 108 may generate one or more surface points using the geometric reconstruction generated bygeometric reconstruction component 106. As will be discussed in greater detail with respect toFigure 5 , a surface point may be a point within a scene or geometric reconstruction that may be visible from one or more camera positions. In an example, a surface light field may be defined as a shape surrounding the surface point. A solid angle may be a region of the surface light field that represents the observable data of the surface point from a camera at a given camera position. As such, coverage of the surface point from one or more camera positions may be measured based the area of solid angles on the surface light field associated with the surface point. - Surface points may be generated within the geometric reconstruction based on one or more rules or algorithms (e.g., such that surface points are distributed among certain detected features of the geometric reconstruction, such that a certain percentage of surface points are visible from a given camera position, etc.) or may be distributed randomly (e.g., according to a uniform distribution, a standard distribution, etc.), among others. The quantity of generated surface points may be determined based on a prior indication (e.g., a constant value, a value proportional to the scanned area or volume, etc.) or may be dynamically determined based on one or more characteristics or attributes of the 3D scene,
moveable camera 102, or environmental conditions, among others. - Camera position
graph generation component 110 may generate a graph of one or more possible camera positions relating to the 3D scene. The graph may be comprised of camera position nodes and edges. Each camera position node may indicate a camera position, while an edge between two camera position nodes may indicate a path (and an associated cost) between the two camera position nodes. In some examples, the graph may be generated based on a geometric reconstruction (e.g., as reconstructed by geometric reconstruction component 106) and/or one or more surface points (e.g., as generated by surface point generation component 108), based on one or more rules or algorithms (e.g., such that the camera position nodes are distributed among certain detected features of the reconstruction, such that a certain percentage of surface points are visible from a given camera position node, etc.), or may be distributed randomly (e.g., according to a uniform distribution, a standard distribution, etc.), among others. The size of the graph (e.g., the number of camera position nodes, the interconnectedness of the graph, etc.) may be determined based on a prior indication (e.g., a constant value, a value proportional to the scanned area or volume, etc.) or may be dynamically determined based on one or more characteristics or attributes of the scene,moveable camera 102, the geometric reconstruction, the associated surface points, or environmental conditions, among others. -
Subgradient determination component 112 may be used to determine a subgradient associated with a camera position graph (e.g., which may have been generated by camera position graph generation component 110). A reward associated with a camera position used to observe a surface point may not be additive. Rather the reward may be submodular, because if a nearby camera position was already used to observe the surface point, the amount of additional gathered information relating to the surface point is less than if the surface point was previously unobserved. Thus, while a camera position may have a high reward initially, the reward associated with the camera position may decrease as camera positions are added to the computed trajectory. As such, a subgradient may be determined in order to provide an additive approximation of the marginal reward for each camera position node. In some examples,subgradient determination component 112 may determine the subgradient by sorting the camera position nodes of the camera position graph by decreasing marginal reward. Sorting may comprise selecting the node with the highest marginal reward, and then continually selecting the node with the next-highest marginal reward in view of the nodes that have already been selected. The subgroup comprised of the sequence of sorted nodes may then be used to additively approximate the nodes in the camera position graph. -
Trajectory generation component 114 may generate an optimal trajectory, which may then be provided tomoveable camera 102 by computingdevice 104. Trajectory generation component may use information received frommoveable camera 102 or data generated by at least one of components 106-114, or it may provide a trajectory without having first received information or data frommoveable camera 102 or at least one of components 106-114. In one example,trajectory generation component 114 may receive one or more parameters that may be used to generate a trajectory, including, but not limited to, a bounding rectangle for the scene (e.g., as geographical coordinates, measurements, etc.) or a zone in which it is safe to operate (e.g., above or within a 3D scene, a specified distance above or away from obstacles, etc.), among others. As an example,trajectory generation component 114 may generate an initial trajectory formoveable camera 102 absent any previous knowledge of the scene. - In another example,
trajectory generation component 114 may use information relating to the scene, such as information provided or generated by at least one of components 106-112. As an example, a subgradient (e.g., as may be determined by subgradient determination component 112) may be used in conjunction with a camera position graph (e.g., as may be generated by camera position graph generation component 110). Given that the subgradient provides an additive approximation for the submodular nature of each camera position node's marginal reward within the camera position graph, an optimal trajectory may be generated by evaluating the problem as an orienteering problem that may be formulated and solved as an integer linear program (ILP). As will be appreciated, a variety of algorithms may be used to solve the resulting ILP, including, but not limited to, a branch-and-bound algorithm or a branch-and-cut algorithm. Thus, an optimal trajectory may be determined based on the camera position nodes and edges that were determined to provide an optimal level of reward in relation to the cost incurred. -
Figure 2 illustrates anexample scene 200 for which an optimal trajectory for a moveable camera may be generated.Scene 200 is comprised ofobject 202 andcamera position graph 204. As discussed above, object 202 may be an interior object, an exterior object, or a combination thereof. In order to generate an optimal trajectory to scanobject 202,camera position graph 204 may be generated. In an example,camera position graph 204 may be generated using a camera position graph generation component, such as camera positiongraph generation component 110 inFigure 1 . -
Camera position graph 204 may be comprised of one or more potentialcamera position nodes 206A, between which one ormore edges 206B may exist. As discussed above, rewards may be associated withcamera position nodes 206A, while costs may be associated withedges 206B.Camera position nodes 206A may be determined such that they provide a variety of different vantage points or perspectives ofobject 202. As an example, they may be determined randomly (e.g., according to a uniform distribution, a standard distribution, etc.) or based on information relating to object 202 (e.g., gathered from a previous scan, received as one or more parameters, etc.), among others.Edges 206B may be determined based on similar considerations. An optimal flight trajectory for a moveable camera may then be generated by identifying a set of camera position nodes and a set of edges fromcamera position graph 204 according to aspects disclosed herein. -
Figure 3 illustrates anexample scene 300 for which an optimal trajectory for a moveable camera may be generated.Scene 300 comprisesobject 302 andflight path 304. In an example,scene 300 may be an overhead view ofscene 200.Flight path 304 may be an initial flight path generated by a computing device (e.g.,computing device 104 inFigure 1 ) and provided to a moveable camera (e.g., moveable camera 102). The moveable camera may useflight path 304 to perform a scan ofscene 300 andobject 302. In some examples,flight path 304 may be generated based on one or more indications that provide information relating toscene 300,object 302, or the moveable camera, among others. As an example, an indication may include a region in which the moveable camera may operate or should avoid (e.g., a safe height abovescene 300, the location of obstacles to avoid, etc.), as well as a target region that the moveable camera should scan, among others. Data gathered by the moveable camera usingflight path 304 may be used when generating an optimal trajectory. In an example, the data may be used by components 106-114 inFigure 1 . As will be appreciated, a variety of trajectories (e.g., having a different pattern, different or varying altitudes, or multiple passes, among other characteristics) may be used without departing from the spirit of this disclosure. -
Figure 4 illustrates anexample scene 400 for which an optimal trajectory for a moveable camera may be generated.Scene 400 comprisesobject 402 andcamera position graph 404. In an example,scene 400 may be a side view ofscene 200. In an example,camera position graph 404 may be generated using a camera position graph generation component, such as camera positiongraph generation component 110 inFigure 1 . Further,camera position graph 404 may be generated based on information collected from an initial trajectory, such asflight path 304 inFigure 3 . The collected information may be processed using aspects disclosed herein in order to generatecamera position graph 404 from which an optimal set of camera position nodes and edges may be determined (e.g., using at least one of components 106-114). -
Figure 5 illustrates an example surface light field coverage diagram 500 which may be used when generating an optimal trajectory for the moveable camera. Surface light field coverage diagram 500 comprisessurface point 502, surfacelight field 504, and solid angles 506-512.Surface point 502 may be a point within a scene. In one example,surface point 502 may be a surface point that was generated by surfacepoint generation component 108 inFigure 1 using reconstructed scene information fromgeometric reconstruction component 106. Surfacelight field 504 may surroundsurface point 502. While surfacelight field 504 is pictured as a hemisphere, it will be appreciated that surfacelight field 504 may be other shape (e.g., at least a subpart of a sphere, a cylinder, etc.) without departing from the spirit of this disclosure. - Surface
light field 504 may represent possible perspectives from whichsurface point 502 may be observed. A solid angle (e.g., solid angles 506-512) of surfacelight field 504 may indicate a region that may be observed from a given camera position. In some examples, this region may be used when determining a reward for the camera position associated with a solid angle. Further, different camera positions may provide different coverage ofsurface point 502. As an example, a camera position having a grazing angle (e.g., such as that of solid angle 508) may provide less coverage, and therefore a lower reward, forsurface point 502 than other camera positions (e.g., that ofcamera position 506, which is more directly abovesurface point 502 and therefore may enable the moveable camera to capture more information). Additionally, overlapping solid angles (e.g.,solid angle 510 and solid angle 512) may provide a diminishing reward if both associated camera positions are used, given that both associated camera positions provide similar coverage ofsurface point 502. As a result, the solid angles 506-512 may be weighted or prioritized accordingly when each associated camera position is being evaluated (e.g., bysubgradient determination component 112 and/ortrajectory generation component 114 inFigure 1 ). - In some examples, coverage of one or more surface points by one or more cameras may be represented using a matrix, wherein the rows of the matrix may be associated with surface light field samples and the columns of the matrix may be associated with camera position nodes in the camera position graph. If a surface point associated with a surface light field sample is observable by a given camera position node, a value may be stored in the matrix at the appropriate row and column. Columns of the matrix may then be selected to generate a resulting matrix (representing a trajectory comprising camera position nodes associated with the selected columns), which may then be used to determine the coverage of each surface point for the selected set of camera position nodes. In an example, the initial matrix may be multiplied by a weighting matrix, wherein the weighting matrix is comprised of weights associated with the surface light field samples that indicate the relative value (e.g., quality, observability, etc.) of a surface light field sample with respect to the associated surface point.
-
Figure 6 illustrates anexample method 600 for generating an optimal trajectory for a moveable camera capturing images used to create a3D scene.Method 600 may be performed by a computing device such ascomputing device 104 inFigure 1 .Method 600 begins atoperation 602, where a set of data gathered during an initial pass may be received. The data maybe received from a moveable camera, such asmoveable camera 102 inFigure 1 . In one example, the data may have been provided by a moveable camera by performing an initial flight pass such asflight path 304 inFigure 3 . The received data may comprise image data, video data, audio data, data relating to depth, and/or other geometric information. In some examples, additional information may be received, such as data generated by one or more moveable cameras that performed the initial pass (e.g., GPS coordinates, barometric sensor data, attitude, pitch, roll, yaw, altitude, speed, etc.) or environmental data (e.g., climate conditions, wind speed, temperature, visibility, etc.), among other information (e.g., time, date, or information relating to the hardware, trajectory, or 3D scene, among others). - Moving to
operation 604, the received data may be analyzed to determine a subsequent flight trajectory. Data analysis may be performed by computingdevice 104 inFigure 1 (e.g., using at least one of components 106-114). In an example, analyzing the data may comprise generating a scene reconstruction using at least a portion of the received data, generating one or more surface points in the reconstructed scene, generating a camera position graph, determining a subgradient, and/or generating a trajectory. As discussed herein, the subsequent trajectory may be determined by evaluating the reward of the trajectory in view of the cost. - At
operation 606, the subsequent flight trajectory may be provided to a moveable camera (e.g.,moveable camera 102 inFigure 1 ). In some examples, there may be a plurality of cameras to which at least a portion of the subsequent trajectory may be provided. The subsequent trajectory may be provided using any method of communication, including, but not limited to, wireless or wired communication methods. In other examples, the subsequent trajectory may be provided to a component on the same or different computing device as was used to determine the subsequent flight trajectory. The component may instruct or control one or more moveable cameras based on the provided flight trajectory. - Moving to
operation 608, a set of data gathered during a subsequent pass may be received. In an example, the data may have been captured by one or more moveable cameras using the subsequent flight trajectory. The received data may comprise image data, video data, audio data, data relating to depth, and/or other geometric information. In some examples, additional information may be received, such as data generated by one or more moveable cameras that performed the initial pass or environmental data, among other information. - In one example, flow may move from
operation 608 tooperation 604, where the data received inoperation 608 may be used atoperation 604 to perform analysis and determine a subsequent flight trajectory for the moveable camera. In some examples, other previously received data (e.g., data that was gathered during the initial pass or other subsequent passes) may be used in addition to the data that was received inoperation 608. Flow may then continue tooperations operations operation 610. Flow may instead branch tooperation 610 as a result of the satisfaction of one or more conditions (e.g., a specific number of passes have been made, subsequent flight trajectories have yielded diminishing optimization benefits, etc.). - In another example (or as a result of satisfying one or more conditions), flow may progress from
operation 608 tooperation 610, where data gathering may be completed. At least a portion of the gathered data may be used to perform a variety of computations, such as generating a 3D model of the scene or performing measurements or calculations, among other uses. Flow terminates atoperation 610. -
Figure 7 illustrates anexample method 700 for analyzing data to generate a subsequent flight trajectory for a moveable camera.Method 700 may be performed by a computing device (e.g.,computing device 104 inFigure 1 ).Method 700 begins atoperation 702, where data relating to a scene may be received. The data may be received from a moveable camera, such asmoveable camera 102 inFigure 1 . Atoperation 704, at least a portion of the received data may be used to generate a reconstruction of the scene. Generating the reconstruction may be performed bygeometric reconstruction component 106 inFigure 1 . - Moving to
operation 706, one or more surface points may be generated. In an example, surface points may be generated using surfacepoint generation component 106 inFigure 1 . The one or more surface points may be generated based on the reconstructed scene that was generated inoperation 704. Atoperation 708, a graph of possible camera positions may be generated (e.g., using camera pointgraph generation component 110 inFigure 1 ). The graph of possible camera positions may comprise one or more camera position nodes and edges among the camera position nodes as disclosed herein. - At
operation 710, a subgradient may be determined for the camera positions. As an example, the subgradient may be determined bysubgradient determination component 112 inFigure 1 . In one example, determining a subgradient may comprise performingmethod 800 inFigure 8 , which will be described in greater detail below. The subgradient may be generated based on information received or generated in at least one of previous operations 702-708. As discussed above, the subgradient may be determined such that camera position nodes are sorted based on decreasing marginal reward, wherein each subsequent camera position node is selected based on the decreasing marginal reward for that camera position node in view of previously-selected camera position nodes. - Moving to
operation 712, an optimal trajectory may be generated. In some examples, the optimal trajectory may be generated based on at least a part of information received or generated in at least one of pervious operations 702-710. In some examples, the trajectory may be generated usingtrajectory generation component 114 inFigure 1 . In another example, the trajectory may be generated using the camera position graph and the subgradient fromoperations - At
operation 714, the optimal trajectory may be provided to a moveable camera. In some examples, the trajectory may be provided to one or more moveable cameras (e.g.,moveable camera 102 inFigure 1 ). The trajectory may be provided using any method of communication, including, but not limited to, wireless or wired communication methods. In an example, the trajectory may be provided to the same or different computing device as was used to determine perform at least a part ofmethod 700. The component may instruct or control one or more moveable cameras based on the provided flight trajectory. Flow terminates atoperation 714. -
Figure 8 illustrates anexample method 800 for generating a subgradient for approximating the marginal reward of one or more camera positions.Method 800 may be performed by a computing device such ascomputing device 104 inFigure 1 .Method 800 begins atoperation 802, where a camera position graph and a set of surface points may be received. The camera position graph may comprise one or more camera positions nodes and one or more edges among the camera position nodes. - Moving to
operation 804, the camera position nodes in the camera position graph may be sorted based on decreasing marginal reward. Sorting may comprise selecting the camera position node with the highest marginal reward, and selecting subsequent nodes based on next-highest marginal reward in view of the camera position nodes that have already been selected. A marginal reward associated with a camera position may be determined by comparing the reward and the cost as defined herein. In an example, a surface light field (e.g., surfacelight field 504 inFigure 5 ) for each surface point may be populated with a solid angle relating to each camera position node to which the surface point is visible. The surface light fields may then be used to determine a reward associated with each camera position, wherein the reward is based on the surface light field for each camera position node observable by the camera. This sequence of sorted nodes is a subgradient that may then be used to additively approximate the camera position nodes within the camera position graph. Atoperation 806, the subgradient may be provided. As an example, the subgradient may be provided to a component (e.g.,trajectory generation component 114 inFigure 1 ), a computing device, or a moveable camera. Flow terminates atoperation 806. -
Figure 9 illustrates anexample method 900 for analyzing data to generate a subsequent flight trajectory for a moveable camera.Method 900 begins atoperation 902, where data relating to a scene may be received. The data maybe received from a moveable camera, such asmoveable camera 102 inFigure 1 . Atoperation 904, at least a portion of the received data may be used to generate a reconstruction of the scene. Generating the reconstruction may be performed bygeometric reconstruction component 106 inFigure 1 . - Moving to
operation 906, one or more surface points may be generated. In an example, surface points may be generated using surfacepoint generation component 106 inFigure 1 . The one or more surface points may be generated based on the reconstructed scene that was generated inoperation 904. Atoperation 908, a graph of possible camera positions may be generated (e.g., using camera pointgraph generation component 110 inFigure 1 ). The graph of possible camera positions may comprise one or more camera position nodes and edges among the camera position nodes as disclosed herein. - At
operation 910, a root camera position may be selected as the first camera position of the trajectory. The root camera position may be determined based on one or more rules or algorithms, or it may be determined randomly, among others. In an example, the root camera position may be determined by comparing the marginal reward associated with each camera position node in the camera position graph, wherein the marginal reward may be a comparison of the reward and cost associated with a camera position node. - Moving to
operation 912, the camera position node having the next-highest marginal reward may be selected and added to the trajectory. The marginal reward associated with a camera position node may be determined in view of the camera position nodes that are already included in the trajectory, such that candidate camera position nodes providing similar information to camera position nodes already in the flight trajectory have a decreased marginal reward. - At
determination operation 914, a determination may be made whether a constraint is met. In some examples, a plurality of constraints may be evaluated. A constraint may relate to a variety of factors, including, but not limited to, the quantity or quality of information collected, the amount of energy required to navigate the currently-generated trajectory, or the amount of camera position nodes currently included in the trajectory. If it is determined atoperation 914 that the constraint is not met, flow branches tooperation 912, where another camera position node may be added to the trajectory as discussed above. Flow may loop betweenoperations - By contrast, if it is determined that the constraint is met, flow proceeds to
operation 916, where the generated trajectory may be provided. In some examples, the trajectory may be provided to one or more moveable cameras (e.g.,moveable camera 102 inFigure 1 ). The trajectory may be provided using any method of communication, including, but not limited to, wireless or wired communication methods. In an example, the trajectory may be provided to the same or different computing device as was used to determine perform at least a part ofmethod 900. The component may instruct or control one or more moveable cameras based on the provided flight trajectory. Flow terminates atoperation 916. -
Figures 10-13 and the associated descriptions provide a discussion of a variety of operating environments in which aspects of the disclosure may be practiced. However, the devices and systems illustrated and discussed with respect toFigures 10-13 are for purposes of example and illustration and are not limiting of a vast number of electronic device configurations that may be utilized for practicing aspects of the disclosure, as described herein. -
Figure 10 is a block diagram illustrating physical components (e.g., hardware) of anelectronic device 1000 with which aspects of the disclosure may be practiced. The components of theelectronic device 1000 described below may have computer executable instructions for generating a mailto link in an electronic communication application such as described above. - In a basic configuration, the
electronic device 1000 may include at least oneprocessing unit 1010 and asystem memory 1015. Depending on the configuration and type of electronic device, thesystem memory 1015 may comprise, but is not limited to, volatile storage (e.g., random access memory), non-volatile storage (e.g., read-only memory), flash memory, or any combination of such memories. Thesystem memory 1015 may include anoperating system 1025 and one ormore program modules 1020 suitable for parsing received responses, generating electronic messages, updating attendee lists and so on. - The
operating system 1025, for example, may be suitable for controlling the operation of theelectronic device 1000. Furthermore, embodiments of the disclosure may be practiced in conjunction with a graphics library, other operating systems, or any other application program and is not limited to any particular application or system. This basic configuration is illustrated inFigure 10 by those components within a dashedline 1030. - The
electronic device 1000 may have additional features or functionality. For example, theelectronic device 1000 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape. Such additional storage is illustrated inFigure 10 by aremovable storage device 1035 and anon-removable storage device 1040. - As stated above, a number of program modules and data files may be stored in the
system memory 1015. While executing on theprocessing unit 1010, the program modules 1020 (e.g., the trajectory generation component 1005) may perform processes including, but not limited to, the aspects, as described herein. - Furthermore, embodiments of the disclosure may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors. For example, embodiments of the disclosure may be practiced via a system-on-a-chip (SOC) where each or many of the components illustrated in
Figure 10 may be integrated onto a single integrated circuit. Such an SOC device may include one or more processing units, graphics units, communications units, system virtualization units and various application functionality all of which are integrated (or "burned") onto the chip substrate as a single integrated circuit. - When operating via an SOC, the functionality, described herein, with respect to the capability of the client to switch protocols may be operated via application-specific logic integrated with other components of the
electronic device 1000 on the single integrated circuit (chip). Embodiments of the disclosure may also be practiced using other technologies capable of performing logical operations such as, for example, AND, OR, and NOT, including but not limited to mechanical, optical, fluidic, and quantum technologies. In addition, embodiments of the disclosure may be practiced within a general purpose computer or in any other circuits or systems. - The
electronic device 1000 may also have one or more input device(s) 1045 such as a keyboard, a trackpad, a mouse, a pen, a sound or voice input device, a touch, force and/or swipe input device, etc. The output device(s) 1050 such as a display, speakers, a printer, etc. may also be included. The aforementioned devices are examples and others may be used. Theelectronic device 1000 may include one ormore communication connections 1055 allowing communications with otherelectronic devices 1060. Examples ofsuitable communication connections 1055 include, but are not limited to, radio frequency (RF) transmitter, receiver, and/or transceiver circuitry; universal serial bus (USB), parallel, and/or serial ports. - The term computer-readable media as used herein may include computer storage media. Computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, or program modules.
- The
system memory 1015, theremovable storage device 1035, and thenon-removable storage device 1040 are all computer storage media examples (e.g., memory storage). Computer storage media may include RAM, ROM, electrically erasable read-only memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other article of manufacture which can be used to store information and which can be accessed by theelectronic device 1000. Any such computer storage media may be part of theelectronic device 1000. Computer storage media does not include a carrier wave or other propagated or modulated data signal. - Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term "modulated data signal" may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
-
Figures 11A and11B illustrate a mobileelectronic device 1100, for example, a mobile telephone, a smart phone, wearable computer (such as a smart watch), a tablet computer, a laptop computer, and the like, with which embodiments of the disclosure may be practiced. With reference toFigure 11A , one aspect of a mobileelectronic device 1100 for implementing the aspects is illustrated. - In a basic configuration, the mobile
electronic device 1100 is a handheld computer having both input elements and output elements. The mobileelectronic device 1100 typically includes adisplay 1105 and one ormore input buttons 1110 that allow the user to enter information into the mobileelectronic device 1100. Thedisplay 1105 of the mobileelectronic device 1100 may also function as an input device (e.g., a display that accepts touch and/or force input). - If included, an optional
side input element 1115 allows further user input. Theside input element 1115 may be a rotary switch, a button, or any other type of manual input element. In alternative aspects, mobileelectronic device 1100 may incorporate more or less input elements. For example, thedisplay 1105 may not be a touch screen in some embodiments. In yet another alternative embodiment, the mobileelectronic device 1100 is a portable phone system, such as a cellular phone. The mobileelectronic device 1100 may also include anoptional keypad 1135.Optional keypad 1135 may be a physical keypad or a "soft" keypad generated on the touch screen display. - In various embodiments, the output elements include the
display 1105 for showing a graphical user interface (GUI), a visual indicator 1120 (e.g., a light emitting diode), and/or an audio transducer 1125 (e.g., a speaker). In some aspects, the mobileelectronic device 1100 incorporates a vibration transducer for providing the user with tactile feedback. In yet another aspect, the mobileelectronic device 1100 incorporates input and/or output ports, such as an audio input (e.g., a microphone jack), an audio output (e.g., a headphone jack), and a video output (e.g., a HDMI port) for sending signals to or receiving signals from an external device. -
Figure 11B is a block diagram illustrating the architecture of one aspect of a mobileelectronic device 1100. That is, the mobileelectronic device 1100 can incorporate a system (e.g., an architecture) 1140 to implement some aspects. In one embodiment, thesystem 1140 is implemented as a "smart phone" capable of running one or more applications (e.g., browser, e-mail, calendaring, contact managers, messaging clients, games, media clients/players, content selection and sharing applications and so on). In some aspects, thesystem 1140 is integrated as an electronic device, such as an integrated personal digital assistant (PDA) and wireless phone. - One or
more application programs 1150 may be loaded into thememory 1145 and run on or in association with theoperating system 1155. Examples of the application programs include phone dialer programs, e-mail programs, personal information management (PIM) programs, word processing programs, spreadsheet programs, Internet browser programs, messaging programs, and so forth. - The
system 1140 also includes anon-volatile storage area 1160 within thememory 1145. Thenon-volatile storage area 1160 may be used to store persistent information that should not be lost if thesystem 1140 is powered down. - The
application programs 1150 may use and store information in thenon-volatile storage area 1160, such as email or other messages used by an email application, and the like. A synchronization application (not shown) also resides on thesystem 1140 and is programmed to interact with a corresponding synchronization application resident on a host computer to keep the information stored in thenon-volatile storage area 1160 synchronized with corresponding information stored at the host computer. - The
system 1140 has apower supply 1165, which may be implemented as one or more batteries. Thepower supply 1165 may further include an external power source, such as an AC adapter or a powered docking cradle that supplements or recharges the batteries. - The
system 1140 may also include aradio interface layer 1170 that performs the function of transmitting and receiving radio frequency communications. Theradio interface layer 1170 facilitates wireless connectivity between thesystem 1140 and the "outside world," via a communications carrier or service provider. Transmissions to and from theradio interface layer 1170 are conducted under control of theoperating system 1155. In other words, communications received by theradio interface layer 1170 may be disseminated to theapplication programs 1150 via theoperating system 1155, and vice versa. - The
visual indicator 1120 may be used to provide visual notifications, and/or anaudio interface 1175 may be used for producing audible notifications via an audio transducer (e.g.,audio transducer 1125 illustrated inFigure 11A ). In the illustrated embodiment, thevisual indicator 1120 is a light emitting diode (LED) and theaudio transducer 1125 may be a speaker. These devices may be directly coupled to thepower supply 1165 so that when activated, they remain on for a duration dictated by the notification mechanism even though theprocessor 1185 and other components might shut down for conserving battery power. The LED may be programmed to remain on indefinitely until the user takes action to indicate the powered-on status of the device. - The
audio interface 1175 is used to provide audible signals to and receive audible signals from the user (e.g., voice input such as described above). For example, in addition to being coupled to theaudio transducer 1125, theaudio interface 1175 may also be coupled to a microphone to receive audible input, such as to facilitate a telephone conversation. In accordance with embodiments of the present disclosure, the microphone may also serve as an audio sensor to facilitate control of notifications, as will be described below. - The
system 1140 may further include avideo interface 1180 that enables an operation of peripheral device 1130 (e.g., on-board camera) to record still images, video stream, and the like. The captured images may be provided to the artificial intelligence entity advertisement system such as described above. - A mobile
electronic device 1100 implementing thesystem 1140 may have additional features or functionality. For example, the mobileelectronic device 1100 may also include additional data storage devices (removable and/or non-removable) such as, magnetic disks, optical disks, or tape. Such additional storage is illustrated inFigure 11B by thenon-volatile storage area 1160. - Data/information generated or captured by the mobile
electronic device 1100 and stored via thesystem 1140 may be stored locally on the mobileelectronic device 1100, as described above, or the data may be stored on any number of storage media that may be accessed by the device via theradio interface layer 1170 or via a wired connection between the mobileelectronic device 1100 and a separate electronic device associated with the mobileelectronic device 1100, for example, a server computer in a distributed computing network, such as the Internet. As should be appreciated such data/information may be accessed via the mobileelectronic device 1100 via theradio interface layer 1170 or via a distributed computing network. Similarly, such data/information may be readily transferred between electronic devices for storage and use according to well-known data/information transfer and storage means, including electronic mail and collaborative data/information sharing systems. - As should be appreciated,
Figures 11A and11B are described for purposes of illustrating the present methods and systems and is not intended to limit the disclosure to a particular sequence of steps or a particular combination of hardware or software components. -
Figure 12 illustrates one aspect of the architecture of asystem 1200 in which aspects of the disclosure may be practiced. The system may include a general electronic device 1210 (e.g., personal computer), tabletelectronic device 1215, or mobileelectronic device 1220, as described above. Each of these devices may include asurface point component 1225 and/or a camera position graph generation component such as described. The surface point component may be configured to generate one or more surface points as described herein. Surface points (and, in some examples, a camera position graph) may be transmitted to thetrajectory component 1235 which may provide, over thenetwork 1230, an optimal trajectory based on the provided information. - In some aspects, the
trajectory component 1235 may receive various types of information or content that is stored by thestore 1240 or transmitted from adirectory service 1245, aweb portal 1250,mailbox services 1255,instant messaging stores 1260, orsocial networking services 1265. - By way of example, the aspects described above may be embodied in a general electronic device 1210 (e.g., personal computer), a tablet
electronic device 1215 and/or a mobile electronic device 1220 (e.g., a smart phone). Any of these embodiments of the electronic devices may obtain content from or provide data to thestore 1240. - As should be appreciated,
Figure 12 is described for purposes of illustrating the present methods and systems and is not intended to limit the disclosure to a particular sequence of steps or a particular combination of hardware or software components. -
Figure 13 illustrates an example tabletelectronic device 1300 that may execute one or more aspects disclosed herein. In addition, the aspects and functionalities described herein may operate over distributed systems (e.g., cloud-based computing systems), where application functionality, memory, data storage and retrieval and various processing functions may be operated remotely from each other over a distributed computing network, such as the Internet or an intranet. User interfaces and information of various types may be displayed via on-board electronic device displays or via remote display units associated with one or more electronic devices. - For example, user interfaces and information of various types may be displayed and interacted with on a wall surface onto which user interfaces and information of various types are projected. Interaction with the multitude of computing systems with which embodiments of the invention may be practiced include, keystroke entry, touch screen entry, voice or other audio entry, gesture entry where an associated electronic device is equipped with detection (e.g., camera) functionality for capturing and interpreting user gestures for controlling the functionality of the electronic device, and the like.
- As should be appreciated,
Figure 13 is described for purposes of illustrating the present methods and systems and is not intended to limit the disclosure to a particular sequence of steps or a particular combination of hardware or software components. - As will be understood from the foregoing disclosure, one aspect of the technology relates to a system comprising: at least one processor; and a memory storing instructions which, when executed by the at least one processor, performs a method for recreating a three-dimensional scene using data captured from a moveable camera. The method comprises: receiving data captured by the moveable camera relating to the three-dimensional scene; generating a reconstruction of the three-dimensional scene based on the received data; identifying one or more surface points within the three-dimensional scene; generating a graph of a plurality of camera positions, comprising one or more nodes and one or more edges; determining, based on the graph, a subgradient of the one or more nodes; generating, based on the subgradient and the graph, an optimal trajectory for the moveable camera; and providing the optimal trajectory to the moveable camera. In an example, the data relating to the three-dimensional scene is received as a result of the moveable camera performing an initial pass of the three-dimensional scene. In another example, identifying one or more surface points within the three-dimensional scene comprises randomly generating one or more surface points based on the reconstruction. In a further example, generating the graph is based on at least one of the reconstruction and the one or more surface points. In yet another example, determining the subgradient comprises: identifying, from the plurality of camera positions, a camera position having a first highest marginal reward; computing, based on the identified camera position, a new marginal reward for each of the plurality of camera positions; and identifying, based on a new marginal reward, a camera position having a second highest marginal reward from the plurality of camera positions. In a further still example, generating the optimal trajectory comprises evaluating a cost associated with at least one of the one or more edges and a reward associated with at least one of the one or more nodes. In another example, the instructions further comprise receiving additional data captured by the moveable camera relating to the three-dimensional scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the three-dimensional scene based on the optimal trajectory.
- In another aspect, the technology relates to a computer-implemented method for generating an optimal trajectory for a moveable camera configured to scan a scene. The method comprises: receiving data captured by the moveable camera relating to the scene; generating a reconstruction of the scene based on the received data; identifying one or more surface points within the reconstruction; generating a graph of a plurality of camera positions, comprising one or more nodes and one or more edges; selecting, from the plurality of camera positions, a first camera position having a highest marginal reward; adding the first camera position to the optimal trajectory; determining, based on the optimal trajectory, if a constraint is met; when the constraint is not met, computing, based on the optimal trajectory, a new marginal reward for each of the plurality of camera positions; selecting, based on a new marginal reward, a second camera position having a second highest marginal reward; adding the second camera position to the optimal trajectory; and when the constraint is met, providing the optimal trajectory to the moveable camera. In an example, the data relating to the scene is received as a result of the moveable camera performing an initial pass of the scene. In another example, identifying one or more surface points within the scene comprises randomly generating one or more surface points based on the reconstruction. In a further example, generating the graph is based on at least one of the reconstruction and the one or more surface points. In yet another example, constraint relates to one of the amount of energy required by the moveable camera to navigate the trajectory, the amount of storage capacity required by the trajectory, and the amount of camera positions included by the trajectory. In a further still example, the method further comprises receiving additional data captured by the moveable camera relating to the scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the scene based on the optimal trajectory.
- In another aspect, the technology relates to a computer-implemented method for recreating a three-dimensional scene using data captured from a moveable camera. The method comprises: receiving data captured by the moveable camera relating to the three-dimensional scene; generating a reconstruction of the three-dimensional scene based on the received data; identifying one or more surface points within the three-dimensional scene; generating a graph of a plurality of camera positions, comprising one or more nodes and one or more edges; determining, based on the graph, a subgradient of the one or more nodes; generating, based on the subgradient and the graph, an optimal trajectory for the moveable camera; and providing the optimal trajectory to the moveable camera. In an example, the data relating to the three-dimensional scene is received as a result of the moveable camera performing an initial pass of the three-dimensional scene. In another example, identifying one or more surface points within the three-dimensional scene comprises randomly generating one or more surface points based on the reconstruction. In a further example, generating the graph is based on at least one of the reconstruction and the one or more surface points. In yet another example, determining the subgradient comprises: identifying, from the plurality of camera positions, a camera position having a first highest marginal reward; computing, based on the identified camera position, a new marginal reward for each of the plurality of camera positions; and identifying, based on a new marginal reward, a camera position having a second highest marginal reward from the plurality of camera positions. In a further still example, generating the optimal trajectory comprises evaluating a cost associated with at least one of the one or more edges and a reward associated with at least one of the one or more nodes. In another example, the method further comprises receiving additional data captured by the moveable camera relating to the three-dimensional scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the three-dimensional scene based on the optimal trajectory.
- Aspects of the present disclosure, for example, are described above with reference to block diagrams and/or operational illustrations of methods, systems, and computer program products according to aspects of the disclosure. The functions/acts noted in the blocks may occur out of the order as shown in any flowchart. For example, two blocks shown in succession may in fact be executed substantially concurrently or the blocks may sometimes be executed in the reverse order, depending upon the functionality/acts involved.
Claims (15)
- A system comprising:at least one processor (1010); anda memory (1015) storing instructions which, when executed by the at least one processor, performs a method for recreating a three-dimensional scene using data captured from a moveable camera, comprising:receiving (702) data captured by the moveable camera relating to the three-dimensional scene;generating (704) a reconstruction of the three-dimensional scene based on the received data;identifying (706) one or more surface points within the three-dimensional scene;generating (708) a graph of a plurality of camera positions, comprising one or more nodes and one or more edges;determining (710), based on the graph, a subgradient of the one or more nodes;generating (712), based on the subgradient and the graph, an optimal trajectory for the moveable camera; andproviding (714) the optimal trajectory to the moveable camera.
- The system of claim 1, wherein determining the subgradient comprises:identifying, from the plurality of camera positions, a camera position having a first highest marginal reward;computing, based on the identified camera position, a new marginal reward for each of the plurality of camera positions; andidentifying, based on a new marginal reward, a camera position having a second highest marginal reward from the plurality of camera positions.
- The system of claim 1, wherein generating the optimal trajectory comprises evaluating a cost associated with at least one of the one or more edges and a reward associated with at least one of the one or more nodes.
- A computer-implemented method for generating an optimal trajectory for a moveable camera configured to scan a scene, comprising:receiving (902) data captured by the moveable camera relating to the scene;generating (904) a reconstruction of the scene based on the received data;identifying (906) one or more surface points within the reconstruction;generating (908) a graph of a plurality of camera positions, comprising one or more nodes and one or more edges;selecting (912), from the plurality of camera positions, a first camera position having a highest marginal reward;adding the first camera position to the optimal trajectory;determining (914), based on the optimal trajectory, if a constraint is met;when the constraint is not met, computing, based on the optimal trajectory, a new marginal reward for each of the plurality of camera positions;selecting (912), based on a new marginal reward, a second camera position having a second highest marginal reward;adding the second camera position to the optimal trajectory; andwhen the constraint is met, providing (916) the optimal trajectory to the moveable camera.
- The computer-implemented method of claim 4, wherein the constraint relates to one of the amount of energy required by the moveable camera to navigate the trajectory, the amount of storage capacity required by the trajectory, and the amount of camera positions included by the trajectory.
- The computer-implemented method of claim 4, further comprising:
receiving additional data captured by the moveable camera relating to the scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the scene based on the optimal trajectory. - A computer-implemented method for recreating a three-dimensional scene using data captured from a moveable camera, comprising:receiving (702) data captured by the moveable camera relating to the three-dimensional scene;generating (704) a reconstruction of the three-dimensional scene based on the received data;identifying (706) one or more surface points within the three-dimensional scene;generating (708) a graph of a plurality of camera positions, comprising one or more nodes and one or more edges;determining (710), based on the graph, a subgradient of the one or more nodes;generating (712), based on the subgradient and the graph, an optimal trajectory for the moveable camera; andproviding (714) the optimal trajectory to the moveable camera.
- The computer-implemented method of claim 7, wherein the data relating to the three-dimensional scene is received as a result of the moveable camera performing an initial pass of the three-dimensional scene.
- The computer-implemented method of claim 7, wherein generating the graph is based on at least one of the reconstruction and the one or more surface points.
- The computer-implemented method of claim 7, further comprising:
receiving additional data captured by the moveable camera relating to the three-dimensional scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the three-dimensional scene based on the optimal trajectory. - The system of claim 1, wherein identifying one or more surface points within the three-dimensional scene comprises randomly generating one or more surface points based on the reconstruction.
- The system of claim 1, further comprising instructions for:
receiving additional data captured by the moveable camera relating to the three-dimensional scene, wherein the additional data is received as a result of the moveable camera performing a subsequent pass of the three-dimensional scene based on the optimal trajectory. - The computer-implemented method of claim 4, wherein generating the graph is based on at least one of the reconstruction and the one or more surface points.
- The computer-implemented method of claim 7, wherein determining the subgradient comprises:identifying, from the plurality of camera positions, a camera position having a first highest marginal reward;computing, based on the identified camera position, a new marginal reward for each of the plurality of camera positions; andidentifying, based on a new marginal reward, a camera position having a second highest marginal reward from the plurality of camera positions.
- The computer-implemented method of claim 7, wherein generating the optimal trajectory comprises evaluating a cost associated with at least one of the one or more edges and a reward associated with at least one of the one or more nodes.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201762446119P | 2017-01-13 | 2017-01-13 | |
US15/593,556 US10602056B2 (en) | 2017-01-13 | 2017-05-12 | Optimal scanning trajectories for 3D scenes |
PCT/US2017/067158 WO2018132224A1 (en) | 2017-01-13 | 2017-12-19 | Optimal scanning trajectories for 3d scenes |
Publications (2)
Publication Number | Publication Date |
---|---|
EP3568970A1 EP3568970A1 (en) | 2019-11-20 |
EP3568970B1 true EP3568970B1 (en) | 2021-01-20 |
Family
ID=60997550
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP17830063.8A Active EP3568970B1 (en) | 2017-01-13 | 2017-12-19 | Optimal scanning trajectories for 3d scenes |
Country Status (4)
Country | Link |
---|---|
US (1) | US10602056B2 (en) |
EP (1) | EP3568970B1 (en) |
CN (1) | CN110178364B (en) |
WO (1) | WO2018132224A1 (en) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP3349086A1 (en) * | 2017-01-17 | 2018-07-18 | Thomson Licensing | Method and device for determining a trajectory within a 3d scene for a camera |
JP6946087B2 (en) * | 2017-07-14 | 2021-10-06 | キヤノン株式会社 | Information processing device, its control method, and program |
CN110209846A (en) * | 2019-04-25 | 2019-09-06 | 深圳大学 | Data set construction method, device and terminal device based on unmanned plane instruction sequence |
CN111026272B (en) * | 2019-12-09 | 2023-10-31 | 网易(杭州)网络有限公司 | Training method and device for virtual object behavior strategy, electronic equipment and storage medium |
CN112351438B (en) * | 2020-11-04 | 2022-12-02 | 南京航空航天大学 | Unmanned aerial vehicle base station deployment method based on undirected graph |
Family Cites Families (24)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8350895B2 (en) | 1997-09-04 | 2013-01-08 | Dann M Allen | Stereo pair and method of making stereo pairs |
US7363157B1 (en) * | 2005-02-10 | 2008-04-22 | Sarnoff Corporation | Method and apparatus for performing wide area terrain mapping |
US8060270B2 (en) | 2008-02-29 | 2011-11-15 | The Boeing Company | System and method for inspection of structures and objects by swarm of remote unmanned vehicles |
FR2961601B1 (en) * | 2010-06-22 | 2012-07-27 | Parrot | METHOD FOR EVALUATING THE HORIZONTAL SPEED OF A DRONE, IN PARTICULAR A DRONE SUITABLE FOR AUTOPILOT STATIONARY FLIGHT |
EP2423871B1 (en) * | 2010-08-25 | 2014-06-18 | Lakeside Labs GmbH | Apparatus and method for generating an overview image of a plurality of images using an accuracy information |
US8965598B2 (en) * | 2010-09-30 | 2015-02-24 | Empire Technology Development Llc | Automatic flight control for UAV based solid modeling |
US8860825B2 (en) * | 2012-09-12 | 2014-10-14 | Google Inc. | Methods and systems for removal of rolling shutter effects |
US9464902B2 (en) | 2013-09-27 | 2016-10-11 | Regents Of The University Of Minnesota | Symbiotic unmanned aerial vehicle and unmanned surface vehicle system |
CN103809597B (en) * | 2014-02-18 | 2016-09-21 | 清华大学 | The flight path planning method of unmanned plane and unmanned plane |
US9476730B2 (en) * | 2014-03-18 | 2016-10-25 | Sri International | Real-time system for multi-modal 3D geospatial mapping, object recognition, scene annotation and analytics |
CN103941748B (en) * | 2014-04-29 | 2016-05-25 | 百度在线网络技术(北京)有限公司 | Autonomous navigation method and system and Map building method and system |
JP6124384B2 (en) | 2014-05-30 | 2017-05-10 | エスゼット ディージェイアイ テクノロジー カンパニー リミテッドSz Dji Technology Co.,Ltd | Method, system, and program for creating direction of travel of drone |
US9494937B2 (en) | 2014-06-20 | 2016-11-15 | Verizon Telematics Inc. | Method and system for drone deliveries to vehicles in route |
WO2016003555A2 (en) | 2014-07-01 | 2016-01-07 | Scanifly, LLC | Device, method, apparatus, and computer-readable medium for solar site assessment |
WO2016029169A1 (en) | 2014-08-22 | 2016-02-25 | Cape Productions Inc. | Methods and apparatus for unmanned aerial vehicle autonomous aviation |
US9618934B2 (en) | 2014-09-12 | 2017-04-11 | 4D Tech Solutions, Inc. | Unmanned aerial vehicle 3D mapping system |
US9446858B2 (en) | 2014-09-18 | 2016-09-20 | Kevin Hess | Apparatus and methods for tethered aerial platform and system |
US9855658B2 (en) | 2015-03-19 | 2018-01-02 | Rahul Babu | Drone assisted adaptive robot control |
US9486921B1 (en) * | 2015-03-26 | 2016-11-08 | Google Inc. | Methods and systems for distributing remote assistance to facilitate robotic object manipulation |
US9989965B2 (en) * | 2015-08-20 | 2018-06-05 | Motionloft, Inc. | Object detection and analysis via unmanned aerial vehicle |
CN105447853B (en) * | 2015-11-13 | 2018-07-13 | 深圳市道通智能航空技术有限公司 | Flight instruments, flight control system and method |
US10372968B2 (en) * | 2016-01-22 | 2019-08-06 | Qualcomm Incorporated | Object-focused active three-dimensional reconstruction |
US9495764B1 (en) * | 2016-03-21 | 2016-11-15 | URC Ventures, Inc. | Verifying object measurements determined from mobile device images |
US9975632B2 (en) * | 2016-04-08 | 2018-05-22 | Drona, LLC | Aerial vehicle system |
-
2017
- 2017-05-12 US US15/593,556 patent/US10602056B2/en active Active
- 2017-12-19 WO PCT/US2017/067158 patent/WO2018132224A1/en unknown
- 2017-12-19 EP EP17830063.8A patent/EP3568970B1/en active Active
- 2017-12-19 CN CN201780083406.2A patent/CN110178364B/en active Active
Non-Patent Citations (1)
Title |
---|
None * |
Also Published As
Publication number | Publication date |
---|---|
CN110178364B (en) | 2021-03-09 |
CN110178364A (en) | 2019-08-27 |
US10602056B2 (en) | 2020-03-24 |
WO2018132224A1 (en) | 2018-07-19 |
EP3568970A1 (en) | 2019-11-20 |
US20180367728A1 (en) | 2018-12-20 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP3568970B1 (en) | Optimal scanning trajectories for 3d scenes | |
US11165959B2 (en) | Connecting and using building data acquired from mobile devices | |
Li et al. | Applications of multirotor drone technologies in construction management | |
US20210342669A1 (en) | Method, system, and medium for processing satellite orbital information using a generative adversarial network | |
US9830679B2 (en) | Shared virtual reality | |
CN108351649A (en) | System and method for UAV interactive instructions and control | |
Beretta et al. | Automated lithological classification using UAV and machine learning on an open cast mine | |
US10767975B2 (en) | Data capture system for texture and geometry acquisition | |
US20190340317A1 (en) | Computer vision through simulated hardware optimization | |
Freimuth et al. | A framework for automated acquisition and processing of as-built data with autonomous unmanned aerial vehicles | |
Mourtzis et al. | Unmanned Aerial Vehicle (UAV) path planning and control assisted by Augmented Reality (AR): The case of indoor drones | |
KR20220143957A (en) | Determining traversable space from a single image | |
EP4070169B1 (en) | Electronic apparatus and controlling method thereof | |
CA3069813A1 (en) | Capturing, connecting and using building interior data from mobile devices | |
CN118696349A (en) | High-speed real-time scene reconstruction from input image data | |
US20180225836A1 (en) | Scene reconstruction from bursts of image data | |
Park et al. | Pilot study of low-light enhanced terrain mapping for robotic exploration in lunar psrs | |
Niedzwiedzki et al. | Real-time parallel-serial LiDAR-based localization algorithm with centimeter accuracy for GPS-denied environments | |
Buck et al. | Unreal engine-based photorealistic aerial data generation and unit testing of artificial intelligence algorithms | |
Haibt | End-to-end digital twin creation of the archaeological landscape in Uruk-Warka (Iraq) | |
US20220012462A1 (en) | Systems and Methods for Remote Measurement using Artificial Intelligence | |
KR102568651B1 (en) | Phase map forming device and method for generating movement paths of multiple unmanned moving objects | |
US20220375175A1 (en) | System For Improving The Precision and Accuracy of Augmented Reality | |
US20240233276A1 (en) | Interior/exterior building walkthrough image interface | |
Li et al. | KP-Cartographer: A Lightweight SLAM Approach Based on Cartographer |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: UNKNOWN |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE INTERNATIONAL PUBLICATION HAS BEEN MADE |
|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: REQUEST FOR EXAMINATION WAS MADE |
|
17P | Request for examination filed |
Effective date: 20190626 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
AX | Request for extension of the european patent |
Extension state: BA ME |
|
DAV | Request for validation of the european patent (deleted) | ||
DAX | Request for extension of the european patent (deleted) | ||
GRAP | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOSNIGR1 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: GRANT OF PATENT IS INTENDED |
|
INTG | Intention to grant announced |
Effective date: 20200810 |
|
GRAS | Grant fee paid |
Free format text: ORIGINAL CODE: EPIDOSNIGR3 |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: THE PATENT HAS BEEN GRANTED |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): AL AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HR HU IE IS IT LI LT LU LV MC MK MT NL NO PL PT RO RS SE SI SK SM TR |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: EP |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R096 Ref document number: 602017031833 Country of ref document: DE |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: REF Ref document number: 1357357 Country of ref document: AT Kind code of ref document: T Effective date: 20210215 |
|
REG | Reference to a national code |
Ref country code: IE Ref legal event code: FG4D |
|
REG | Reference to a national code |
Ref country code: NL Ref legal event code: FP |
|
REG | Reference to a national code |
Ref country code: LT Ref legal event code: MG9D |
|
REG | Reference to a national code |
Ref country code: AT Ref legal event code: MK05 Ref document number: 1357357 Country of ref document: AT Kind code of ref document: T Effective date: 20210120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: BG Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210420 Ref country code: LT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: GR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210421 Ref country code: FI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: HR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: NO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210420 Ref country code: PT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210520 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: AT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: LV Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: PL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: RS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: SE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210520 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R097 Ref document number: 602017031833 Country of ref document: DE |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SM Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: CZ Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: EE Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
RAP4 | Party data changed (patent owner data changed or rights of a patent transferred) |
Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC |
|
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: SK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: RO Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
26N | No opposition filed |
Effective date: 20211021 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: AL Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 Ref country code: ES Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: SI Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: IS Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210520 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MC Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
REG | Reference to a national code |
Ref country code: CH Ref legal event code: PL |
|
REG | Reference to a national code |
Ref country code: BE Ref legal event code: MM Effective date: 20211231 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LU Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20211219 Ref country code: IE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20211219 |
|
REG | Reference to a national code |
Ref country code: DE Ref legal event code: R079 Ref document number: 602017031833 Country of ref document: DE Free format text: PREVIOUS MAIN CLASS: H04N0005232000 Ipc: H04N0023600000 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: BE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20211231 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: LI Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20211231 Ref country code: CH Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20211231 |
|
P01 | Opt-out of the competence of the unified patent court (upc) registered |
Effective date: 20230430 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: CY Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: HU Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT; INVALID AB INITIO Effective date: 20171219 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: NL Payment date: 20231121 Year of fee payment: 7 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: GB Payment date: 20231124 Year of fee payment: 7 |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: FR Payment date: 20231122 Year of fee payment: 7 Ref country code: DE Payment date: 20231121 Year of fee payment: 7 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MK Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: MT Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20210120 |