This patent application is based on and claims priority pursuant to 35 U.S.C. § 119(a) to Japanese Patent Application No. 2018-070486, filed on Mar. 31, 2018, and 2019-046780, filed on Mar. 14, 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 capturing system, an image processing method, and a recording medium.
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.
On the other hand, a digital camera that captures two hemispherical images from which a 360-degree, spherical image is generated, has been proposed. Such digital camera generates an equirectangular projection image based on two hemispherical images, and transmits the equirectangular projection image to a communication terminal, such as a smart phone, for display to a user.
Example embodiments of the present invention include an information processing apparatus, which: obtains a first image in first projection, and a second image in second projection; transforms projection of a first corresponding area of the first image, which corresponds to the second image, from the first projection to the second projection, to generate a third image in the second projection; identifies a plurality of feature points, respectively, in the second image and the third image; determines a second corresponding area in the third image, which corresponds to the second image, based on the plurality of feature points respectively identified in the second image and the third image; corrects the second corresponding area based on a plurality of blocks in the third image, which are determined through matching a plurality of blocks divided from the second image to corresponding areas of the third image; transforms projection of a plurality of points in the corrected corresponding area of the third image, from the second projection to the first projection, to obtain location information indicating locations of the plurality of points that have been obtained through transformation in the first image; and stores, in a memory, the location information indicating the locations of the plurality of points in the first image in the first projection, in association with the plurality of points in the second image in the second projection.
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 second image is an image to be superimposed on the first image. For example, the first image is an image covering an area larger than that of the second image. In another example, the second 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 image may be a high-definition image. In another example, the first image and the second 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 image in a second projection include a perspective projection image, such as a planar image. Tn this disclosure, the second image, such as the planar image captured with the general image capturing device, is treated as one example of the second image in the second projection (that is, in the second projective space).
The first image, and even the second image, if desired, can be made up of multiple pieces of image data which have been captured through different lenses, or using different image sensors, or at different times.
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, one or more 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 I/F 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 I/F 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.
The Micro USB terminal 121 is a connector to be connected with such as a Micro USB cable, or other electronic device.
<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 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 one example of location information. The correction parameter is one example of correction information.
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 metadata generator 55a that performs encoding, and a superimposing unit 55b that performs decoding. In this example, the encoding corresponds to processing to generate metadata to be used for superimposing images for display (“superimposed display metadata”). Further, in this example, the decoding corresponds to processing to generate images for display using the superimposed display metadata. The metadata generator 55a performs processing of S22, which is processing to generate superimposed display metadata, as illustrated in
First, a functional configuration of the metadata generator 55a is described according to the embodiment. The metadata generator 55a includes an extractor 550, a first area calculator 552, a point of gaze specifier 554, a projection converter 556, a second area calculator 558, a corresponding area correction unit 559, an area divider 560, a projection reverse converter 562, a shape converter 564, a correction parameter generator 566, and a superimposed display metadata generator 570. In case the brightness and color is not to be corrected, the shape converter 564 and the correction parameter generator 566 do not have to be provided.
The extractor 550 extracts feature points according to local features of each of two images having the same object. 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. Unless the difference in projection methods cause highly distorted images, any desired image projection methods may be used. For example, referring to
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 fv2 based on the plurality of feature points fp2 in the planar image P. 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 fv2 of the feature points fp2 in the planar image P. 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 P. The first area calculator 552 then applies first homography transformation to the planar image P (S120). Here, the corresponding points are a plurality of points that are selected from each image based on similarity. 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 P. In such case, a central point CP1 of a rectangle defined by four vertices of the planar image P, 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 P 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 P 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 P 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.5π). 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 PA, which is a part surrounding the point of gaze GP1, from the equirectangular projection image EC. The projection converter 556 converts the peripheral area PA, from the equirectangular projection to the perspective projection, to generate a peripheral area image PI (S140). The peripheral area PA 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 P. Here, the central point CP2 of the peripheral area image PI corresponds to the point of gaze GP 1.
(Transformation of Projection)
The following describes transformation of a projection, performed at S140 of
(x,y,z)=(cos(ea)×cos(aa),cos(ea)×sin(aa),sin(ea)), wherein the sphere CS has a radius of 1. (Equation 4)
The planar image P in perspective projection, is a two-dimensional image. When the planar image P 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 P, 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 Assuming that the polar angle is t, Equation 6 can be expressed as:t=arctan(r). (Equation 7)
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 P in perspective projection. More specifically, the moving radius r, which corresponds to the diagonal angle of view α of the planar image P, is used to calculate transformation map coordinates, which indicate correspondence of a location of each pixel between the planar image P 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 first area calculator 552 to determine correspondence between the planar image P and the peripheral area image PI, it is desirable that the peripheral area image PI is sufficiently large to include the entire second area CA02. If the peripheral area image PI has a large size, the second area CA02 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 CA02. 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 P. 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 P1 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 P while centering on the point of gaze, but has the vertical angle of view α that is kept small as possible.
(Calculation of Location Information)
Referring back to
In the above-described transformation, in order to increase the calculation speed, an image size of at least one of the planar image P and the equirectangular projection image EC may be changed, before applying the first homography transformation. For example, assuming that the planar image P has 40 million pixels, and the equirectangular projection image EC has 30 million pixels, the planar image P may be reduced in size to 30 million pixels. Alternatively, both of the planar image P 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 P and the peripheral area image PI may be changed, before applying the second homography transformation.
The homography is generally known as a technique to project one plane onto another plane through projection transformation.
Specifically, through the first homography transformation, a first homography is calculated based on a relation in projective space between the planar image P and the equirectangular projection image EC, to obtain the point of gaze GP1. Through homography transformation, from the peripheral area PA, which is defined by the GP1, the peripheral area image PI is obtained. A second homography can be represented as a transformation matrix indicating a relation in projective space between the peripheral area image PI and the planar image P. As described above, the peripheral area image PI is obtained by applying predetermined projection transformation to the equirectangular projection image EC. Any point (such as a quadrilateral) on the planar image P (that is, one reference system) is multiplied by the transformation matrix (homography), which is calculated, to obtain a corresponding point (corresponding quadrilateral) on the peripheral area image PI (that is, another reference system).
The corresponding area correction unit 559 corrects the second area CA02 to generate a second area CA2, which is similar to an area in the equirectangular projection image EC corresponding to the planar image P. The corresponding area correction unit 559 is described in detail with reference to
The corresponding area correction unit 559 includes a dividing unit 21, a matching unit 22, a motion vector calculation unit 23, a motion vector correction unit 24, and a representative point correction unit 25. The corresponding area correction unit 559 receives data of the second area CA02 calculated by the second area calculator 558 and corrects the second area CA02. The result of correcting the second area CA02 is output to the area divider 560.
The matching unit 22 uses each of the obtained blocks as a template to calculate the corresponding area in the peripheral area image PI. That is, the matching unit 22 determines, for each block, the corresponding area in the peripheral area image PI. The area corresponding to each block may be searched for from within not the entire peripheral area image PI but a portion of the peripheral area image P1. For example, a detection result of the second area calculator 558 is subjected to block matching. In this case, the peripheral area image PI may be divided into a number of blocks equal to the number of blocks of the planar image P, and block matching may be performed on neighboring pixels of corresponding blocks. The number of blocks of the peripheral area image PI is desirably set to a value equal to or less than the number of blocks of the planar image P. This can avoid large deviations of the results of block matching and also can reduce the time taken for calculation. Further, specifying an area of neighboring pixels can maintain balance between the matching accuracy and the time taken for calculation. As illustrated in
The motion vector calculation unit 23 calculates a motion vector for correcting the position of each block.
With the use of motion vectors, the initial position of each representative point to be used as a reference is compared with the position of the corresponding representative point, which has been moved through block matching, and the corresponding vector is calculated. In this embodiment, the position of each representative point, which has been moved after block matching, is compared with the position (initial position) of each of the representative points RP01 to RP04 of the second area CA02. While the illustration of
The offsets from the representative points RP01 to RP04 of the second area CA02 to corners of the blocks illustrated in
Accordingly, the motion vector correction unit 24 corrects a motion vector.
Similarity refers to a measure used for template matching between, for example, each block in the planar image P and the corresponding area in the peripheral area image PI, such as sum of squared differences (SSD) or zero-mean normalized cross-correlation (ZNCC). Similarity is represented by a real number having a value ranging from 0 to 1. For example, SSD uses the sum of squared differences of pixel values between two images as a measure. The smaller the SSD, the more similar the images are. ZNCC is a measure of similarity used to subtract the mean of pixel values from each of two images and then determine normalized cross-correlation of the two images. Any measure other than SSD or ZNCC may be used. Dissimilarity represented by a real number having a value ranging from 0 to 1 may be used as a measure of matching. In this case, a value obtained by subtracting dissimilarity from 1 may be used as similarity.
The luminance variance is a value V represented using Equation 20 below.
Here, n denotes the number of pixels in a block, the initial x denotes the luminance value of each pixel, and the subsequent x (x-bar) denotes the mean of the luminance values of the pixels.
The validity X based on similarity is described. A result of matching between low-similarity blocks is likely to be unreliable. If a result of matching between low-similarity blocks is applied, a position may be corrected in accordance with the incorrect matching result. Accordingly, the validity X is set to 0 for low-similarity blocks so as not to use the results for correction processing. For intermediate-similarity blocks, position correction is performed with adverse effects minimized. For high-similarity blocks, the validity X is set to 1.
Next, the validity Y based on luminance variance is described. A block with low luminance variance is likely to present an image having a few feature points. Even when the similarity is high, the matching result is likely to be unreliable. If a result of matching between blocks having low luminance variance is applied, as in the low-similarity case, a position may be corrected in accordance with the incorrect matching result. Accordingly, the validity Y is set to 0 for blocks having low luminance variance so as not to use the results for correction processing. For blocks having intermediate luminance variance, position correction is performed with adverse effects minimized. For blocks having high luminance variance, the validity Y is set to 1. Reference values LX (e.g., 0.4) and HX (e.g., 0.7) for similarity and reference values LY and HY for luminance variance may be specified as desired. The final correction validity is calculated using Equation 21 below. For example, parameters for low, intermediate, and high similarities, which are set for each of the validity X and the validity Y, may have the following ranges of values: 0 or more and less than 0.3 for low similarity, 0.3 or more and less than 0.7 for intermediate similarity, and 0.7 or more up to 1.0 for high similarity. Two or three or more levels of similarity may be used, and the parameter ranges may be set as desired.
Validity=√XY (Equation 21)
The motion vector correction unit 24 multiplies a motion vector by the calculated correction validity to correct the value of the motion vector, and uses the corrected motion vector as a final motion vector. The correction validity is set to a large value for high similarity. If the matching result is correct, the corresponding area is corrected greatly, whereas, if the matching result is wrong, the correction is minimized. The motion vectors are corrected accordingly.
The representative point correction unit 25 corrects representative points in accordance with the changed motion vectors.
In contrast, the representative point for the lower right block has high similarity and high luminance variance, and thus the matching result for this block is determined to be reliable. That is, the validity X is set to 1, and the validity Y is set to 1, resulting in the correction validity being equal to 1. Accordingly, the correction process based on the detected position of this block is performed. The representative point for the lower left block has sufficiently high similarity and intermediate luminance variance, and the correction validity is set to Y. Accordingly, correction using this block is performed by an amount corresponding to Y.
In
Accordingly, the corresponding area correction unit 559 finally determines representative points RP1 to RP4.
Next, another processing method performed by the corresponding area correction unit 559 is described with reference to
As illustrated in
As illustrated in
As illustrated in
As described above, the corresponding area correction unit 559 corrects the second area CA02 to generate a new second area CA2. Accordingly, finally, through the operation of superimposing images (see step S23) described below and the operation of displaying an image described below (step S24), images illustrated in
In contrast, after block matching and correction are performed, if the superimposition/combination location L2 in the peripheral area image PI is converted so that the superimposition/combination location L2 has the same shape as the planar image P by using motion vectors, as illustrated in
Referring back 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 P.
Although the planar image P is superimposed on the equirectangular projection image EC at a right location with the location parameter, these image EC and image P 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 P. 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 P. More specifically, the shape of the second area CA2 is made equal to the shape of the planar image P, such that each grid area LA2 in the second area CA2 illustrated in
The correction parameter generator 566 generates the correction parameter, which is to be applied to each grid area LA2′ in the second area CA2′, such that each grid area LA2′ is equal to the corresponding grid area LA0 in the planar image P in brightness and color. Specifically, the correction parameter generator 566 specifies four grid areas LA0 that share one common grid, and calculates an average avg=(Rave, Gave, Bave) of brightness and color values (R, G, B) of all pixels contained in the specified four grid areas LA0. Similarly, the correction parameter generator 566 specifies four grid areas LA2′ that share one common grid, and calculates an average avg′=(Rave, Gave, Bave) of brightness and color values (R, G, B) of all pixels contained in the specified four grid areas LA2′. If one gird of the specified grid areas LA0 and the corresponding grid of the specific grid areas LA2′ correspond to one of four vertices of the second area CA2 (or the third area CA3), the correction parameter generator 566 calculates the average avg and the average avg′ of the brightness and color of pixels from one grid area located at the corner. If one grid of the specific grid areas LA0 and the corresponding grid of the specific grid areas LA2′ correspond to a gird of the outline of the second area CA2 (or the third area CA3), the correction parameter generator 566 calculates the average avg and the average avg′ of the brightness and color of pixels from two grid areas inside the outline. In this embodiment, the correction parameter is gain data for correcting the brightness and color of the planar image P. Accordingly, the correction parameter Pa is obtained by dividing the avg′ by the avg, as represented by the following equation 14.
Pa=avg′/avg (Equation 14)
In displaying images being superimposed, each grid area LA0 is multiplied with the gain, represented by the correction parameter. Accordingly, the brightness and color of the planar image P is made substantially equal to that of the equirectangular projection image EC (spherical image CE). This prevents unnatural look, even when the planar image P is superimposed on the equirectangular projection image EC. In addition to or in alternative to the average value, the correction parameter may be calculated using the median or the most frequent value of brightness and color of pixels in the grid areas.
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 metadata generator 570 generates superimposed display metadata indicating a location where the planar image P is superimposed on the spherical image CE, and correction values for correcting brightness and color of pixels, using such as the location parameter and the correction parameter.
(Superimposed Display Metadata)
Referring to
As illustrated in
The equirectangular projection image information is transmitted from the special image capturing device 1, with the captured image data. The equirectangular projection image information includes an image identifier (image ID) and attribute data of the captured image data. The image identifier, included in the equirectangular projection image information, is used to identify the equirectangular projection image. While
The attribute data, included in the equirectangular projection image information, is any information related to the equirectangular projection image. In the case of metadata of
The planar image information is transmitted from the generic image capturing device 3 with the 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. While
The attribute data, included in the planar image information, is any information related to the planar image P. In the case of metadata of
The superimposed display information is generated by the smart phone 5. In this example, the superimposed display information includes area division number information, a coordinate of a grid in each grid area (location parameter), and correction values for brightness and color (correction parameter). The area division number information indicates a number of divisions of the first area CA1, both in the horizontal (longitude) direction and the vertical (latitude) direction. 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
Referring to
As described above, the first area CA1, which is a part of the equirectangular projection image EC, is converted to 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
Referring back to
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.
(Functional Configuration of Superimposing Unit)
Referring to
The superimposed area generator 582 specifies a part of the sphere CS, which corresponds to the third area CA3, 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 metadata, 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>
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.
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 superimposed display metadata, which is used to display an image where the planar image P is partly superimposed on the spherical image CE (S22). Here, the planar image P is a high-definition image, and the spherical image CE is a low-definition image. The storing and reading unit 59 stores the superimposed display metadata in the memory 5000.
Referring to
<Generation of Superimposed Display Metadata>
First, operation of generating the superimposed display metadata is described. The superimposed display metadata is used to display an image on the display 517, where the high-definition planar image P is superimposed on the spherical image CE. The spherical image CE is generated from the low-definition equirectangular projection image EC. As illustrated in
Referring to
Next, the first area calculator 552 calculates a rectangular, first area CA1 in the equirectangular projection image EC, which corresponds to the planar image P, based on similarity between the feature value fv1 of the feature 8 points fp1 in the equirectangular projection image EC, and the feature value fv2 of the feature points fp2 in the planar image P, using the homography (S120). More specifically, the first area calculator 552 calculates a rectangular, first area CA1 in the equirectangular projection image EC, which corresponds to the planar image P, based on similarity between the feature value fv1 of the feature points fp1 in the equirectangular projection image EC, and the feature value fv2 of the feature points fp2 in the planar image P, using the homography (S120). The above-described processing is performed to roughly estimate corresponding pixel (gird) positions between the planar image P and the equirectangular projection image EC that differ in projection.
Next, 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 P after the first homography transformation (S130).
The projection converter 556 extracts a peripheral area PA, which is a part surrounding the point of gaze GP1, from the equirectangular projection image EC. The projection converter 556 converts the peripheral area PA, from the equirectangular projection to the perspective projection, to generate a peripheral area image PI (S140).
The extractor 550 extracts a plurality of feature points fp3 from the peripheral area image PI, which is obtained by the projection converter 556 (S150).
Next, the second area calculator 558 calculates a rectangular, second area CA02 in the peripheral area image PT, which corresponds to the planar image P, based on similarity between the feature value fv2 of the feature points fp2 in the planar image P, and the feature value fv3 of the feature points fp3 in the peripheral area image PI using second homography (S160). In this example, the planar image P, which is a high-definition image of 40 million pixels, may be reduced in size.
Next, the corresponding area correction unit 559 corrects the second corresponding area CA02, which is calculated by the second area calculator 558, to generate a second corresponding area CA2.
Specifically, as illustrated in
Next, the motion vector calculation unit 23 calculates a motion vector from a representative point (such as a RP01) in the second corresponding area CA02, for each of corners (vertices) of the corresponding blocks in the peripheral area image PI that are matched by the matching unit 22 (S163, S263).
The motion vector correction unit 24 corrects the motion vector, as described above referring to
The representative point correction unit 25 corrects the representative points (such as RP01) to obtain the corrected representative points RP1, RP2, RP3, and RP4 (RP11, RP14, RP41, RP44), to generate the second corresponding area CA2 having the corrected representative points as four vertices of a rectangle (S165, S265).
Next, the area divider 560 divides the second area CA2 into a plurality of grid areas LA2 as illustrated in
As illustrated in
Referring to
After S180, the shape converter 564 converts the second area CA2 to have a shape that is the same as the shape of the planar image P. Specifically, the shape converter 564 maps four vertices of the second area CA2, illustrated in
As illustrated in
The correction parameter generator 566 generates the correction parameter, which is to be applied to each grid area LA2′ in the second area CA2′, such that each grid area LA2′ is equal to the corresponding grid area LA0 in the planar image P in brightness and color (S210).
As illustrated in
Then, the operation of generating the superimposed display metadata performed at S22 of
<Superimposition>
Referring to
The storing and reading unit 59 (obtainer) illustrated in
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 metadata, 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
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 in this embodiment, even when images that differ in projection are superimposed one above the other, the grid shift caused by the difference in projection can be compensated. For example, even when the planar image P in perspective projection is superimposed on the equirectangular projection image EC in equirectangular projection, these images are displayed with the same coordinate positions. More specifically, the special image capturing device 1 and the generic image capturing device 3 capture images using different projection methods. In such case, if the planar image P obtained by the generic image capturing device 3, is superimposed on the spherical image CE that is generated from the equirectangular projection image EC obtained by the special image capturing device, the planar image P does not fit in the spherical image CE as these images CE and P look different from each other. In view of this, as illustrated in
Further, the peripheral area image PI can be converted to have a substantially same shape as that of the planar image using the motion vector, through block matching and correcting. Accordingly, as illustrated in
Further, in this embodiment, the location parameter indicates positions where the superimposed image S is superimposed on the spherical image CE, using the third area CA3 including a plurality of grid areas. Accordingly, as illustrated in
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 metadata, 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 RANI 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 metadata, generated by the image and audio processing unit 75. With the superimposed display metadata, each grid area LA0 of the planar image P 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 metadata generator 75a that performs encoding, and a superimposing unit 75b that performs decoding. The metadata generator 75a performs processing of S44, which is processing to generate superimposed display metadata, as illustrated in
(Functional Configuration of Metadata Generator)
First, a functional configuration of the metadata generator 75a is described according to the embodiment. The metadata generator 75a includes an extractor 750, a first area calculator 752, a point of gaze specifier 754, a proj ection converter 756, a second area calculator 758, a corresponding area correction unit 759, an area divider 760, a projection reverse converter 762, a shape converter 764, a correction parameter generator 766, and a superimposed display metadata generator 770. These elements of the metadata generator 75a are substantially similar in function to the extractor 550, first area calculator 552, point of gaze specifier 554, projection converter 556, second area calculator 558, corresponding area correction unit, area divider 560, projection reverse converter 562, shape converter 564, correction parameter generator 566, and superimposed display metadata generator 570 of the metadata generator 55a, 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 that are different in projection, 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, 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 metadata 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. 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 metadata 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 superimposed display 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 metadata generator 75a illustrated in
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.
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-070486 | Mar 2018 | JP | national |
2019-046780 | Mar 2019 | JP | national |