This patent application is based on and claims priority pursuant to 35 U.S.C. § 119(a) to Japanese Patent Application No. 2018-058883, filed on Mar. 26, 2018, and 2019-044537, filed on Mar. 12, 2019, in the Japan Patent Office, the entire disclosure of which is hereby incorporated by reference herein.
The present invention relates to an image processing apparatus, an image processing system, an image capturing system, and an image processing method.
The wide-angle image, taken with a wide-angle lens, is useful in capturing such as landscape, as the image tends to cover large areas. For example, there is an image capturing system, which captures a wide-angle image of a target object and its surroundings, and an enlarged image of the target object. The wide-angle image is combined with the enlarged image such that, even when a part of the wide-angle image showing the target object is enlarged, that part embedded with the enlarged image is displayed in high resolution.
Example embodiments of the present invention include an information processing apparatus including processing circuitry to: obtain a first image in first projection, a second image in second projection, and a third image in the second projection that is the same as the projection of the second image; calculate a first corresponding area in the first image, which corresponds to the second image, through first homography transformation, based on similarity between a plurality of feature points in the first image, and a plurality of features points in the second image; transform a projection of a peripheral area including the first corresponding area from the first projection to the second projection, to generate a peripheral area image; calculate a second corresponding area in the peripheral area image, which corresponds to the second image, through second homography transformation, based on similarity between a plurality of feature points in the second image, and a plurality of feature points in the peripheral area image; calculate a third corresponding area in the second image, which corresponds to the third image, through third homography transformation, based on similarity between a plurality of feature points in the second image, and a plurality of feature points in the third image; reversely transform a projection of the second corresponding area, from the second projection to the first projection, to generate first location information based on a first specific corresponding area in the first image, which corresponds to the second corresponding area; calculate a fourth corresponding area in the peripheral area image, which corresponds to the third image, through the second homography transformation; and reversely transform a projection of the fourth corresponding area, from the second projection to the first projection, to generate second location information based on a second specific corresponding area in the first image, which corresponds to the fourth corresponding area.
A more complete appreciation of the disclosure and many of the attendant advantages and features thereof can be readily obtained and understood from the following detailed description with reference to the accompanying drawings, wherein:
The accompanying drawings are intended to depict embodiments of the present invention and should not be interpreted to limit the scope thereof. The accompanying drawings are not to be considered as drawn to scale unless explicitly noted.
The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of the present invention. As used herein, the singular forms “a”, “an” and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise.
In describing embodiments illustrated in the drawings, specific terminology is employed for the sake of clarity. However, the disclosure of this specification is not intended to be limited to the specific terminology so selected and it is to be understood that each specific element includes all technical equivalents that have a similar function, operate in a similar manner, and achieve a similar result.
In this disclosure, a first image is an image superimposed with a second image and a third image. In one example, the first image and the second image are different in image type, and the second image and the third image are the same in image type. In one example, the second (or third) image is an image with image quality higher than that of the first image, for example, in terms of image resolution. For instance, the first image may be a low-definition image, and the second (or third) image may be a high-definition image. In another example, the first image and the second (or third) image are images expressed in different projections (projective spaces). Examples of the first image in a first projection include an equirectangular projection image, such as a spherical image. Examples of the second (or third) image in a second projection include a perspective projection image, such as a planar image. In this disclosure, the second (or third) image, such as the planar image captured with the generic image capturing device, is treated as one example of the second (or third) image in the second projection (that is, in the second projective space). The first image and the second (or third) image, if desired, can be image data which have been captured through different lenses, or using different image sensors, or at different times.
Further, any number of third images may be superimposed on the second image, which is superimposed on the first image.
Further, in this disclosure, the spherical image does not have to be the full-view spherical image. For example, the spherical image may be the wide-angle view image having an angle of about 180 to 360 degrees in the horizontal direction. As described below, it is desirable that the spherical image is image data having at least a part that is not entirely displayed in the predetermined area T.
Referring to the drawings, embodiments of the present invention are described below.
First, referring to
First, referring to
As illustrated in
As illustrated in
Next, referring to
Next, referring to
As illustrated in
The equirectangular projection image is mapped on the sphere surface using Open Graphics Library for Embedded Systems (OpenGL ES) as illustrated in
Since the spherical image CE is an image attached to the sphere surface, as illustrated in
The predetermined-area image Q, which is an image of the predetermined area T illustrated in
Referring to
L/f=tan(α/2) (Equation 1)
Referring to
<Overview of Image Capturing System>
First, referring to
As illustrated in
The special image capturing device 1 is a special digital camera, which captures an image of an object or surroundings such as scenery to obtain two hemispherical images, from which a spherical (panoramic) image is generated, as described above referring to
The generic image capturing device 3 is a digital single-lens reflex camera, however, it may be implemented as a compact digital camera. The generic image capturing device 3 is provided with a shutter button 315a, which is a part of an operation unit 315 described below.
The smart phone 5 is wirelessly communicable with the special image capturing device 1 and the generic image capturing device 3 using short-range wireless communication, such as Wi-Fi, Bluetooth (Registered Trademark), and Near Field Communication (NFC). The smart phone 5 is capable of displaying the images obtained respectively from the special image capturing device 1 and the generic image capturing device 3, on a display 517 provided for the smart phone 5 as described below.
The smart phone 5 may communicate with the special image capturing device 1 and the generic image capturing device 3, without using the short-range wireless communication, but using wired communication such as a cable. The smart phone 5 is an example of an image processing apparatus capable of processing images being captured. Other examples of the image processing apparatus include, but not limited to, a tablet personal computer (PC), a note PC, and a desktop PC. The smart phone 5 may operate as a communication terminal described below.
Hardware Configuration
Next, referring to
<Hardware Configuration of Special Image Capturing Device>
First, referring to
As illustrated in
The imaging unit 101 includes two wide-angle lenses (so-called fish-eye lenses) 102a and 102b, each having an angle of view of equal to or greater than 180 degrees so as to form a hemispherical image. The imaging unit 101 further includes the two imaging elements 103a and 103b corresponding to the wide-angle lenses 102a and 102b respectively. The imaging elements 103a and 103b each includes an imaging sensor such as a complementary metal oxide semiconductor (CMOS) sensor and a charge-coupled device (CCD) sensor, a timing generation circuit, and a group of registers. The imaging sensor converts an optical image formed by the wide-angle lenses 102a and 102b into electric signals to output image data. The timing generation circuit generates horizontal or vertical synchronization signals, pixel clocks and the like for the imaging sensor. Various commands, parameters and the like for operations of the imaging elements 103a and 103b are set in the group of registers.
Each of the imaging elements 103a and 103b of the imaging unit 101 is connected to the image processor 104 via a parallel I/F bus. In addition, each of the imaging elements 103a and 103b of the imaging unit 101 is connected to the imaging controller 105 via a serial I/F bus such as an I2C bus. The image processor 104, the imaging controller 105, and the audio processor 109 are each connected to the CPU 111 via a bus 110. Furthermore, the ROM 112, the SRAM 113, the DRAM 114, the operation unit 115, the network I/F 116, the communication circuit 117, the electronic compass 118, and the terminal 121 are also connected to the bus 110.
The image processor 104 acquires image data from each of the imaging elements 103a and 103b via the parallel IIF bus and performs predetermined processing on each image data. Thereafter, the image processor 104 combines these image data to generate data of the equirectangular projection image as illustrated in
The imaging controller 105 usually functions as a master device while the imaging elements 103a and 103b each usually functions as a slave device. The imaging controller 105 sets commands and the like in the group of registers of the imaging elements 103a and 103b via the serial I/F bus such as the I2C bus. The imaging controller 105 receives various commands from the CPU 111. Further, the imaging controller 105 acquires status data and the like of the group of registers of the imaging elements 103a and 103b via the serial I/F bus such as the I2C bus. The imaging controller 105 sends the acquired status data and the like to the CPU 111.
The imaging controller 105 instructs the imaging elements 103a and 103b to output the image data at a time when the shutter button 115a of the operation unit 115 is pressed. In some cases, the special image capturing device 1 is capable of displaying a preview image on a display (e.g., the display of the smart phone 5) or displaying a moving image (movie). In case of displaying movie, the image data are continuously output from the imaging elements 103a and 103b at a predetermined frame rate (frames per minute).
Furthermore, the imaging controller 105 operates in cooperation with the CPU 111 to synchronize the time when the imaging element 103a outputs image data and the time when the imaging element 103b outputs the image data. It should be noted that, although the special image capturing device 1 does not include a display in this embodiment, the special image capturing device 1 may include the display.
The microphone 108 converts sounds to audio data (signal). The audio processor 109 acquires the audio data output from the microphone 108 via an I/F bus and performs predetermined processing on the audio data.
The CPU 111 controls entire operation of the special image capturing device 1, for example, by performing predetermined processing. The ROM 112 stores various programs for execution by the CPU 111. The SRAM 113 and the DRAM 114 each operates as a work memory to store programs loaded from the ROM 112 for execution by the CPU 111 or data in current processing. More specifically, in one example, the DRAM 114 stores image data currently processed by the image processor 104 and data of the equirectangular projection image on which processing has been performed.
The operation unit 115 collectively refers to various operation keys, such as the shutter button 115a. In addition to the hardware keys, the operation unit 115 may also include a touch panel. The user operates the operation unit 115 to input various image capturing (photographing) modes or image capturing (photographing) conditions.
The network IIF 116 collectively refers to an interface circuit such as a USB I/F that allows the special image capturing device 1 to communicate data with an external medium such as an SD card or an external personal computer. The network I/F 116 supports at least one of wired and wireless communications. The data of the equirectangular projection image, which is stored in the DRAM 114, is stored in the external medium via the network I/F 116 or transmitted to the external device such as the smart phone 5 via the network I/F 116, at any desired time.
The communication circuit 117 communicates data with the external device such as the smart phone 5 via the antenna 117a of the special image capturing device 1 by short-range wireless communication such as Wi-Fi, NFC, and Bluetooth. The communication circuit 117 is also capable of transmitting the data of equirectangular projection image to the external device such as the smart phone 5.
The electronic compass 118 calculates an orientation of the special image capturing device 1 from the Earth's magnetism to output orientation information. This orientation information is an example of related information, which is metadata described in compliance with Exif. This information is used for image processing such as image correction of captured images. The related information also includes a date and time when the image is captured by the special image capturing device 1, and a size of the image data.
The gyro sensor 119 detects the change in tilt of the special image capturing device 1 (roll, pitch, yaw) with movement of the special image capturing device 1. The change in angle is one example of related information (metadata) described in compliance with Exif. This information is used for image processing such as image correction of captured images.
The acceleration sensor 120 detects acceleration in three axial directions. The position (an angle with respect to the direction of gravity) of the special image capturing device 1 is determined, based on the detected acceleration. With the gyro sensor 119 and the acceleration sensor 120, accuracy in image correction improves.
<Hardware Configuration of Generic Image Capturing Device>
Next, referring to
The elements 304, 310, 311, 312, 313, 314, 315, 316, 317, 317a, and 318 of the generic image capturing device 3 are substantially similar in structure and function to the elements 104, 110, 111, 112, 113, 114, 115, 116, 117, 117a, and 118 of the special image capturing device 1, such that the description thereof is omitted.
Further, as illustrated in
The imaging controller 305 is substantially similar in structure and function to the imaging controller 105. The imaging controller 305 further controls operation of the lens unit 306 and the mechanical shutter button 307, according to user operation input through the operation unit 315.
The display 319 is capable of displaying an operational menu, an image being captured, or an image that has been captured, etc.
<Hardware Configuration of Smart Phone>
Referring to
The CPU 501 controls entire operation of the smart phone 5. The ROM 502 stores a control program for controlling the CPU 501 such as an IPL. The RAM 503 is used as a work area for the CPU 501. The EEPROM 504 reads or writes various data such as a control program for the smart phone 5 under control of the CPU 501. The CMOS sensor 505 captures an object (for example, the user operating the smart phone 5) under control of the CPU 501 to obtain captured image data. The imaging element I/F 513a is a circuit that controls driving of the CMOS sensor 505. The acceleration and orientation sensor 506 includes various sensors such as an electromagnetic compass for detecting geomagnetism, a gyrocompass, and an acceleration sensor. The medium I/F 508 controls reading or writing of data with respect to a recording medium 507 such as a flash memory. The GPS receiver 509 receives a GPS signal from a GPS satellite.
The smart phone 5 further includes a long-range communication circuit 511, an antenna 511a for the long-range communication circuit 511, a CMOS sensor 512, an imaging element I/F 513b, a microphone 514, a speaker 515, an audio input/output I/F 516, a display 517, an external device connection I/F 518, a short-range communication circuit 519, an antenna 519a for the short-range communication circuit 519, and a touch panel 521.
The long-range communication circuit 511 is a circuit that communicates with other device through the communication network 100. The CMOS sensor 512 is an example of a built-in imaging device capable of capturing a subject under control of the CPU 501. The imaging element I/F 513a is a circuit that controls driving of the CMOS sensor 512. The microphone 514 is an example of built-in audio collecting device capable of inputting audio under control of the CPU 501. The audio I/O I/F 516 is a circuit for inputting or outputting an audio signal between the microphone 514 and the speaker 515 under control of the CPU 501. The display 517 may be a liquid crystal or organic electro luminescence (EL) display that displays an image of a subject, an operation icon, or the like. The external device connection I/F 518 is an interface circuit that connects the smart phone 5 to various external devices. The short-range communication circuit 519 is a communication circuit that communicates in compliance with the Wi-Fi, NFC, Bluetooth, and the like. The touch panel 521 is an example of input device that enables the user to input a user instruction through touching a screen of the display 517.
The smart phone 5 further includes a bus line 510. Examples of the bus line 510 include an address bus and a data bus, which electrically connects the elements such as the CPU 501.
It should be noted that a recording medium such as a CD-ROM or HD storing any of the above-described programs may be distributed domestically or overseas as a program product.
<Functional Configuration of Image Capturing System>
Referring now to
<Functional Configuration of Special Image Capturing Device>
Referring to
The special image capturing device 1 further includes a memory 1000, which is implemented by the ROM 112, the SRAM 113, and the DRAM 114 illustrated in
Still referring to
The acceptance unit 12 of the special image capturing device 1 is implemented by the operation unit 115 illustrated in
The image capturing unit 13 is implemented by the imaging unit 101, the image processor 104, and the imaging controller 105, illustrated in
The audio collection unit 14 is implemented by the microphone 108 and the audio processor 109 illustrated in
The image and audio processing unit 15 is implemented by the instructions of the CPU 111, illustrated in
The determiner 17, which is implemented by instructions of the CPU 111, performs various determinations.
The short-range communication unit 18, which is implemented by instructions of the CPU 111, and the communication circuit 117 with the antenna 117a, communicates data with a short-range communication unit 58 of the smart phone 5 using the short-range wireless communication in compliance with such as Wi-Fi.
The storing and reading unit 19, which is implemented by instructions of the CPU 111 illustrated in
<Functional Configuration of Generic Image Capturing Device>
Next, referring to
The generic image capturing device 3 further includes a memory 3000, which is implemented by the ROM 312, the SRAM 313, and the DRAM 314 illustrated in
The acceptance unit 32 of the generic image capturing device 3 is implemented by the operation unit 315 illustrated in
The image capturing unit 33 is implemented by the imaging unit 301, the image processor 304, and the imaging controller 305, illustrated in
The audio collection unit 34 is implemented by the microphone 308 and the audio processor 309 illustrated in
The image and audio processing unit 35 is implemented by the instructions of the CPU 311, illustrated in
The display control 36, which is implemented by the instructions of the CPU 311 illustrated in
The determiner 37, which is implemented by instructions of the CPU 311, performs various determinations. For example, the determiner 37 determines whether the shutter button 315a has been pressed by the user.
The short-range communication unit 38, which is implemented by instructions of the CPU 311, and the communication circuit 317 with the antenna 317a, communicates data with the short-range communication unit 58 of the smart phone 5 using the short-range wireless communication in compliance with such as Wi-Fi.
The storing and reading unit 39, which is implemented by instructions of the CPU 311 illustrated in
<Functional Configuration of Smart Phone>
Referring now to
The smart phone 5 further includes a memory 5000, which is implemented by the ROM 502, RAM 503 and EEPROM 504 illustrated in
Referring now to
The long-range communication unit 51 of the smart phone 5 is implemented by the long-range communication circuit 511 that operates under control of the CPU 501, illustrated in
The acceptance unit 52 is implement by the touch panel 521, which operates under control of the CPU 501, to receive various selections or inputs from the user. While the touch panel 521 is provided separately from the display 517 in
The image capturing unit 53 is implemented by the CMOS sensors 505 and 512, which operate under control of the CPU 501, illustrated in
In this example, the captured image data is planar image data, captured with a perspective projection method.
The audio collection unit 54 is implemented by the microphone 514 that operates under control of the CPU 501. The audio collecting unit 14a collects sounds around the smart phone 5.
The image and audio processing unit 55 is implemented by the instructions of the CPU 501, illustrated in
The display control 56, which is implemented by the instructions of the CPU 501 illustrated in
In this example, the location parameter is an example of location information. In case a plurality of images to be superimposed is present, the location information is obtained for each image. The location information is thus a general term for first location information such as a first location parameter, and second location information such as a second location parameter.
Further, the correction parameter is an example of correction information. In case a plurality of images to be superimposed is present, the correction parameter is obtained for each image. The correction information is thus a general term for first correction information such as a first correction parameter, and second correction information such as a second correctio parameter.
The determiner 57 is implemented by the instructions of the CPU 501, illustrated in
The short-range communication unit 58, which is implemented by instructions of the CPU 501, and the short-range communication circuit 519 with the antenna 519a, communicates data with the short-range communication unit 18 of the special image capturing device 1, and the short-range communication unit 38 of the generic image capturing device 3, using the short-range wireless communication in compliance with such as Wi-Fi.
The storing and reading unit 59, which is implemented by instructions of the CPU 501 illustrated in
Referring to
The image and audio processing unit 55 mainly includes a generator 55a that performs encoding, and a superimposing unit 55b that performs decoding. In this example, the encoding corresponds to processing to generate data to be used for superimposing images for display, such as the superimposition relationship metadata. Further, in this example, the decoding corresponds to processing to generate images for display using such as the superimposition relationship metadata. The generator 55a performs processing of S22, which is processing to generate the superimposition relationship metadata, as illustrated in
(Functional Configuration of Generator)
First, a functional configuration of the generator 55a is described. The generator 55a mainly includes a metadata generator 55a1 and a display data generator 55a2.
(Functional Configuration of Metadata Generator)
In case a plurality of planar images are to be superimposed on the equirectangular projection image, as described above, the user viewing the images may feel strangeness, for example, due to the positional shift between two or more of the planar images. To prevent this shift, the metadata generator 55a1 generates superimposition relationship metadata, as described below.
While three or more planar images may be superimposed, in the following, the example case in which two planar images are present is described for simplicity. Specifically, in the following example, the planar image PA and the planar image PB are superimposed on the equirectangular projection image EC. The planar image PB is to be displayed, as a foreground image of the planar image PA. The planar image PA is to be displayed, as a foreground image of the equirectangular projection image EC.
Further, in the following, the equirectangular projection image EC is an example of a first image, the planar image PA is an example of a second image, and the planar image PB is an example of a third image. The term “planar image P” is used to collectively refer to the planar images PA and PB.
The metadata generator 55a1 identifies a pair of images having a parent-child relationship from the planar image PA, the planar image PB, and the equirectangular projection image EC. Images to be paired can be specified by, for example, performing matching processing on two images arbitrarily selected from among input images and calculating a location to be superimposed (that is, where the image to be superimposed, is to be superimposed, which is referred to as a superimposed location) to determine whether one of the two images overlaps with the other image. Metadata may be generated after a parent-child relationship is determined. In this example, the equirectangular projection image EC and the planar image PA have a parent-child relationship, as the equirectangular projection image EC is a background image and the planar image PA is a foreground image. The planar image PA and the planar image PB have a parent-child relationship, as the planar image PA is a background image and the planar image PB is a foreground image. In this case, superimposition relationship metadata is generated for each of the planar image PA and the planar image PB, as describe below referring to
The metadata generator 55a1 includes an extractor 550, a first area calculator 552, a point of gaze specifier 554, a projection converter 556, a second area calculator 557a, a third area calculator 559a, and a superimposition relationship metadata generator 558. Numerals and symbols designating images and areas described below are provided in
Further, a number of corresponding area calculators (such as the second area calculator 557a and the third area calculator 559a) may not only be limited to two, as the number depends on a number of images to be processed.
The extractor 550 extracts feature points according to local features of each image. The feature points are distinctive keypoints in both images. The local features correspond to a pattern or structure detected in the image such as an edge or blob. In this embodiment, the extractor 550 extracts the features points for each of two images that are different from each other. These two images to be processed by the extractor 550 may be the images that have been generated using different image projection methods, or using the same image projection method. Unless the difference in projection methods cause highly distorted images, any desired image projection methods may be used.
The first area calculator 552 calculates the feature value fv1 based on the plurality of feature points fp1 in the equirectangular projection image EC. The first area calculator 552 further calculates the feature value fv2A based on the plurality of feature points fp2A in the planar image PA. The feature values, or feature points, may be detected in any desired method. However, it is desirable that feature values, or feature points, are invariant or robust to changes in scale or image rotation. The first area calculator 552 specifies corresponding points between the images, based on similarity between the feature value fv1 of the feature points fp1 in the equirectangular projection image EC, and the feature value fv2A of the feature points fp2A in the planar image PA. Here, the corresponding points are a plurality of feature points selected from the equirectangular projection image EC and the planar image PA in accordance with the similarity. Based on the corresponding points between the images, the first area calculator 552 calculates the homography for transformation between the equirectangular projection image EC and the planar image PA. The first area calculator 552 then applies first homography transformation to the planar image PA (S120). Accordingly, the first area calculator 552 obtains a first corresponding area CA1 (“first area CA1”), in the equirectangular projection image EC, which corresponds to the planar image PA. In such case, a central point CP1 of a rectangle (quadrilateral) defined by four vertices of the planar image PA, is converted to the point of gaze GP1 in the equirectangular projection image EC, by the first homography transformation.
Here, the coordinates of four vertices p1, p2, p3, and p4 of the planar image PA are p1=(x1, y1), p2=(x2, y2), p3=(x3, y3), and p4=(x4, y4). The first area calculator 552 calculates the central point CP1 (x, y) using the equation 2 below.
S1={(x4−x2)*(y1−y2)−(y4−y2)*(x1−x2)}/2,S2={(x4−x2)*(y2−y3)−(y4−y2)*(x2−x3)}/2,x=x1+(x3−x1)*S1/(S1+S2),y=y1+(y3−y1)*S1/(S1+S2) (Equation 2)
While the planar image PA is a rectangle in the case of
x=(x1+x3)/2,y=(y1+y3)/2 (Equation 3)
The point of gaze specifier 554 specifies the point (referred to as the point of gaze) in the equirectangular projection image EC, which corresponds to the central point CP1 of the planar image PA after the first homography transformation (S130).
Here, the point of gaze GP1 is expressed as a coordinate on the equirectangular projection image EC. The coordinate of the point of gaze GP1 may be transformed to the latitude and longitude. Specifically, a coordinate in the vertical direction of the equirectangular projection image EC is expressed as a latitude in the range of −90 degree (−0.5π) to +90 degree (+0.5n). Further, a coordinate in the horizontal direction of the equirectangular projection image EC is expressed as a longitude in the range of −180 degree (−π) to +180 degree (+π). With this transformation, the coordinate of each pixel, according to the image size of the equirectangular projection image EC, can be calculated from the latitude and longitude system.
The projection converter 556 extracts a peripheral area PeA, which is a portion surrounding the point of gaze GP1, from the equirectangular projection image EC. The projection converter 556 converts the peripheral area PeA, from the equirectangular projection to the perspective projection, to generate a peripheral area image PI (S140). The peripheral area PeA is determined, such that, after projection transformation, the square-shaped, peripheral area image PI has a vertical angle of view (or a horizontal angle of view), which is the same as the diagonal angle of view α of the planar image PA. Here, the central point CP2 of the peripheral area image PT corresponds to the point of gaze GP1.
(Transformation of Projection)
The following describes transformation of a projection, performed at S140 of
(x,y,z)=(cos(ea)x cos(aa), cos(ea)x sin(aa), sin(ea)), wherein the sphere CS has a radius of 1. (Equation 4)
The planar image PA in perspective projection, is a two-dimensional image. When the planar image PA is represented by the two-dimensional polar coordinate system (moving radius, argument)=(r, a), the moving radius r, which corresponds to the diagonal angle of view α, has a value in the range from 0 to tan (diagonal angle view/2). That is, 0<=r<=tan(diagonal angle view/2). The planar image PA, which is represented by the two-dimensional rectangular coordinate system (u, v), can be expressed using the polar coordinate system (moving radius, argument)=(r, a) using the following transformation equation 5.
u=r×cos(a),v=r×sin(a) (Equation 5)
The equation 5 is represented by the three-dimensional coordinate system (moving radius, polar angle, azimuth). For the surface of the sphere CS, the moving radius in the three-dimensional coordinate system is “1”. The equirectangular projection image, which covers the surface of the sphere CS, is converted from the equirectangular projection to the perspective projection, using the following equations 6 and 7. Here, the equirectangular projection image is represented by the above-described two-dimensional polar coordinate system (moving radius, azimuth)=(r, a), and the virtual camera IC is located at the center of the sphere.
r=tan(polar angle) (Equation 6)
a=azimuth (Equation 7)
Assuming that the polar angle is t, Equation 6 can be expressed as: t=arctan(r).
Accordingly, the three-dimensional polar coordinate (moving radius, polar angle, azimuth) is expressed as (1, arctan(r),a).
The three-dimensional polar coordinate system is transformed into the rectangle coordinate system (x, y, z), using Equation 8.
(x,y,z)=(sin(t)×cos(a), sin(t)=sin(a), cos(t)) (Equation 8)
Equation 8 is applied to convert between the equirectangular projection image EC in equirectangular projection, and the planar image PA in perspective projection. More specifically, the moving radius r, which corresponds to the diagonal angle of view α of the planar image PA, is used to calculate transformation map coordinates, which indicate correspondence of a location of each pixel between the planar image PA and the equirectangular projection image EC. With this transformation map coordinates, the equirectangular projection image EC is transformed to generate the peripheral area image PI in perspective projection.
Through the above-described projection transformation, the coordinate (latitude=90°, longitude=0°) in the equirectangular projection image EC becomes the central point CP2 in the peripheral area image PI in perspective projection. In case of applying projection transformation to an arbitrary point in the equirectangular projection image EC as the point of gaze, the sphere CS covered with the equirectangular projection image EC is rotated such that the coordinate (latitude, longitude) of the point of gaze is positioned at (90°, 0°).
The sphere CS may be rotated using any known equation for rotating the coordinate.
(Determination of Peripheral Area Image)
Next, referring to
To enable the second area calculator 557a to determine correspondence between the planar image PA and the peripheral area image PI, it is desirable that the peripheral area image PI is sufficiently large to include the entire second area CA2. If the peripheral area image PI has a large size, the second area CA2 is included in such large-size area image. With the large-size peripheral area image PI, however, the time required for processing increases as there are a large number of pixels subject to similarity calculation. For this reasons, the peripheral area image PI should be a minimum-size image area including at least the entire second area CA2. In this embodiment, the peripheral area image PI is determined as follows.
More specifically, the peripheral area image PI is determined using the 35 mm equivalent focal length of the planar image, which is obtained from the Exif data recorded when the image is captured. Since the 35 mm equivalent focal length is a focal length corresponding to the 24 mm×36 mm film size, it can be calculated from the diagonal and the focal length of the 24 mm×36 mm film, using Equations 9 and 10.
film diagonal=sqrt(24*24+36*36) (Equation 9)
angle of view of the image to be combined/2=arctan((film diagonal/2)/35 mm equivalent focal length of the image to be combined) (Equation 10)
The image with this angle of view has a circular shape. Since the actual imaging element (film) has a rectangular shape, the image taken with the imaging element is a rectangle that is inscribed in such circle. In this embodiment, the peripheral area image PI is determined such that, a vertical angle of view α of the peripheral area image PI is made equal to a diagonal angle of view α of the planar image PA. That is, the peripheral area image PI illustrated in
angle of view of square=sqrt(film diagonal*film diagonal+film diagonal*film diagonal) (Equation 11)
vertical angle of view α/2=arctan((angle of view of square/2)/35 mm equivalent focal length of planar image)) (Equation 12)
The calculated vertical angle of view α is used to obtain the peripheral area image PI in perspective projection, through projection transformation. The obtained peripheral area image PI at least contains an image having the diagonal angle of view α of the planar image PA while centering on the point of gaze, but has the vertical angle of view α that is kept small as possible.
Referring back to
The third area calculator 559a calculates feature values fv2B of a plurality of feature points fp2B in the planar image PB and the feature values fv2A of the plurality of feature points fp2A in the planar image PA. The third area calculator 559a calculates corresponding points between the planar image PB and the planar image PA based on the similarity between the calculated feature values fv2B and the calculated feature values fv2A. Based on the calculated corresponding points between the two images, the third area calculator 559a computes a homography for transformation between the planar image PB and the planar image PA. The third area calculator 559a uses the computed homography for transformation to perform third homography transformation. As a result of the third homography transformation, the third area calculator 559a calculates a third corresponding area CA3 (“third area CA3”).
The superimposition relationship metadata generator 558 generates superimposition relationship metadata for the planar image PA illustrated in
(Superimposition Relationship Metadata (1))
The parent image information is information on the parent image such as an image on which the target image is to be superimposed. The parent image information includes information identifying the parent image such as the image ID of the parent image, and information on the projection method (projective space) of the parent image.
The target image ID information is information on the target image (subject image) such as the superimposed image. The target image ID information includes information identifying the target image such as the image ID of the target image, and information on the projection method of the target image.
The superimposed location calculation information includes superimposed location calculation image information and superimposed location transformation information. The superimposed location calculation image information includes parent image information and target image information. The parent image information includes the image size of the parent image, and generation information for the parent image in equirectangular projection. The image size is the size of the peripheral area image PI described below, for example, which is obtained when superimposed location transformation information described below is calculated. The generation information includes the point of gaze (in degrees), the angle of view (in degrees), and position correction information (in degrees) (Pitch, Yaw, Roll). The point of gaze (in degrees) is, for example, a point of gaze CP2 illustrated in
The superimposed location transformation information indicates a transformation matrix corresponding to a second homography.
The metadata generation information indicates the version of the superimposition relationship metadata.
The superimposition relationship metadata (1) includes parent image information as information for identifying a parent image, and target image ID information as information for identifying a target image (subject image). Examples of the image identifier include a file name, a universally unique identifier (UUID), and a Uniform Resource Identifier (URI). The file name is available when the image is managed in a computer of an individual. To specify a file from a large number of unspecified images, typically, the unique ID is specified. In this case, UUID may be used or URI may be recorded as a resource on a network. In the illustrated example, the file name is used. The target image ID information (image ID) that identifies the subject image and parent image information (image ID) that identifies the parent image are used to provide information indicating two images as a parent and a child. Further, information on the projection methods of the parent image and the subject image is stored as described below.
Transformation for projecting a certain plane onto another plane is referred to as homography. The transformation is expressed using a simple 33 matrix. Also in this embodiment, homography is used to represent the relationship (projection) between corresponding positions in a parent image and a child image. When the projection types of the parent image and the child image are both perspective projection, the corresponding positions in the parent image and the child image can be represented using plane-to-plane projection, that is, using homography, if parallax between the parent image and the child image or distortion of the parent image and the child image are ignored. For the reason described above, the respective projection methods of the two images are stored as information. In addition, a transformation matrix is stored as superimposed location transformation information for mapping the child image to the parent image. A homography between two perspective projection images may be determined by using a known technique, namely, extracting feature points from the two images and matching corresponding feature points to estimate planes. Alternatively, if the two images have no large parallax, template matching may be applied to estimate the corresponding plane of the child image, which corresponds to the plane of the parent image. The correspondence between the parent image and the child image is represented as homography, which has the following advantage: when the correspondence between the parent image and a parent-of-parent (grandparent) image is also represented by using homography, the correspondence between the child image and the parent-of-parent image is also represented by using homography.
Equirectangular projection is a technique of projection used to represent a 360-degree omnidirectional image. Equirectangular projection is used in map creation or as a form of an image to be output from a 360-degree full spherical camera. When the child image is based on perspective projection and the parent image is based on equirectangular projection, the correspondence between the parent image and the child image is difficult to represent using homography. To address this difficulty, a portion of an equirectangular projection image, which is the parent image, is converted into a perspective projection image, and the homography of the obtained perspective projection image is stored together with parent image information. The parent image information is obtained when a portion of the equirectangular projection image is converted into a perspective projection image, and includes the image size, the point of gaze, the angle of view, and position information (“positioning correction”). The inventors have disclosed a method for calculating and recording the relationship in position between corresponding areas in a background image (a parent image) and a foreground image (child image) when the background image and the foreground image are based on different projection methods. The disclosed method includes mutual transformation between equirectangular projection and perspective projection. Once the point of gaze, the angle of view, and the image size are determined, the position in an equirectangular projection image to which a position in a perspective projection image generated from the equirectangular projection image corresponds can be calculated. When images are actually superimposed on each other, data indicating positions in the background image corresponding to all the pixels in the foreground image is not generated, but the foreground image is divided into a suitable number of horizontal and vertical grids or meshes and the coordinates of each of the grids is calculated as latitude and longitude coordinates on the background image, which is an image based on equirectangular projection.
(Superimposition Relationship Metadata (2))
The image size in the parent image information indicates the image size of the entire planar image PA illustrated in
In the above-described transformation, in order to increase the calculation speed, an image size of at least one of the planar image PA, the planar image PB, and the equirectangular projection image EC may be changed, before applying the homography transformation. For example, assuming that the planar image PA has 40 million pixels, and the equirectangular projection image EC has 30 million pixels, the planar image PA may be reduced in size to 30 million pixels. Alternatively, both of the planar image PA and the equirectangular projection image EC may be reduced in size to 10 million pixels. Similarly, an image size of at least one of the planar image PA and the peripheral area image PI may be changed, before applying the second homography transformation.
(Functional Configuration of Display Data Generator)
The display data generator 55a2 includes a second area calculator 557b, a third area calculator 559b, an area divider 560, a projection reverse converter 562, a shape converter 564, a correction parameter generator 566, and a superimposed display data generator 570. If the brightness or color is not to be corrected, none of the shape converter 564 and the correction parameter generator 566 has to be provided.
The second area calculator 557b uses a homography similar to that used by the second area calculator 557a for transformation to perform second homography transformation.
The third area calculator 559b uses a homography similar to that used by the third area calculator 559a for transformation to perform third homography transformation. The area divider 560 divides a part of the image into a plurality of grid areas. A method for dividing the second area CA2 into a plurality of grid areas is described in detail with reference to
As illustrated in
Next, dividing the second area CA2 into the plurality of grid areas LA2 is explained in detail.
The second area CA2 is equally divided using the following equation. Assuming that a line connecting two points, A(X1, Y1) and B(X2, Y2), is to be equally divided into “n” coordinates, the coordinate of a point Pm that is the “m”th point counted from the point A is calculated using the equation 13.
Pm=(X1+(X2−X1)×m/n,Y1+(Y2−Y1)×m/n) (Equation 13)
With Equation 13, the line can be equally divided into a plurality of coordinates. The upper line and the lower line of the rectangle are each divided into a plurality of coordinates, to generate a plurality of lines connecting corresponding coordinates of the upper line and the lower line. The generated lines are each divided into a plurality of coordinates, to further generate a plurality of lines. Here, coordinates of points (vertices) of the upper left, upper right, lower right, and lower left of the rectangle are respectively represented by TL, TR, BR, and BL. The line connecting TL and TR, and the line connecting BR and BL are each equally divided into 30 coordinates (0 to 30th coordinates). Next, each of the lines connecting corresponding 0 to 30th coordinates of the TL-TR line and the BR-BL line, is equally divided into 20 coordinates. Accordingly, the rectangular area is divided into 30×20, sub-areas.
Referring back to
As described above, the location parameter is generated, which is used to calculate the correspondence of each pixel between the equirectangular projection image EC and the planar image PA.
Although the planar image PA is superimposed on the equirectangular projection image EC at a right location with the location parameter, these image EC and image PA may vary in brightness or color (such as tone), causing an unnatural look. The shape converter 564 and the correction parameter generator 566 are provided to avoid this unnatural look, even when these images that differ in brightness and color, are partly superimposed one above the other.
Before applying color correction, the shape converter 564 converts the second area CA2 to have a shape that is the same as the shape of the planar image PA. To made the shape equal, the shape converter 564 maps four vertices of the second area CA2, on corresponding four vertices of the planar image PA. More specifically, the shape of the second area CA2 is made equal to the shape of the planar image PA, such that each grid area LA2 in the second area CA2 illustrated in
The correction parameter generator 566 generates a correction parameter for correcting the grid areas LA2′ in the second area CA2′, which has the same shape as the grid areas LAA in the planar image PA, such that the grid areas LA2′ and the grid areas LAA are equal in brightness and color. Specifically, the correction parameter generator 566 specifies four grid areas LAA having one common grid, and calculates an average a=(Rave, Gave, Bave) of the brightness and color values (R, G, B) of all the pixels included in the specified four grid areas LAA. Similarly, the correction parameter generator 566 specifies four grid areas LA2′ having one common grid, and calculates an average a′=(R′ave, G′ave, B′ave) of the brightness and color values (R′, G′, B′) of all the pixels included in the specified four grid areas LA2′. If one grid in each of the grid areas LA2′ and one grid in each of the grid areas LAA respectively correspond to one of the four vertices of the second area CA2 and one of the four vertices of the planar image PA, the correction parameter generator 566 calculates the average a of the brightness and color values of the pixels included in one of the grid areas LAA and the average a′ of the brightness and color values of the pixels included in one of the grid areas LA2′. If one grid in each of the grid areas LA2′ and one grid in each of the grid areas LAA are respectively included in the outer edge of the second area CA2 and the outer edge of the planar image PA, the correction parameter generator 566 calculates the average a and the average a′ of the brightness and color values of the pixels included in two inner grid areas. In this embodiment, the correction parameter is used as gain data for correcting the brightness and color value of the planar image PA. Accordingly, as given in Equation 14 below, the average a′ is divided by the average a to determine a correction parameter Pa.
Pa=a′/a (Equation 14)
When the superimposed image, described below, is displayed, each of the grid areas LAA is multiplied by the gain value represented by the correction parameter. Accordingly, the color tone and brightness of the planar image PA are corrected to be close to those indicated by the pixel values of the equirectangular projection image EC (the spherical image CE). This allows a displayed superimposed image to look natural. In addition to or in alternative to the average, the median or mode of the brightness and color of pixels may be used to calculate the correction parameter.
In this embodiment, the values (R, G, B) are used to calculate the brightness and color of each pixel. Alternatively, any other color space may be used to obtain the brigthness and color, such as brightness and color difference using YUV, and brigthness and color difference using sYCC(YCbCr) according to the JPEG. The color space may be converted from RGB, to YUV, or to sYCC (YCbCr), using any desired known method. For example, RGB, in compliance with JPEG file interchange format (JFIF), may be converted to YCbCr, using Equation 15.
The superimposed display data generator 570 generates superimposed display data indicating a location at which the planar image P is superimposed on the spherical image CE, and correction values for the brightness and color values of pixels by using the location parameter and the correction parameter. Similar generation processing is applied to the fourth area CA4.
The third area calculator 559b extracts the superimposition relationship metadata (2) indicating the superimposition relationship between the planar images PA and PB, and analyzes the information identifying the parent image, which is included in the superimposition relationship metadata (2), to determine that the parent image is the planar image PA. Further, the third area calculator 559b obtains the superimposed location calculation information (superimposed location calculation image information and superimposed location transformation information) of the planar image PA and the planar image PB. Then, the third area calculator 559b obtains superimposition relationship metadata of the parent image. As described above, the parent image is identified using the file name or ID information stored in the information identifying the parent image, which is included in the superimposition relationship metadata (1). The file name or ID information is used as a key to obtain the superimposition relationship metadata of the parent image. The superimposition relationship metadata, which is managed in a PC of an individual, may be obtained simply as a file. The superimposition relationship metadata, which is managed in a cloud server, may be obtained by using ID information as a key. In this example, the superimposition relationship metadata (1) is obtained and is analyzed. As a result of the analysis, the parent image is identified as the equirectangular projection image EC, and the parent image is determined to be based on equirectangular projection. The parent image information in the superimposed location calculation information includes the point of gaze, the angle of view, and the image size when the perspective projection image (the peripheral area image PI) is generated from the equirectangular projection image EC. Accordingly, the superimposed location transformation information (homography) and the image sizes included in each of the superimposition relationship metadata (1) and the superimposition relationship metadata (2) are used to convert the area information of the planar images PA and PB into area information of a perspective projection image generated from the equirectangular projection image EC. Then, the converted corresponding areas are divided into grids by the area divider 560, and location information of the grids is determined. The determined location information is converted into location information of the equirectangular projection image EC as a first location parameter and a second location parameter by using the points of gaze and the angles of view obtained in the superimposition relationship metadata (1) and the superimposition relationship metadata (2) by the projection reverse converter 562. Then, the shape converter 564 converts the shape into the desired shape by using the location information (that is, the first location parameter and the second location parameter) of the grids obtained by the area divider 560. The correction parameter generator 566 compares corresponding areas between the perspective projection image generated from the equirectangular projection image EC, which is defined by the desired shape, and each one of the planar image PA and the planar image PB in terms of the brightness or color to determine a first correction parameter and second correction parameter, and stores the determined first and second correction parameters in any desired memory. The generated first and second location parameters and the generated first and second correction parameter are used to superimpose images on each other.
(Superimposed Display Data)
The following describes a data structure of the superimposed display data with reference to
As illustrated in
The planar image information is information transmitted from the generic image capturing device 3 together with captured image data. The planar image information includes an image identifier (image ID) and attribute data of the captured image data. The image identifier included in the planar image information is used to identify the planar image P (planar image PA or PB). In
The attribute data included in the planar image information is information related to the planar image P. In
The superimposed display information is information generated by the smart phone 5. The superimposed display information includes area division number information, the coordinates of grids in each grid area (location parameter), and correction values for the brightness and color values (correction parameter). The area division number information indicates the number of horizontal (longitude) grid areas into which the first area CA1 is divided and the number of vertical (latitude) grid areas into which the first area CA1 is divided. The area division number information is referred to when dividing the first area CA1 into a plurality of grid areas.
The location parameter is mapping information, which indicates, for each grid in each grid area of the planar image P, a location in the equirectangular projection image EC. For example, the location parameter associates a location of each grid in each grid area in the equirectangular projection image EC, with each grid in each grid area in the planar image P. The correction parameter, in this example, is gain data for correcting color values of the planar image P. Since the target to be corrected may be a monochrome image, the correction parameter may be used only to correct the brightness value. Accordingly, at least the brightness of the image is to be corrected using the correction parameter.
The perspective projection, which is used for capturing the planar image P, is not applicable to capturing the 360-degree omnidirectional image, such as the spherical image CE. The wide-angle image, such as the spherical image, is often captured in equirectangular projection. In equirectangular projection, like Mercator projection, the distance between lines in the horizontal direction increases away from the standard parallel. This results in generation of the image, which looks very different from the image taken with the general-purpose camera in perspective projection. If the planar image P, superimposed on the spherical image CE, is displayed, the planar image P and the spherical image CE that differ in projection, look different from each other. Even scaling is made equal between these images, the planar image P does not fit in the spherical image CE. In view of the above, the location parameter is generated as described above referring to
The location parameter and the correction parameter are described in detail with reference to
The first area CA1, which is a portion of the equirectangular projection image EC, is converted into the second area CA2 in perspective projection, which is the same projection with the projection of the planar image P. As illustrated in
As illustrated in
As described above, the location parameter indicates correspondence of pixel positions, between the planar image P and the equirectangular projection image EC (spherical image CE). If such correspondence information is to be provided for all pixels, data for about 40 million pixels is needed in case the generic image capturing device 3 is a high-resolution digital camera. This increases processing load due to the increased data size of the location parameter. In view of this, in this embodiment, the planar image P is divided into 600 (30×20) grid areas. The location parameter indicates correspondence of each gird in each of 600 grid areas, between the planar image P and the equirectangular projection image EC (spherical image CE). When displaying the superimposed images by the smart phone 5, the smart phone 5 may interpolate the pixels in each grid area based on the coordinate of each grid in that grid area. Accordingly, the smart phone 5 can display the superimposed image. The relationship between a fourth corresponding area CA4 and a second specific corresponding area CA12, described below, is similar to the relationship between the second area CA2 and the first specific corresponding area CA11.
(Functional Configuration of Superimposing Unit)
Referring to
The superimposed area generator 582 specifies a portion of the virtual sphere CS, which corresponds to the first specific corresponding area CA11, to generate a partial sphere PS.
The correction unit 584 corrects the brightness and color of the planar image P, using the correction parameter of the superimposed display data, to match the brightness and color of the equirectangular projection image EC. The correction unit 584 may not always perform correction on brightness and color. In one example, the correction unit 584 may only correct the brightness of the planar image P using the correction parameter.
The image generator 586 superimposes (maps) the planar image P (or the corrected image C of the planar image P), on the partial sphere PS to generate an image to be superimposed on the spherical image CE, which is referred to as a superimposed image S for simplicity. The image generator 586 generates mask data M, based on a surface area of the partial sphere PS. The image generator 586 covers (attaches) the equirectangular projection image EC, over the sphere CS, to generate the spherical image CE.
The mask data M, having information indicating the degree of transparency, is referred to when superimposing the superimposed image S on the spherical image CE. The mask data M sets the degree of transparency for each pixel, or a set of pixels, such that the degree of transparency increases from the center of the superimposed image S toward the boundary of the superimposed image S with the spherical image CE. With this mask data M, the pixels around the center of the superimposed image S have brightness and color of the superimposed image S, and the pixels near the boundary between the superimposed image S and the spherical image CE have brightness and color of the spherical image CE. Accordingly, superimposition of the superimposed image S on the spherical image CE is made unnoticeable. However, application of the mask data M can be made optional, such that the mask data M does not have to be generated.
The image superimposing unit 588 superimposes the superimposed image S and the mask data M, on the spherical image CE. The image is generated, in which the high-definition superimposed image S is superimposed on the low-definition spherical image CE.
As illustrated in
<<Operation According to Embodiment>>
Referring now to
As illustrated in
The short-range communication unit 58 of the smart phone 5 sends a polling inquiry to start image capturing, to the short-range communication unit 38 of the generic image capturing device 3 (S12). The short-range communication unit 38 of the generic image capturing device 3 receives the inquiry to start image capturing.
The determiner 37 of the generic image capturing device 3 determines whether image capturing has started, according to whether the acceptance unit 32 has accepted pressing of the shutter button 315a by the user (S13).
The short-range communication unit 38 of the generic image capturing device 3 transmits a response based on a result of the determination at S13, to the smart phone 5 (S14). When it is determined that image capturing has started at S13, the response indicates that image capturing has started. In such case, the response includes an image identifier of the image being captured with the generic image capturing device 3. In contrary, when it is determined that the image capturing has not started at S13, the response indicates that it is waiting to start image capturing. The short-range communication unit 58 of the smart phone 5 receives the response.
The description continues, assuming that the determination indicates that image capturing has started at S13 and the response indicating that image capturing has started is transmitted at S14.
The generic image capturing device 3 starts capturing the image (S15). The processing of S15, which is performed after pressing of the shutter button 315a, includes capturing the object and surroundings to generate captured image data (planar image data) with the image capturing unit 33, and storing the captured image data in the memory 3000 with the storing and reading unit 39. In this example, it is assumed that more than one planar image is captured.
At the smart phone 5, the short-range communication unit 58 transmits an image capturing start request, which requests to start image capturing, to the special image capturing device 1 (S16). The short-range communication unit 18 of the special image capturing device 1 receives the image capturing start request.
The special image capturing device 1 starts capturing the image (S17). Specifically, at S17, the image capturing unit 13 captures the object and surroundings to generate captured image data, i.e., two hemispherical images as illustrated in
At the smart phone 5, the short-range communication unit 58 transmits a request to transmit a captured image (“captured image request”) to the generic image capturing device 3 (S18). The captured image request includes the image identifier received at S14. The short-range communication unit 38 of the generic image capturing device 3 receives the captured image request.
The short-range communication unit 38 of the generic image capturing device 3 transmits planar image data, obtained at S15, to the smart phone 5 (S19). With the planar image data, the image identifier for identifying the planar image data, and attribute data, are transmitted. The image identifier and attribute data of the planar image, are a part of planar image information illustrated in
The short-range communication unit 18 of the special image capturing device 1 transmits the equirectangular projection image data, obtained at S17, to the smart phone 5 (S20). With the equirectangular projection image data, the image identifier for identifying the equirectangular projection image data, and attribute data, are transmitted. As illustrated in
Next, the storing and reading unit 59 of the smart phone 5 stores the planar image data received at S19, and the equirectangular projection image data received at S20, in the same folder in the memory 5000 (S21).
Next, the image and audio processing unit 55 of the smart phone 5 generates superimposition relationship metadata, which is used to display an image where the planar image P (for example, the planar images PA and PB) is partly superimposed on the spherical image CE (S22). Here, the planar image P (any one of the planar images PA and PB) is a high-definition image, and the spherical image CE is a low-definition image. The storing and reading unit 59 stores the superimposition relationship metadata in the memory 5000.
Referring to
(Process of Generating Superimposition Relationship Metadata)
First, a process of generating superimposition relationship metadata is described.
(Superimposition Relationship Metadata (1))
First, a process is described for generating the superimposition relationship metadata (see
The extractor 550 extracts a plurality of feature points fp1 from the rectangular, equirectangular projection image EC, which is generated in equirectangular projection (S110). The extractor 550 further extracts a plurality of feature points fp2A from the rectangular, planar image PA, which is generated in perspective projection (S110) As described above, the feature points are extracted based on local features of each of the images including the same object, for example.
Then, as illustrated in
Then, the point of gaze specifier 554 specifies the point (the point of gaze GP1) in the equirectangular projection image EC, which corresponds to the central point CP1 of the planar image PA after the first homography transformation (S130).
Then, as illustrated in
Next, the extractor 550 extracts a plurality of feature points fp3A from the peripheral area image PI, which is obtained by the projection converter 556, based on local features of the image (S150).
Then, the second area calculator 557a calculates corresponding points between the planar image PA and the peripheral area image PI based on the similarity between the feature values fv2A of the plurality of feature points fp2A in the planar image PA and the feature values fv3A of the plurality of feature points fp3A in the peripheral area image PI. The second area calculator 557 further estimates a plane on the peripheral area image PI, which corresponds to the planar image PA, based on the calculated corresponding points between the two images to perform second homography transformation. Accordingly, the second area calculator 557a calculates the rectangular, second area CA2 in the peripheral area image PI, which corresponds to the planar image PA (S160). The planar image PA, which is a high-definition image having, for example, 40,000,000 pixels, may be resized to a suitable size in advance.
Then, the superimposition relationship metadata generator 558 generates superimposition relationship metadata (1) for the planar image PA, as illustrated in
(Superimposition Relationship Metadata (2))
Next, a process is described for generating the superimposition relationship metadata (see
First, the extractor 550 extracts the plurality of feature points fp2A from the rectangular, planar image PA, which is generated in perspective projection (S180). The extractor 550 further extracts the plurality of feature points fp2B from the rectangular, planar image PB, which is also generated in perspective projection (S180).
Then, the third area calculator 559a calculates corresponding points between the planar image PB and the planar image PA based on the similarity between the feature values fv2B of the plurality of feature points fp2B in the planar image PB and the feature values fv3A of the plurality of feature points fp3A in the planar image PA. The third area calculator 559a further estimates a plane in the planar image PA, which corresponds to the planar image PB, based on the calculated corresponding points between the two images to perform third homography transformation. Accordingly, the third area calculator 559a calculates the rectangular, third area CA3 in the planar image PA, which corresponds to the planar image PB (S190).
Then, the superimposition relationship metadata generator 558 generates superimposition relationship metadata (2) for the planar image B, as illustrated in
(Process of Generating Superimposed Display Data)
Next, a process for generating superimposed display data is described.
(Superimposed Display Data (1))
First, a process is described for generating superimposed display parameters (see
The second area calculator 557b performs second homography transformation using the superimposition relationship metadata generated at S170 to calculate the rectangular second area CA2 in the peripheral area image PI, which corresponds to the planar image PA (S210-1).
Then, as illustrated in
Then, as illustrated in
Next, a process of generating a first correction parameter is described with reference to
After the processing of S230-1, the shape converter 564 projects the four vertices of the second area CA2, as illustrated in
Then, as illustrated in
Then, the correction parameter generator 566 generates a first correction parameter (S260-1). The first correction parameter is used to match the brightness and color values of the grid areas LAA in the planar image PA, corresponding to the grid areas LA2′ in the second area CAT, to the color values of the grid areas LA2′.
Finally, as illustrated in
(Superimposed Display Data (2))
Next, a process is described for generating superimposed display data (see
First, the third area calculator 559b performs third homography transformation using the superimposition relationship metadata generated at S200 to calculate the rectangular, third area CA3 in the planar image PA, which corresponds to the planar image PB (S210-2-1).
Then, the second area calculator 557b performs second homography transformation using the superimposition relationship metadata generated at S170 to calculate a rectangular, fourth corresponding area CA4 (“fourth area CA4”) in the peripheral area image PI, which corresponds to the third area CA3 (S210-2-2).
Then, the area divider 560 divides the fourth area CA4 into a plurality of grid areas LA4 (S220-2). The fourth area CA4 may be divided in a way similar to that in
Then, the projection reverse converter 562 converts (reversely converts) the projection of the fourth area CA4 to equirectangular projection, which is the same as the projection of the equirectangular projection image EC (S230-2). Accordingly, as illustrated in
Next, a process is described for generating a second correction parameter. The second correction parameter may be generated in a way similar to that in
After the processing of S230-2, the shape converter 564 projects the four vertices of the fourth area CA4 onto the four vertices of the planar image PB to convert the fourth area CA4 so that the fourth area CA4 has the same shape as the planar image PB. Accordingly, the shape converter 564 obtains a fourth area CA4′ (S240-2).
Then, the area divider 560 divides the planar image PB into a plurality of grid areas LAB (S250-2). The shape and number of grid areas LAB are equal to the shape and number of grid areas LA4′ in the fourth area CA4′, which are obtained as a result of conversion.
Then, the correction parameter generator 566 generates a second correction parameter (S260-2). The second correction parameter is used to match the brightness and color values of the grid areas LAB in the planar image PB, corresponding to the grid areas LA4′ in the fourth area CA4′, to the color values of the grid areas LA4′.
Finally, as illustrated in
Accordingly, the processing of S22 illustrated in
Referring now to
As illustrated in
As illustrated in
Specifically, referring to
Since the location of the foreground image C is determined with respect to the foreground image B, and the location of the foreground image B is determined with respect to the foreground image A, the positional shifts between the planar images A, B, and C can be reduced. Further, since the location of the foreground image A is determined with respect to the background image X, the positional shifts between the background image X, and any one of the foreground images A, B, and C can be reduced.
Further, the operation of determining a superimposed location according to this embodiment can effectively reduce computational loads, especially with the increase in number of images to be processed. This will be explained referring to
In
In this example, as illustrated in
That is, the relationship in location transformation between the foreground images A, B, and C, and information on location transformation of the foreground image A with respect to the background images X and Y, are only needed. For example, the location at which the foreground image C is to be superimposed on the background image X can be determined by converting location information in sequence. Since the superimposed location of the foreground image C on the foreground image A does not change, the superimposed location of the foreground image C on the background image X or Y can be calculated, using a relationship of the foreground image A with respect to the background image X or Y.
The technique described above can reduce the number of times the superimposed location calculation operation is performed based on matching processing, which imposes a large processing load. As the number of foreground images increases, this advantage becomes more noticeable.
Further, since the number of times for calculating the superimposed location for the foreground image with respect to the background image decreases, the overall processing can be simplified, based on assumption that the background image is an equirectangular projection image (spherical image), as matching between the planar image and the equirectangular projection image tends to be more complex compared to matching between the planar images.
Further, as described above referring to
Using information on the relationship between the foreground images, i.e., the superimposition relationship metadata, images can be managed with improved efficiently, especially when a large number of foreground images and/or background images are to be processed. This will be described below referring to
In this example illustrated in
Specifically, referring to the example illustrated in
The group of foreground images can be managed in a tree structure rooted at a single node of each of the background images X, Y, and Z. That is, the background image X may have a tree structure including the foreground images A and D as children. Likewise, the background image Y has a tree structure including the foreground images D to I as children. The background image Z has a tree structure including the foreground images G to I as children. Further, the grouping of foreground images is represented as a set of superimposition relationship metadata for the corresponding background image. That is, metadata related to each image is not used alone but a metadata group is used to identify foreground images to be superimposed on a certain background image and to determine superimposed locations.
Specifically, simple matrix computation, such as determination of the product of homography, may be performed to calculate a position in a child image corresponding to a position in the predecessor image. As described above referring to
In some cases, however, the image sizes of the foreground images A and B when homography for the foreground images A and B is determined, and the image sizes of the foreground images B and C when homography for the foreground images B and C is determined, may differ. In such case, to determine the position (projection) relationship between the foreground images A and C, the difference in scale due to the difference in image size should be taken into account. Here, the difference in image size can be represented by using homography due to the plane-to-plane projection. Accordingly, the product of homography is used to determine the projection from the foreground image A to the foreground image C. As described above referring to
With the use of superimposition relationship metadata, computation of superimposed location can be easily handled. For example, for each of a plurality of different background images X and Y, the superimposed location of a target image can be calculated using superimposed location calculation information of a foreground image as the parent image for that target image. That is, in this embodiment, a background image and a plurality of foreground images are represented as nodes in a tree structure, which indicates the parent-child relationship between the images, and are each assigned superimposition relationship metadata. The metadata items of the images are suitably associated (grouped) to identify each foreground image to be superimposed on a background image and to calculate superimposed location of each foreground image.
Since each node, i.e., each image, has information on the superimposed location in its parent node, which is represented as the superimposition relationship metadata. When a certain image is superimposed on a new background image, which does not belong to the current group, not all of the related foreground images are subjected to matching processing but a foreground image set as the root node of a subtree (a portion of the tree structure) including the related foreground images is subjected to matching processing. Accordingly, the superimposed locations of the descendant foreground images associated with the root node can be calculated.
In
(Operation of Superimposing Images)
Referring back to
The operation of superimposing images at S23 illustrated in
The storing and reading unit 59 (obtainer) illustrated in
Then, as illustrated in
The correction unit 584 corrects the brightness and color of the planar image P, using the correction parameter of the superimposed display data, to match the brightness and color of the equirectangular projection image EC (S320). The planar image P, which has been corrected, is referred to as the “corrected planar image C”.
The image generator 586 superimposes the corrected planar image C of the planar image P, on the partial sphere PS to generate the superimposed image S (S330). The pixels other than the pixels corresponding to the grids having the positions defined by the location parameter are interpolated by linear interpolation. The image generator 586 generates mask data M based on the partial sphere PS (S340). The image generator 586 covers (attaches) the equirectangular projection image EC, over a surface of the sphere CS, to generate the spherical image CE (S350). The image superimposing unit 588 superimposes the superimposed image S and the mask data M, on the spherical image CE (S360). The image is generated, in which the high-definition superimposed image S is superimposed on the low-definition spherical image CE. With the mask data, the boundary between the two different images is made unnoticeable.
As illustrated in
Referring to
As illustrated in
In view of the above, in this embodiment, the location parameter is generated, which indicates respective positions of a plurality of grid areas in the superimposed image S with respect to the planar image P. With this location parameter, as illustrated in
Accordingly, the image capturing system of this embodiment is able to display an image in which the high-definition planar image P is superimposed on the low-definition spherical image CE, with high image quality. This will be explained referring to
It is assumed that, while the spherical image CE without the planar image P being superimposed, is displayed as illustrated in
As described above, when a planar image (foreground image) serving as a second image and a planar image (foreground image) serving as a third image are superimposed on an equirectangular projection image (background image) serving as a first image, the positional shift may be eliminated or reduced between the second image and the third image, while eliminating or reducing the positional shift between the second image and the first image. That is, if the second image and the third image partially or entirely overlap, the positional shift may be noticeable between the second image and the third image, even when there is no positional shift between the second image and the first image. In this embodiment, stepwise matching processing is performed to generate superimposed display data indicating the location at which the third image is to be superimposed on the first image. Accordingly, the positional shift may be eliminated or reduced between the foreground images (the second image and the third image).
When the third image (the foreground image) is superimposed on an area in the second image (another foreground image), the positional shift between the second image and the third image (foreground images) may be reduced by calculating the matched position between the second and third images, rather than by calculating the positions at which the second and third images are superimposed on the background image. In the following, the second image and the third image are each referred to as the foreground image, and the first image is referred to as the background image.
That is, a result of calculation of the locations at which the foreground images are superimposed on the background image tend to include an error, compared to the case in which a result of calculation of the locations at which the foreground image is superimposed on its parent, foreground image. Typically, a foreground image has a smaller angle of view but has higher image resolution than a background image, and is beneficial to extract feature values effective for matching processing. Further, the foreground images that have been captured using the same device (camera) tend to have more similar quality in terms of correlation with lens distortion or image processing than foreground images that have been captured using different devices, which is beneficial to calculate a superimposed location. In addition, with the use of an image having an intermediate angle of view (intermediate-angle-of-view foreground image) having a smaller difference in angle of view from a background image, the final position at which a foreground image (narrow-angle foreground image) having a narrow angle of view is superimposed on the background image can be determined more accurately than that determined by matching the foreground image directly to the background image, which has a larger angle of view and a larger difference in quality than the foreground image, based on fewer feature points or smaller feature values. That is, for example, as illustrated in
(2) When the planar image PB (the foreground image B), which is captured with relatively long focal length, is to be matched to the equirectangular projection image EC (background image), due to the large difference in size between the captured areas, it may be difficult to calculate the superimposed location or the planar image PB and the equirectangular projection image EC may be greatly shifted from each other. In contrast, in this embodiment, stepwise matching processing is performed such that the planar image PB is matched to the planar image PA (the foreground image A), which is captured with relatively short focal length, and is finally matched to the equirectangular projection image EC. This stepwise matching processing may advantageously determine the superimposed location or prevent the occurrence of large shift between the planar image PB and the equirectangular projection image EC.
In matching processing to calculate the superimposed location of a foreground image in a background image, if the foreground image has a narrow angle of view, the area in the background image corresponding to the foreground image is also narrow. Accordingly, the number of feature values that can be used for the matching processing is reduced. That is, features can be extracted from each of a background image and a foreground image when the foreground image covers a certain area of the background image. If the foreground image covers a small area of the background image, a small number of feature values can be obtained. This causes a tendency that the accuracy of determination of a superimposed location in the background image is also reduced. In some cases, the detection of the superimposed location may fail. In stepwise matching processing according to this embodiment, a foreground image having an intermediate angle of view (intermediate-angle-of-view foreground image) is used to determine an area in the intermediate-angle-of-view foreground image corresponding to a narrow-angle foreground image by using matching processing. The transformation between the intermediate-angle-of-view foreground image and the narrow-angle foreground image is stored as superimposed location transformation information. A point in the background image corresponding to the intermediate-angle-of-view foreground image is further calculated, and the correspondence between a plurality of points in the intermediate-angle-of-view foreground image and a plurality of corresponding points in the background image is determined. As described above, corresponding areas can be calculated between a background image and a foreground image. Similarly, this technique can be used to identify which area in an intermediate-angle-of-view image a narrow-angle image corresponds, and calculate the location at which the narrow-angle foreground image is to be superimposed on the background image even when the background image and the intermediate-angle-of-view foreground image are based on different projection methods. That is, for example, as illustrated in
(3) As described above, using superimposition relationship metadata can simplify the calculation process. For example, superimposed location calculation information for a parent foreground image is determined to calculate the superimposed location of a child image in each of a plurality of different background images X and Y.
In this embodiment, a plurality of foreground images and a background image are used as nodes in a tree structure, which indicates the parent-child relationship between the images, and are each assigned superimposition relationship metadata. The metadata items of the images are suitably associated (grouped) to identify foreground images for a background image and to calculate superimposed locations. That is, each node has information on the superimposed location in its parent node. When a certain image is superimposed on a new background image, which does not belong to the current group, not all of the related foreground images are subjected to matching processing but a foreground image set as the root node of a subtree (a portion of the tree structure) including the related foreground images is subjected to matching processing. Accordingly, the superimposed locations of the descendant foreground images associated with the root node can be calculated. That is, not all of the descendant foreground images are to be matched to a new background image, resulting in a reduction in calculation processing load when many foreground images are to be superimposed. Determining feature values of images and performing matching processing to determine corresponding positions impose a large load. Determining a new position relationship by using previously calculated position relationships is very beneficial. In addition, information on superimposition locations can be handled in units of a tree including subtrees. Accordingly, flexible operations are achieved, such as the generation of a new group and the deletion or addition of a foreground image from or to a group.
Referring now to
<Overview of Image Capturing System>
First, referring to
As illustrated in
In the first embodiment, the smart phone 5 generates superimposed display data, and processes superimposition of images. In this second embodiment, the image processing server 7 performs such processing, instead of the smart phone 5. The smart phone 5 in this embodiment is one example of the communication terminal, and the image processing server 7 is one example of the image processing apparatus or device.
The image processing server 7 is a server system, which is implemented by a plurality of computers that may be distributed over the network to perform processing such as image processing in cooperation with one another.
<Hardware Configuration>
Next, referring to
<Hardware Configuration of Image Processing Server>
The CPU 701 controls entire operation of the image processing server 7. The ROM 702 stores a control program for controlling the CPU 701. The RAM 703 is used as a work area for the CPU 701. The HD 704 stores various data such as programs. The HDD 705 controls reading or writing of various data to or from the HD 704 under control of the CPU 701. The medium I/F 707 controls reading or writing of data with respect to a recording medium 706 such as a flash memory. The display 708 displays various information such as a cursor, menu, window, characters, or image. The network I/F 709 is an interface that controls communication of data with an external device through the communication network 100. The keyboard 711 is one example of input device provided with a plurality of keys for allowing a user to input characters, numerals, or various instructions. The mouse 712 is one example of input device for allowing the user to select a specific instruction or execution, select a target for processing, or move a curser being displayed. The CD-RW drive 714 reads or writes various data with respect to a Compact Disc ReWritable (CD-RW) 713, which is one example of removable recording medium.
The image processing server 7 further includes the bus line 710. The bus line 710 is an address bus or a data bus, which electrically connects the elements in
<Functional Configuration of Image Capturing System>
Referring now to
<Functional Configuration of Image Processing Server>
As illustrated in
The image processing server 7 further includes a memory 7000, which is implemented by the ROM 702, the RAM 703 and the HD 704 illustrated in
The long-range communication unit 71 of the image processing server 7 is implemented by the network I/F 709 that operates under control of the CPU 701, illustrated in
The acceptance unit 72 is implement by the keyboard 711 or mouse 712, which operates under control of the CPU 701, to receive various selections or inputs from the user.
The image and audio processing unit 75 is implemented by the instructions of the CPU 701. The image and audio processing unit 75 applies various types of processing to various types of data, transmitted from the smart phone 5.
The display control 76, which is implemented by the instructions of the CPU 701, generates data of the predetermined-area image Q, as a part of the planar image P, for display on the display 517 of the smart phone 5. The display control 76 superimposes the planar image P, on the spherical image CE, using superimposed display data, generated by the image and audio processing unit 75. With the superimposed display data, each grid area LAA of the planar image PA is placed at a location indicated by a location parameter, and is adjusted to have a brightness value and a color value indicated by a correction parameter.
The determiner 77 is implemented by the instructions of the CPU 701, illustrated in
The storing and reading unit 79, which is implemented by instructions of the CPU 701 illustrated in
(Functional Configuration of Image and Audio Processing Unit)
Referring to
The image and audio processing unit 75 mainly includes a generator 75a that performs encoding, and a superimposing unit 75b that performs decoding. The generator 75a performs processing of S44, which is processing to generate superimposition relationship metadata, as illustrated in
(Functional Configuration of Metadata Generator)
First, a functional configuration of the generator 75a is described according to the embodiment. The generator 75a mainly includes a metadata generator 75a1 and a display data generator 75a2. The metadata generator 75a1 includes an extractor 750, a first area calculator 752, a point of gaze specifier 754, a projection converter 756, a second area calculator 757a, a third area calculator 759a, and a superimposition relationship metadata generator 758. These elements of the metadata generator 75a1 are substantially similar in function to the extractor 550, first area calculator 552, point of gaze specifier 554, projection converter 556, second area calculator 557a, third area calculator 559a, and superimposition relationship metadata generator 558 of the metadata generator 55a1 of the first embodiment. Accordingly, the description thereof is omitted.
The display data generator 75a2 includes a second area calculator 757b, an area divider 760, a projection reverse converter 762, a shape converter 764, a correction parameter generator 766, and a superimposed display data generator 770. These elements of the display data generator 75a2 are substantially similar in function to the second area calculator 557b, third area calculator 559b, area divider 560, projection reverse converter 562, shape converter 564, correction parameter generator 566, and superimposed display data generator 570 of the display data generator 55a2 of the first embodiment, respectively. Accordingly, the description thereof is omitted.
Referring to
<Operation>
Referring to
At the smart phone 5, the long-range communication unit 51 transmits a superimposing request, which requests for superimposing one image on other image, to the image processing server 7, through the communication network 100 (S42). The superimposing request includes image data to be processed, which has been stored in the memory 5000. In this example, the image data to be processed includes planar image data (for example, the planar images A and B), and equirectangular projection image data, which are stored in the same folder. The long-range communication unit 71 of the image processing server 7 receives the image data to be processed.
Next, at the image processing server 7, the storing and reading unit 79 stores the image data to be processed (planar image data and equirectangular projection image data), which is received at S42, in the memory 7000 (S43). The generator 75a illustrated in
Next, the display control 76 generates data of the predetermined-area image Q, which corresponds to the predetermined area T, to be displayed in a display area of the display 517 of the smart phone 5. As described above in this example, the predetermined-area image Q is displayed so as to cover the entire display area of the display 517. In this example, the predetermined-area image Q includes the superimposed image S superimposed with the planar image P (such as planar images PA and PB). The long-range communication unit 71 transmits data of the predetermined-area image Q, which is generated by the display control 76, to the smart phone 5 (S46). The long-range communication unit 51 of the smart phone 5 receives the data of the predetermined-area image Q.
The display control 56 of the smart phone 5 controls the display 517 to display the predetermined-area image Q including the superimposed image S (S47).
Accordingly, the image capturing system of this embodiment can achieve the advantages described above referring to the first embodiment.
Further, in this embodiment, the smart phone 5 performs image capturing, and the image processing server 7 performs image processing such as generation of superimposed display data and generation of superimposed images. This results in decrease in processing load on the smart phone 5. Accordingly, high image processing capability is not required for the smart phone 5.
Any one of the above-described embodiments may be implemented in various other ways. For example, as illustrated in
In any of the above-described embodiments, the planar image P is superimposed on the spherical image CE. Alternatively, the planar image P to be superimposed may be replaced by a part of the spherical image CE. In another example, after deleting a part of the spherical image CE, the planar image P may be embedded in that part having no image.
Furthermore, in the second embodiment, the image processing server 7 performs superimposition of images (S45). For example, the image processing server 7 may transmit the superimposition relationship metadata to the smart phone 5, to instruct the smart phone 5 to perform superimposition of images and display the superimposed images. In such case, at the image processing server 7, the generator 75a illustrated in
Further, in some of the above-described embodiments, the location parameter (that is, the superimposed display data illustrated in
As described above referring to
In this disclosure, examples of superimposition of images include, but not limited to, placement of one image on top of other image entirely or partly, laying one image over other image entirely or partly, mapping one image on other image entirely or partly, pasting one image on other image entirely or partly, combining one image with other image, and integrating one image with other image. That is, as long as the user can perceive a plurality of images (such as the spherical image and the planar image) being displayed on a display as they were one image, processing to be performed on those images for display is not limited to the above-described examples.
The above-described embodiments are illustrative and do not limit the present invention. Thus, numerous additional modifications and variations are possible in light of the above teachings. For example, elements and/or features of different illustrative embodiments may be combined with each other and/or substituted for each other within the scope of the present invention.
The present invention can be implemented in any convenient form, for example using dedicated hardware, or a mixture of dedicated hardware and software. The present invention may be implemented as computer software implemented by one or more networked processing apparatuses. The processing apparatuses can compromise any suitably programmed apparatuses such as a general-purpose computer, personal digital assistant, mobile telephone (such as a WAP or 3G-compliant phone) and so on, depending on the functional structure. Since the present invention can be implemented as software, each and every aspect of the present invention thus encompasses computer software implementable on a programmable device. The computer software can be provided to the programmable device using any recording medium. Examples of such recording medium include, but not limited to, a memory on a server such as a ROM or RAM, and a removable memory such as a USB memory, an optical disc, or a magnetic disk. Such recording medium storing any of the above-described programs may be distributed domestically or overseas as a program product.
Each of the functions of the described embodiments may be implemented by one or more processing circuits or circuitry. Processing circuitry includes a programmed processor, as a processor includes circuitry. A processing circuit also includes devices such as an application specific integrated circuit (ASIC), digital signal processor (DSP), field programmable gate array (FPGA), and conventional circuit components arranged to perform the recited functions.
Number | Date | Country | Kind |
---|---|---|---|
2018-058883 | Mar 2018 | JP | national |
2019-044537 | Mar 2019 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5990941 | Jackson | Nov 1999 | A |
6002430 | McCall | Dec 1999 | A |
6426774 | Driscoll, Jr. | Jul 2002 | B1 |
7382399 | McCall | Jun 2008 | B1 |
8345144 | Georgiev | Jan 2013 | B1 |
10165181 | Ono | Dec 2018 | B2 |
20080002041 | Chuang | Jan 2008 | A1 |
20090041379 | Shih | Feb 2009 | A1 |
20120098926 | Kweon | Apr 2012 | A1 |
20160035110 | Kiyota | Feb 2016 | A1 |
20160323504 | Ono | Nov 2016 | A1 |
20160328854 | Kimura | Nov 2016 | A1 |
20160346693 | Minato | Dec 2016 | A1 |
20170023492 | Olsson | Jan 2017 | A1 |
20170104929 | Ono | Apr 2017 | A1 |
20180126903 | Herrmann | May 2018 | A1 |
20180176465 | Chen | Jun 2018 | A1 |
20180181358 | Asai et al. | Jun 2018 | A1 |
20180182065 | Yoshida et al. | Jun 2018 | A1 |
20180184001 | Yoshida et al. | Jun 2018 | A1 |
20180270417 | Suitoh et al. | Sep 2018 | A1 |
20180329927 | Garg | Nov 2018 | A1 |
20180343388 | Matsushita | Nov 2018 | A1 |
20190001887 | Guerreiro | Jan 2019 | A1 |
20190007609 | Isobe | Jan 2019 | A1 |
20190045122 | Chiaki | Feb 2019 | A1 |
20190202356 | Cano | Jul 2019 | A1 |
20190266423 | Akiba | Aug 2019 | A1 |
Number | Date | Country |
---|---|---|
2016-096487 | May 2016 | JP |
2018-109946 | Jul 2018 | JP |
WO2012166293 | Dec 2012 | WO |
Number | Date | Country | |
---|---|---|---|
20190295216 A1 | Sep 2019 | US |