Image-based localization techniques may be utilized by mobile display devices, robots, drones and other devices to estimate their position and orientation in a physical environment. For example, one or more images captured by a device may be compared to a precomputed map representing a 3D reconstruction of the space.
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. Furthermore, the claimed subject matter is not limited to implementations that solve any or all disadvantages noted in any part of this disclosure.
A method for estimating a camera pose includes recognizing a three-dimensional (3D) map representing a physical environment, the 3D map including a plurality of 3D map features defined as 3D points distributed throughout the 3D map. An obfuscated image representation is received, the representation derived from an original unobfuscated image of the physical environment captured by a camera. The representation includes a plurality of obfuscated features, each including (i) a two-dimensional (2D) line that passes through a 2D point in the original unobfuscated image at which an image feature was detected, and (ii) a feature descriptor that describes the image feature associated with the 2D point that the 2D line of the obfuscated feature passes through. Correspondences are determined between the obfuscated features and the 3D map features of the 3D map of the physical environment. Based on the determined correspondences, a six degree of freedom pose of the camera in the physical environment is estimated.
A wide variety of devices and related technologies may utilize image-based localization techniques. Examples may include wearable computing devices, such as head-mounted display (HMD) devices that provide augmented reality and/or virtual reality experiences, robotic machines, and self-driving vehicles. These and other devices may use image-based localization techniques to determine their position and orientation (i.e., pose) in a physical environment. Herein, such devices will be referred to as “camera devices.” Camera devices may have any suitable hardware and assume mobile or non-mobile form factors. Camera device 104, camera device 300, and computing system 1200 described below with respect to
Some approaches to image-based localization utilize knowledge of a prior three-dimensional (3D) map or scene model of a physical environment. The 3D map is essentially a spatial database including geometric data. In some examples, the geometric data includes points defined in three dimensions (e.g., x, y, z) distributed throughout 3D space to form a 3D point cloud reconstruction of the scene. The 3D points are associated with feature descriptors (e.g., multi-dimensional vectors) extracted from the source images or videos used to construct the map. Thus, the 3D points may be referred to as 3D map features of a 3D map of the physical environment.
Given a 3D map of a physical environment and using one or more images or videos captured by a camera, an image-based localization task may estimate the 3D position (x, y, z) and 3D orientation (roll, pitch, yaw) of the camera within the physical environment. Camera localization algorithms may solve this task in two steps—first by matching 2D point features in the captured image(s) to 3D map features stored in the 3D map as 3D points. Next, the 6 degree-of-freedom (6DOF) pose of the camera may be computed using the 2D point to 3D point matches and their underlying coordinates.
In some cases, camera localization may be performed by a device other than the camera device used to capture the images, potentially conserving processing, battery, and/or storage resources of the camera device. For instance, the images may be transmitted to a remote device (e.g., server) that has access to the 3D map of the physical environment and performs the processing steps used to estimate the camera pose. Furthermore, transmitting images to a remote device alleviates the need for the 3D map to be shared with third parties, which can infer information about the physical environment based on the 3D map. The camera pose optionally may be transmitted back to the camera device. In some examples, however, images used to determine the camera pose may include sensitive, confidential, and/or private information related to the depicted physical environment. For example, the images may depict user faces, sensitive or personal items present in the scene, confidential information, etc. This presents a privacy concern when the images are transmitted to a remote device, as a user of the camera device may not wish for their private images to be transmitted to or stored on a remote device that they do not control.
Notably, image localization may be done on the basis of only the image features detected within the image. Thus, the actual image content (e.g., pixel values) need not be transmitted to the remote device, provided the image features (e.g., the 2D locations of the image features and their associated feature descriptors) are available to the remote device. However, it is possible in some cases to recreate a lossy representation of an original image based on information associated with the image features, namely the 2D positions at which the image features were detected in the image and the associated feature descriptors. In other words, upon receiving the 2D pixel positions of the image features within the image, along with the associated feature descriptors, a remote device may recreate images of a user's current surroundings, therefore potentially revealing private information.
The present disclosure addresses the above confidentiality and privacy concerns by obfuscating image features transmitted to a remote device. Specifically, upon capturing an image of a physical environment, a device may detect image features in the image, and generate a plurality of obfuscated features that represent the image features without revealing their associated 2D positions. Specifically, each obfuscated feature may include a 2D line that passes through the 2D position at which an image feature was detected, and a feature descriptor that describes the image feature. The obfuscated features may be transmitted to a remote device as part of an obfuscated image representation for the purpose of camera pose estimation. Notably, the obfuscated image representation does not include the 2D positions of the image features, making it significantly more difficult, if not impossible, for the remote device to recreate the original image. Nevertheless, the obfuscated image representation may include sufficient information for the remote device to estimate the pose of the camera relative to the 3D map of the physical environment. Thus, privacy concerns associated with transmission of potentially private information to a remote device may be mitigated, while preserving advantages of using a remote device to perform camera localization, such as conservation of processing, storage, and battery resources of the camera device.
Environment 102 includes a structure 104, which in this case is a famous building. As discussed above, image 100 of physical environment 102 captured by a camera device may be transmitted to a remote device (e.g., server) for camera pose estimation. For instance, the remote device may have previously acquired a 3D map of the physical environment, the 3D map including a plurality of 3D map features. The map features may be characterized as a 3D point cloud representing a reconstruction of the physical environment. By determining correspondences between map features in the 3D map and image features detected in the image, the pose of the camera device at the time image 100 was captured may be deduced.
However, the image of environment 102 also includes a user 106 whose face is clearly visible in the image. The user may not wish for an image of their face to be transmitted to a remote device that the user does not control, as this presents a privacy concern. Even in the case where the remote device is trusted or controlled by the user (e.g., a personal or company-owned server), the image may be intercepted en route, and/or unlawfully retrieved from the server by another party. Furthermore, even when the information transmitted to the server only includes image features detected in the image and not the image pixel values themselves, it may be possible to recreate a lossy representation of the image, which can reveal the user's face.
Accordingly,
At 202, method 200 of
In
Returning to
With reference now to
Image features may take a variety of suitable forms and may be detected in a variety of suitable ways. As one example, the image features may be scale invariant feature transform (SIFT) features. A SIFT feature includes a SIFT keypoint, which stores geometric information relevant to the feature, including the 2D position, scale, and one-dimensional angular orientation of the feature. A SIFT feature also includes a feature descriptor, which is implemented as a 128-dimensional vector. A multi-step process may be used to detect SIFT features in an image. It will be understood, however, that this process is provided as an example. Any suitable approach for extracting local features may be used for identifying image features, and such image features need not be SIFT features. As another example, detected image features may be speeded-up robust features (SURF).
To identify SIFT features, multiple copies of the original image may be generated such that each new copy is progressively blurred. In some cases, once a predetermined number of blurred images is created, a new copy of the original image may be created that has a reduced size (e.g., half-size) as compared to the original image. Progressively blurred copies of the reduced size image may then be generated, and this may be repeated any number of times to give any number of sets (or “octaves) of image copies, each set having a different scale. The set of image copies may in some cases be referred to as a “scale space.”
Once the scale space is generated, a Difference of Gaussian (DoG) operation may be performed to identify differences between image copies having the same scale (i.e., in the same octave). In other words, for two blurred copies of the original image having the same scale, with one copy being more blurred than the other, a DoG image is generated that indicates differences in pixel values between the two blurred copies. For example, any pixels that are the same in both blurred images (i.e., difference is zero) may be represented as black in the DoG image. Pixels that differ between the two blurred copies (i.e., difference is non-zero) may be represented in the DoG image with a non-black grayscale value, such that greater differences in pixel values are represented as being more white than smaller differences in pixel values. This results in sets of DoG images in which regions of higher variability in the original image (e.g., corners or edges within the image) are lighter in color than regions having less variability. Any suitable number of DoG images may be generated, depending on how many octaves of blurred image copies were generated.
Next, local maxima and minima may be identified within at least some of the DoG images. This may be done by checking, for each pixel in a given DoG image, whether that pixel has the highest or lowest value relative to some number (e.g., 26) of neighbor pixels. Once maxima and minima are identified at the pixel level, a Taylor expansion may be applied to maxima and minima within the DoG images to find the subpixel-level maxima and minima.
At least some of the identified maxima and minima may have relatively low contrast in the original image, lie along edges, and/or be generally unsuitable as image features. Thus, some number of maxima and minima may be excluded as SIFT features. This may be done by first excluding any pixels having less than a threshold intensity, which may be set to any suitable value depending on the total desired number and distinctiveness of final features. Next, for each potential feature, two perpendicular gradients may be calculated in the pixel vicinity of the potential feature and subtracted from each other. If the potential feature lies away from an edge or corner, both gradients will likely be small, and the difference will be near-zero. Similarly, if the potential feature lies at a corner, then both gradients will be large and the difference will again be near-zero. Potential features that lie along an edge will have a large gradient and a small gradient, for a relatively larger difference. Because features lying along edges are generally less desirable than corner features, edge features may be discarded. In some cases, corner features may be calculated using the Harris corner detector.
Once the final set of SIFT features has been identified, the keypoint orientations and feature descriptors may be calculated. Keypoint orientation may be calculated by evaluating gradient directions and magnitudes in the pixel vicinity of the feature, which can be collected in a histogram having a set number of bins (e.g., each bin corresponding to a range of angles). A highest magnitude bin may be set as the keypoint orientation. In cases where multiple high magnitude orientations are present, a single feature may be divided into multiple features, each having different orientations.
The SIFT feature descriptors may be calculated by examining a 16×16 window around each feature. For sixteen 4×4 windows within the 16×16 window, gradient magnitudes and orientations may be calculated and added to separate 8-bin histograms. In some cases, the magnitude with which an orientation is represented in a histogram may be weighted based on proximity to the feature. When 8-bin histograms are filled for each 4×4 window, 128 values representing the feature may be obtained (sixteen windows each filling eight histogram bins gives 128 total values). These 128 values may be normalized—for example by dividing by the root of total squares—to give a final 128-dimensional vector for each of the plurality of identified SIFT features. Thus, each SIFT feature detected in the image may have a two-dimensional pixel position, a scale, an orientation, and a SIFT feature descriptor. However, in other implementations, other types of feature descriptors may be used.
Turning again to
This is illustrated in
With reference now to
In this manner and with reference now to
In some examples, the 2D direction for each of the 2D lines associated with the obfuscated features may be selected from a predetermined number of different 2D directions. Any suitable predetermined number of directions may be established and utilized. For example, 100 different directions may be predetermined and stored by a camera device. Each of the obfuscated feature lines may be randomly orientated with one of the 100 different directions. In another example, a random direction may be chosen from 256 predetermined directions, such that the direction of each feature line may be expressed as an 8-bit value. In general, however, any number of potential random directions may be established and selected from.
Returning again to
The obfuscated image representation includes the plurality of obfuscated features, which include the 2D lines and feature descriptors described above. Notably, as shown in
This is schematically illustrated in
Furthermore, as will be discussed in more detail below, in some cases it may be desirable to further obfuscate the image features prior to transmission of the obfuscated image representation. Thus, for each of the feature descriptors in the obfuscated image representation, the camera device may apply a randomly selected permutation from a set of predefined permutations that is known to both the camera device and remote device. When the feature descriptors are multi-dimensional vectors, applying a permutation may include applying any of a set of predefined modifications to one or more of the values defining the vector. This may provide an additional defense against attempts by the remote device or a malicious actor to infer private information from an obfuscated image representation.
Communication between the camera device and remote device may be achieved in any suitable way. As examples, the camera device and remote device may be communicatively coupled using a wired connection or may employ a wireless connection via Wi-Fi, Bluetooth, or any other suitable wireless communication protocol. The network 320 may take the form of a local area network (LAN), wide area network (WAN), wired network, wireless network, personal area network, cellular network, or a combination thereof, and may include the Internet.
Returning again to
Turning now to
At 702, method 700 includes recognizing a 3D map of a physical environment including a plurality of 3D map features representing the physical environment. In some examples, the 3D map features may take the form of a 3D point cloud representing a reconstruction of the environment. As will be discussed in more detail below, in some cases the 3D map of the environment may itself be obfuscated. The 3D map may include any suitable number of points—in some examples, a 3D point cloud may include 20,000, 30,000 or more 3D points that denote various locations on surfaces within the physical environment.
Such a 3D map may be generated in any suitable way. In general, a physical environment will be mapped using a suitable imaging device that captures a plurality of images or videos of the physical environment from different positions. These images may be grayscale images, color images, depth images, etc. Image features may be detected in each image, as discussed above. By detecting image features that are common to more than one of the captured images, the spatial relationship between the images may be determined. The distance between each image feature and the imaging system may be inferred from the observed parallax shift when the same image feature is detected in multiple images captured from different positions. Additionally, or alternatively, depth information from a depth camera may be used to identify the dimensions of the physical environment and the distances between the imaging system and each image feature. In some implementations, the pose of the imaging system may be tracked as it captures the plurality of images, providing additional information that can be used to stitch the plurality of images into a 3D representation of the physical environment.
As noted above, each of the 3D points are associated with feature descriptors extracted from the source images that are used to construct the 3D map. A feature descriptor may comprise a multi-dimensional vector that encodes the appearance of a surface around a 3D point. For example, an image patch (such as 32×32 pixels) around a given pixel of a 3D point may encode the appearance of a surface around that point into a feature descriptor that is more compact.
Feature descriptors need not be generated at every 3D pixel of a 3D point cloud. In some examples, feature descriptors may be selectively generated at distinguishing features of the map, such as corners, highly textured areas, etc. In this manner, feature descriptors of obfuscated features in an obfuscated image representation may be more easily matched with corresponding 3D map features in the 3D map. Additionally, in some examples an initially-generated point cloud may be decimated to reduce the density of 3D points included in the cloud. For example, a subset of representative 3D points may be selected in the point cloud, and non-selected 3D points within a predetermined distance of the selected 3D points may be discarded. In this manner, the resulting decimated 3D point cloud may be more quickly loaded and more easily processed by the remote device.
As used in
Turning briefly to
Returning to
Turning again to
In general, the remote device identifies correspondences between the 2D lines in the obfuscated features and the 3D points of the 3D map features. This is done by searching the 3D map for the feature descriptors associated with each obfuscated feature and identifying the 3D map features having the most similar feature descriptors in the 3D point cloud. In other words, determining the correspondences may include identifying a set of obfuscated features having feature descriptors that match feature descriptors of 3D map features in the 3D map. As a result, the 2D line of each obfuscated feature in the set corresponds to a 3D point associated with a 3D map feature, giving a set of 2D line to 3D point correspondences. This feature descriptor matching step can be implemented using one of many nearest neighbor matching techniques. The L2-distance between the descriptor vectors may be used to calculate the pairwise feature similarity.
Notably, not all of the determined correspondences are necessarily correct. In practice, some number of incorrect correspondences may be determined. This is because the underlying feature descriptors can be ambiguous and do not always allow sufficient discrimination between a feature descriptor of an obfuscated feature and multiple feature descriptors associated with 3D points in the map.
The image of the physical environment may include items, objects, people, etc., that were not present when the physical environment was mapped. Thus, one or more image features may be detected in the image that are not represented in the 3D map of the physical environment. Typically, such obfuscated features will not correspond to any 3D points in the map. This may be advantageous in some scenarios, as any private details depicted in the image will likely not correspond to any 3D map features in the 3D map, thus limiting the amount of information that the remote device can infer about the private details. There may also be some number of 3D points in the map that do not match any of the obfuscated features in the obfuscated image representation.
Determining correspondences between obfuscated features and 3D map features is illustrated with respect to
The 2D lines associated with the obfuscated features can be thought of as the projection of a unique 3D plane that originates from the camera projection center and passes through the 2D line. Put another way, each 3D plane represents a back-projection of a 2D line into 3D space in the camera coordinate system. This is illustrated in
Each correspondence between a 2D line and a 3D point in the 3D map provides one constraint on the camera pose solution space. This is because, given the correct camera pose in the 3D map coordinate system, the back-projected 3D plane for a 2D line must pass through the 3D point in the map associated with a 3D map feature that corresponds to the 2D line's obfuscated feature. Thus, a single correspondence between a 2D line and a 3D point represents a nonlinear constraint on the six unknown variables that correspond to the six degree of freedom camera pose. Depending on the specific algorithm used, in order to compute the camera pose, six such correspondences, and therefore six constraints, may be used. The six constraints can be written in the form of a system of multivariate polynomial equations in six variables. In one example, when six 3D plane to 3D point correspondences are known, a minimal solver may calculate a set of eight candidate camera poses by solving an algorithm that outputs pose solutions based on 3D plane to 3D point correspondences. This may be done in a similar manner as that described in A minimal solution for registration of 3D points to 3D planes, Ramalingam et al., 2010, with the exception that Cayley Parameterization may be used for the 3D rotation matrices, which results in a set of polynomial equations having fewer solutions.
In
As noted above, not every 2D line in the obfuscated image representation will necessarily have a corresponding 3D map feature in the 3D map. Similarly, not every 3D map feature will have a corresponding obfuscated feature. This may be advantageous in some scenarios, as any private information included in the image (e.g., faces, personal objects) that were not present when the physical environment was mapped will not correspond to 3D map features. In a specific scenario, image features detected in image 100 associated with structure 104 may be relatively likely to have corresponding 3D map features in the 3D map. Thus, the camera pose relative to the structure may be determined. However, image features that correspond to user 106 will not have corresponding 3D map features, as the user was likely not at the depicted position when the physical environment was mapped.
This is illustrated in
Returning briefly to
To begin, the remote device may identify a subset of correspondences from the overall set of determined 2D line to 3D point correspondences. This is schematically shown in
In some cases, the number of correspondences in the identified subset may correspond to a minimal number of data points necessary to calculate a finite number of solutions using a method known as a minimal solver. For instance, when fitting a 2D line to 2D points, a minimum of two unique data points are needed to find a unique 2D line (single solution) that exactly passes through the 2D points. A single data point, on the other hand, could be consistent with an infinite number of potential solutions. Thus, for this line fitting toy example, two data points are the minimum number required for a minimal solver. A non-minimal solver, by contrast, may use more than two data points.
Continuing with the 2D line fitting example, a plurality of subsets of 2D data point pairs may be selected. In a RANSAC framework, these subsets are selected at random. If the minimal solver is applied to each subset (i.e., pair of 2D points), different potential solutions may be found from each subset. However, some potential solutions (2D lines) will be more consistent with the input data than other potential solutions. In other words, some potential lines will pass through more 2D points in the dataset than others. In RANSAC, for each potential solution identified by a minimal solver, the solution (i.e., 2D line) is compared to other 2D data points in the dataset to determine which points are consistent with the proposed solution (i.e., “inliers”) vs which points are not consistent with the proposed solution (i.e., “outliers”). Any solution that has the highest inlier to outlier ratio, or has at least a threshold number of total inliers, may be accepted as the actual solution—e.g., 2D the line that best fits the set of 2D points.
Returning to the camera pose estimation problem, depending on the information available, a minimal solver may output a finite number of solutions or potential pose candidates from a minimal subset of determined correspondences. In other words, for each identified subset of correspondences, the remote device may calculate a set of candidate camera poses that satisfy the subset of correspondences. For instance, when the subset of correspondences includes six 2D line to 3D point correspondences, a minimal solver may output sixteen candidate camera poses. This 6-pt solver may be implemented by solving a system of polynomial equations using Grobner basis techniques. Examples of such techniques are described in A minimal solution for registration of 3D points to 3D planes, Ramalingam et al., 2010, and A theory of minimal 3D point to 3D plane registration and its generalization, Ramalingam and Taguchi, 2013. As shown in
As an alternative to the 6-pt minimal solver, a linear pose estimation approach may be used that relies on twelve 2D line to 3D point correspondences and outputs only a single solution, or candidate camera pose. Even though this approach may involve additional RANSAC iterations as compared to the approach that uses the 6-pt minimal solver, each iteration may be more computationally efficient, thereby reducing the overall processing time. An example of a suitable linear pose estimation approach is described in Direct 6-DoF Pose Estimation from Point-Plane Correspondences, Khoshelham, 2015.
The number of correspondences required for the minimal solver may in some cases be reduced when some information about the camera's pose is already known. For instance, when capturing the image of the physical environment, the camera device may detect a gravity vector relative to its current pose (e.g., via onboard 3-axis accelerometer). This gravity vector may in some cases be included in the obfuscated image representation along with the 2D lines and the associated feature descriptors. Thus, two degrees of freedom of the camera's 3D orientation (corresponding to roll and pitch) may already be known, reducing the complexity of estimating the remaining degrees of freedom. For instance, when the gravity vector is known, a linear pose estimation approach similar to the one described above may require only five correspondences and output a single solution, or candidate camera pose estimated based on the known gravity vector. Similarly, a 4-pt minimal solver may require only four correspondences and output two candidate camera poses.
Once candidate camera poses are calculated for each subset of correspondences, the remote device may identify a best overall camera pose from the set of every candidate camera pose. In other words, several camera pose hypotheses are identified by the remote device, at least one of which is likely to correspond to the actual pose of the camera.
In
For instance, the remote device may assign a RANSAC score to each candidate camera pose by evaluating an objective function that projects the points into a hypothetical image plane within the 3D map of the physical environment, where the projection is based on the candidate camera pose being tested. Given the correspondences between the obfuscated features and 3D points, the geometric error (e.g., in pixels) may be measured by computing the distance between each 2D line a corresponding 2D point obtained by projecting a 3D map feature's 3D point onto the hypothetical image plane. Candidate camera poses having smaller average geometric error are preferred, and the candidate camera pose having the smallest geometric error may be identified as the best overall camera pose.
The description has thus far focused on a scenario in which the camera captures a single image of the physical environment. From this single image, the camera device derives an obfuscated image representation, which is transmitted to the remote device and used to estimate the pose of the camera. However, in alternate implementations, the camera may capture two or more images of the physical environment, and an obfuscated 3D local map may be derived from the two or more images. Alternatively, two or more images may be captured at the same time by two or more cameras—for instance, in the case of a multi-camera (e.g., stereoscopic) device. The remote device may therefore estimate a current pose of the camera that corresponds to the camera pose when the most recent image was captured. Additionally, or alternatively, the remote device may estimate camera poses for each of the captured images, a range of poses that depict the camera's movements throughout the physical environment as the images were taken, a single pose consistent with both images (i.e., in multi-camera implementations), etc. As used herein, a “3D local map” refers to a 3D representation of the camera device's local environment that is generated by the camera device based on images taken by the camera(s). The 3D local map is different from the 3D map of the physical environment maintained by the remote device.
A multi-image scenario is illustrated in
The 3D local map will be limited to the portions of the physical environment visible in the two or more images and may therefore be less detailed than the 3D map of the physical environment used by the remote device. Furthermore, the 3D local map may use a different coordinate system than the remote 3D map of the physical environment.
The 3D local map may be computed from the two or more captured images in any suitable way. Typically, the camera device will detect and match image features that depict common scene points in the two or more images. A 3D point cloud reconstruction of the physical environment may be inferred by observing the relative positions of each image feature in each captured image, the extent to which each image feature moves as the camera pose changes (e.g., due to parallax), via geometric triangulation, additional information (e.g., depth information) available to the camera device, etc.
Once generated, the 3D local map includes a 3D point cloud, each of the 3D points having an associated feature descriptor calculated from image features detected in the images used to build the 3D local map. This is shown in
From this, the camera device may derive an obfuscated 3D local map that includes a plurality of obfuscated features. Similar to the obfuscated features included in the obfuscated image representation described above, the obfuscated features in the obfuscated 3D local map may include 3D feature representations that replace the 3D points in the unobfuscated 3D local map, as well as feature descriptors describing the appearance of the 3D point that was replaced.
The 3D feature representations in the obfuscated features may take the form of 3D lines, and each 3D line may optionally have a random three-dimensional direction. This is shown in
As an alternative, the 3D feature representations in the obfuscated features may take the form of 3D planes that pass through the 3D points corresponding to the image features, and each 3D plane may have a random 3D direction.
Turning again to
Once transmitted to the remote device, the obfuscated 3D local map may be used to estimate a camera pose based on determined correspondences between 3D feature representations in the obfuscated 3D local map and 3D points in the 3D map of the physical environment. This generally involves finding the 3D rigid body transformation between coordinate systems of the obfuscated 3D local map and the 3D map of the physical environment. The details, however, may be substantially similar to the pose estimation approaches described above with respect to the obfuscated image representation. For example, in the case where the obfuscated 3D local map includes 3D planes, then six 3D plane to 3D point correspondences may used by a 6-pt minimal solver to output sixteen potential 3D rigid body transformations. From these transformations, the camera pose or camera poses may be estimated. Alternatively, when the obfuscated 3D local map includes 3D lines, then a set of three 3D line to 3D point correspondences may be used to estimate the 3D rigid body coordinate transformation. This may be described as a generalized absolute camera pose problem. An example approach is described in A Minimal Solution to the Generalized 3-Point Pose Problem, Nister and Stewenius, 2003. When the gravity vector detected by the camera is included in the obfuscated environment representation, then the 3D rigid body transformation may be estimated using only two 3D line to 3D point correspondences.
Theoretically, the obfuscated 3D local map can have any arbitrary scale and need not have the same scale as the 3D map of the physical environment used by the remote device. This can complicate efforts to calculate the camera pose unless the relative scale factor is known. However, these issues may be alleviated when the 3D local environment map and 3D map of the physical environment used by the remote device are generated using visual inertial simultaneous localization and mapping (VI+SLAM) techniques, or using SLAM with one or more stereo cameras, which reconstruct the world in true dimensions. In such implementations, the obfuscated environment representation will have the same scale as the 3D map of the physical environment.
The description thus far has focused on a case in which the 3D map of the physical environment includes discrete 3D points distributed throughout the 3D map. In alternative scenarios, however, the 3D map of the physical environment may itself be obfuscated. This may be done, for example, to prevent anyone who obtains the 3D map of the physical environment from recreating the original images used to generate the map, as discussed above. To this end, the 3D points in the 3D map of the physical environment may optionally be obfuscated by replacing them with 3D lines each having a random direction. Notably, the 3D lines are selected in such a way that they pass through the 3D points in an original, unobfuscated version of the 3D map, even though the obfuscated 3D map may not include the actual 3D coordinates of the 3D points. When compared to an obfuscated 3D local map derived from one or more images of the physical environment, a RANSAC based approach for determining the 3D rigid body transformation between the local map and the original 3D map may require a generalized relative pose solver that, when provided with six 3D line to 3D line correspondences outputs 64 candidate solutions for the relative 3D rigid body transformation between the coordinate systems of the local map and the original 3D map. An example approach is described in Solutions to Minimal Generalized Relative Pose Problems, Stewenius et al., 2005. When the gravity vector is known, a different minimal solver provided with 4 3D line to 3D line correspondences may output eight candidate camera poses. Using both a confidential query and a confidential map potentially enables an untrusted third party to perform localization computations and/or enables localization computations to be performed on non-secure hardware while guaranteeing privacy of both the map and the query (e.g., in scenarios where the maps are exported to a compute device that is spatially close to the physical location of the mapped site, but not necessarily fully secure).
As discussed above, when determining correspondences between obfuscated features and 3D map features, any feature representations (e.g., 2D lines, 3D lines, 3D planes) corresponding to items, objects, people, etc., not present in the physical environment during mapping will not have corresponding 3D map features in the 3D map of the physical environment. Thus, the positions of the image features represented by the obfuscated representations, whether they are in a 2D obfuscated image representation or an obfuscated 3D local map, will not be revealed. However, the remote device could potentially store any unmatched obfuscated features in a database. As additional obfuscated features are received and additional unmatched obfuscated features are stored, the remote device may eventually be able to determine correspondences between the various unmatched obfuscated features, potentially allowing the remote device to infer the positions or appearances of any objects in the images associated with the obfuscated features. Though this is typically not feasible with objects that move within the physical environment as the images are taken (e.g., people), the appearances of stationary objects may in some cases be revealed. This problem may be exacerbated when the camera device transmits an obfuscated 3D local map based on two or more images.
To address this, the feature descriptors transmitted with the obfuscated features may in some cases be modified. As discussed above, the transmitted feature descriptors may be, for example, 128-dimensional SIFT vectors. Both the camera device and remote device may maintain a known set of predefined permutations that can be applied to the feature vectors. Each time the camera device transmits an obfuscated image representation to the remote device, the camera device may randomly apply any of these potential permutations to the included feature descriptors without notifying the remote device of which permutations were selected. In other words, for each of the feature descriptors, the camera device may apply a randomly-selected permutation from a known set of predetermined permutations to the feature descriptor prior to transmitting the obfuscated image representation to the remote device.
Once the remote device receives the obfuscated image representation, the remote device may apply each of the predefined permutations to each of the received feature descriptors, thus creating a plurality of permuted descriptor copies for each feature descriptor. The remote device may then search for correspondences between the permuted descriptor copies and the 3D map features. For image features that are present in both the captured image and 3D map of the physical environment, at least one permuted copy of the feature descriptor is likely to give a strong feature match—i.e., the permuted descriptor copy will match the 3D map feature with at least a threshold similarity. Therefore, the correspondence can still be determined, which allows the camera pose to still be estimated as described above. However, for obfuscated features that do not have corresponding 3D map features in the 3D map, it is unlikely that any of the permuted versions of the associated feature descriptor will result in a strong feature match. Furthermore, even if the unmatched obfuscated features are stored by the remote device as discussed above, each stored version of the obfuscated feature line will likely have a different permutation, thus making it significantly more difficult for the remote device to infer the true feature descriptors and thereby reveal private information.
In some embodiments, the methods and processes described herein may be tied to a computing system of one or more computing devices. In particular, such methods and processes may be implemented as a computer-application program or service, an application-programming interface (API), a library, and/or other computer-program product.
Computing system 1200 includes a logic machine 1202 and a storage machine 1204. Computing system 1200 may optionally include a display subsystem 1206, input subsystem 1208, communication subsystem 1210, and/or other components not shown in
Logic machine 1202 includes one or more physical devices configured to execute instructions. For example, the logic machine may be configured to execute instructions that are part of one or more applications, services, programs, routines, libraries, objects, components, data structures, or other logical constructs. Such instructions may be implemented to perform a task, implement a data type, transform the state of one or more components, achieve a technical effect, or otherwise arrive at a desired result.
The logic machine may include one or more processors configured to execute software instructions. Additionally or alternatively, the logic machine may include one or more hardware or firmware logic machines configured to execute hardware or firmware instructions. Processors of the logic machine may be single-core or multi-core, and the instructions executed thereon may be configured for sequential, parallel, and/or distributed processing. Individual components of the logic machine optionally may be distributed among two or more separate devices, which may be remotely located and/or configured for coordinated processing. Aspects of the logic machine may be virtualized and executed by remotely accessible, networked computing devices configured in a cloud-computing configuration.
Storage machine 1204 includes one or more physical devices configured to hold instructions executable by the logic machine to implement the methods and processes described herein. When such methods and processes are implemented, the state of storage machine 1204 may be transformed—e.g., to hold different data.
Storage machine 1204 may include removable and/or built-in devices. Storage machine 1204 may include optical memory (e.g., CD, DVD, HD-DVD, Blu-Ray Disc, etc.), semiconductor memory (e.g., RAM, EPROM, EEPROM, etc.), and/or magnetic memory (e.g., hard-disk drive, floppy-disk drive, tape drive, MRAM, etc.), among others. Storage machine 1204 may include volatile, nonvolatile, dynamic, static, read/write, read-only, random-access, sequential-access, location-addressable, file-addressable, and/or content-addressable devices.
It will be appreciated that storage machine 1204 includes one or more physical devices. However, aspects of the instructions described herein alternatively may be propagated by a communication medium (e.g., an electromagnetic signal, an optical signal, etc.) that is not held by a physical device for a finite duration.
Aspects of logic machine 1202 and storage machine 1204 may be integrated together into one or more hardware-logic components. Such hardware-logic components may include field-programmable gate arrays (FPGAs), program- and application-specific integrated circuits (PASIC/ASICs), program- and application-specific standard products (PSSP/ASSPs), system-on-a-chip (SOC), and complex programmable logic devices (CPLDs), for example.
The terms “module,” “program,” and “engine” may be used to describe an aspect of computing system 1200 implemented to perform a particular function. In some cases, a module, program, or engine may be instantiated via logic machine 1202 executing instructions held by storage machine 1204. It will be understood that different modules, programs, and/or engines may be instantiated from the same application, service, code block, object, library, routine, API, function, etc. Likewise, the same module, program, and/or engine may be instantiated by different applications, services, code blocks, objects, routines, APIs, functions, etc. The terms “module,” “program,” and “engine” may encompass individual or groups of executable files, data files, libraries, drivers, scripts, database records, etc.
It will be appreciated that a “service”, as used herein, is an application program executable across multiple user sessions. A service may be available to one or more system components, programs, and/or other services. In some implementations, a service may run on one or more server-computing devices.
When included, display subsystem 1206 may be used to present a visual representation of data held by storage machine 1204. This visual representation may take the form of a graphical user interface (GUI). As the herein described methods and processes change the data held by the storage machine, and thus transform the state of the storage machine, the state of display subsystem 1206 may likewise be transformed to visually represent changes in the underlying data. Display subsystem 1206 may include one or more display devices utilizing virtually any type of technology. Such display devices may be combined with logic machine 1202 and/or storage machine 1204 in a shared enclosure, or such display devices may be peripheral display devices.
When included, input subsystem 1208 may comprise or interface with one or more user-input devices such as a keyboard, mouse, touch screen, or game controller. In some embodiments, the input subsystem may comprise or interface with selected natural user input (NUI) componentry. Such componentry may be integrated or peripheral, and the transduction and/or processing of input actions may be handled on- or off-board. Example NUI componentry may include a microphone for speech and/or voice recognition; an infrared, color, stereoscopic, and/or depth camera for machine vision and/or gesture recognition; a head tracker, eye tracker, accelerometer, and/or gyroscope for motion detection and/or intent recognition; as well as electric-field sensing componentry for assessing brain activity.
When included, communication subsystem 1210 may be configured to communicatively couple computing system 1200 with one or more other computing devices. Communication subsystem 1210 may include wired and/or wireless communication devices compatible with one or more different communication protocols. As non-limiting examples, the communication subsystem may be configured for communication via a wireless telephone network, or a wired or wireless local- or wide-area network. In some embodiments, the communication subsystem may allow computing system 1200 to send and/or receive messages to and/or from other devices via a network such as the Internet.
In an example, a method for estimating a camera pose comprises: recognizing a three-dimensional (3D) map representing a physical environment, the 3D map including a plurality of 3D map features defined at a plurality of 3D points distributed throughout the 3D map; receiving an obfuscated image representation derived from an original unobfuscated image of the physical environment captured by a camera, the obfuscated image representation including a plurality of obfuscated features, and each obfuscated feature including (i) a two-dimensional (2D) line that passes through a 2D point in the original unobfuscated image at which an image feature was detected, and (ii) a feature descriptor associated with the 2D point that describes the image feature that the 2D line of the obfuscated feature passes through; determining correspondences between the obfuscated features in the obfuscated image representation and 3D map features in the 3D map; and based on the determined correspondences, estimating a six degree of freedom pose of the camera in the physical environment. In this or any other example, determining the correspondences includes identifying a set of obfuscated features having feature descriptors that match feature descriptors of 3D map features in the 3D map, such that the 2D line of each obfuscated feature in the set corresponds to a 3D point associated with a 3D map feature giving a set of 2D line to 3D point correspondences. In this or any other example, based on the determined 2D line to 3D point correspondences, the pose of the camera is estimated using a random sample consensus (RANSAC) framework and a minimal or non-minimal solver to calculate a plurality of candidate camera poses from subsets of the determined 2D line to 3D point correspondences. In this or any other example, estimating the pose of the camera includes: identifying a subset of the determined 2D line to 3D point correspondences; and identifying one or more candidate camera poses consistent with the subset of the determined 2D line to 3D point correspondences. In this or any other example, estimating the pose of the camera further includes identifying additional subsets of the determined 2D line to 3D point correspondences, identifying one or more additional candidate camera poses for each of the additional subsets of 2D line to 3D point correspondences, and identifying a best overall camera pose from the candidate camera poses. In this or any other example, each subset of correspondences includes six 2D line to 3D point correspondences, and each set of candidate camera poses includes sixteen candidate camera poses. In this or any other example, each subset of correspondences includes six 2D line to 3D point correspondences, each 2D line is back-projected as a 3D plane in a camera coordinate system , and a minimal solver calculates a set of eight candidate camera poses by solving an algorithm that outputs pose solutions based on 3D plane to 3D point correspondences. In this or any other example, each subset of correspondences includes twelve 2D line to 3D point correspondences, and each set of candidate camera poses includes a single candidate camera pose. In this or any other example, the obfuscated image representation includes an indication of a gravity vector detected when the original unobfuscated image was captured, each subset of correspondences includes five 2D line to 3D point correspondences, and each set of candidate camera poses includes a single candidate camera pose calculated based on the gravity vector. In this or any other example, a feature descriptor in the obfuscated image representation is a permuted feature descriptor that has been modified with a permutation randomly-selected from a known set of predefined permutations, and the method further comprises applying each permutation of the known set of predefined permutations to the permuted feature descriptor to create a plurality of permuted descriptor copies, searching for correspondences between each permuted descriptor copy and the plurality of 3D map features, and determining a correspondence between the feature descriptor and a 3D map feature if a permuted descriptor copy has at least a threshold similarity to the 3D map feature.
In an example, a method for estimating a camera pose comprises: via a camera, capturing an image of a physical environment; detecting a plurality of image features at two-dimensional (2D) pixel locations within the image of the physical environment; generating a plurality of obfuscated features corresponding to the plurality of image features, each obfuscated feature including (i) a 2D line passing through the 2D pixel location of a corresponding image feature, and (ii) a feature descriptor that describes the image feature associated with the 2D point that the 2D line of the obfuscated feature passes through; transmitting an obfuscated image representation to a remote device, the obfuscated image representation including the plurality of obfuscated features, the obfuscated image representation not including the 2D pixel locations of the plurality of image features; and receiving, from the remote device, a six degree of freedom pose of the camera within the physical environment estimated by the remote device based on correspondences between the obfuscated features and a plurality of three-dimensional (3D) map features defined at a plurality of 3D points within a 3D map of the physical environment previously acquired by the remote device. In this or any other example, each image feature detected in the image has a (2D) position, a scale, a one-dimensional (1D) angular orientation, and a feature descriptor, and the obfuscated image representation does not include the 2D position, the scale, and the 1D angular orientation of the image feature. In this or any other example, the method further comprises, for each of the feature descriptors, applying a randomly-selected permutation from a predetermined set of permutations to the feature descriptor prior to transmitting the obfuscated image representation to the remote device. In this or any other example, each 2D line has a randomly assigned direction.
In an example, a method for estimating a current camera pose, comprises: recognizing a three-dimensional (3D) map representing a physical environment, the 3D map including a plurality of 3D map features defined at a plurality of 3D points distributed throughout the 3D map; receiving an obfuscated 3D local map derived from two or more images of the physical environment having been captured by two or more cameras, the obfuscated 3D local map including a plurality of obfuscated features each including (i) a 3D feature representation that replaces a 3D point in the unobfuscated 3D local map, the 3D point having been computed based on feature matching and triangulation of 2D image features detected in the two or more images, and (ii) a feature descriptor that describes one of the 2D image features from which the 3D image feature was triangulated; determining correspondences between obfuscated 3D feature representations in the obfuscated 3D local map and 3D point features in the 3D map of the physical environment; and based on the determined obfuscated 3D feature representation to 3D point correspondences, estimating a six degree of freedom pose of the two or more cameras in the physical environment. In this or any other example, the 3D feature representations are 3D lines passing through the 3D points in the original, unobfuscated 3D local map, each 3D line having a random direction, and the determined correspondences include at least three 3D line to 3D point correspondences. In this or any other example, the 3D feature representations are 3D lines each having a random direction, and the 3D map features in the three-dimensional map of the physical environment are obfuscated map features, such that each obfuscated map feature takes the form of a 3D line that has a random direction and that passes through the 3D point of a 3D map feature in an original, unobfuscated version of the 3D map. In this or any other example, the 3D feature representations are 3D planes passing through the 3D points in the original, unobfuscated 3D local map, each 3D plane having a random direction, and the determined correspondences include at least six 3D plane to 3D point correspondences. In this or any other example, the obfuscated 3D local map includes an indication of a gravity vector detected when the two or more images were captured. In this or any other example, the obfuscated 3D local map has a same scale as the 3D map of the physical environment.
It will be understood that the configurations and/or approaches described herein are exemplary in nature, and that these specific embodiments or examples are not to be considered in a limiting sense, because numerous variations are possible. The specific routines or methods described herein may represent one or more of any number of processing strategies. As such, various acts illustrated and/or described may be performed in the sequence illustrated and/or described, in other sequences, in parallel, or omitted. Likewise, the order of the above-described processes may be changed.
The subject matter of the present disclosure includes all novel and non-obvious combinations and sub-combinations of the various processes, systems and configurations, and other features, functions, acts, and/or properties disclosed herein, as well as any and all equivalents thereof.