IMAGE PROCESSING APPARATUS, IMAGE CAPTURING SYSTEM, IMAGE PROCESSING METHOD, AND RECORDING MEDIUM

Information

  • Patent Application
  • 20190306420
  • Publication Number
    20190306420
  • Date Filed
    March 25, 2019
    5 years ago
  • Date Published
    October 03, 2019
    5 years ago
Abstract
An information processing apparatus obtain a first image in first projection, and a second image in second projection; transforms projection of a first corresponding area of the first image to generate a third image in the second projection; identifies a plurality of feature points in the second image and the third image; determines a second corresponding area in the third image based on the plurality of feature points; 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 the third image; transforms projection of a plurality of points in the corrected corresponding area to obtain location information indicating locations of the plurality of points in the first image; and stores the location information in association with the plurality of points in the second image in the second projection.
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

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.


BACKGROUND
Technical Field

The present invention relates to an image processing apparatus, an image capturing system, an image processing method, and a recording medium.


Description of the Related Art

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.


SUMMARY

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.





BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS

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:



FIGS. 1A, 1B, 1C, and 1D (FIG. 1) are a left side view, a rear view, a plan view, and a bottom side view of a special image capturing device, according to an embodiment;



FIG. 2 is an illustration for explaining how a user uses the image capturing device, according to an embodiment;



FIGS. 3A, 3B, and 3C are views illustrating a front side of a hemispherical image, a back side of the hemispherical image, and an image in equirectangular projection, respectively, captured by the image capturing device, according to an embodiment;



FIG. 4A and FIG. 4B are views respectively illustrating the image in equirectangular projection covering a surface of a sphere, and a spherical image, according to an embodiment;



FIG. 5 is a view illustrating positions of a virtual camera and a predetermined area in a case in which the spherical image is represented as a three-dimensional solid sphere according to an embodiment;



FIGS. 6A and 6B are respectively a perspective view of FIG. 5, and a view illustrating an image of the predetermined area on a display, according to an embodiment;



FIG. 7 is a view illustrating a relation between predetermined-area information and a predetermined-area image according to an embodiment;



FIG. 8 is a schematic view illustrating an image capturing system according to a first embodiment;



FIG. 9 is a perspective view illustrating an adapter, according to the first embodiment;



FIG. 10 illustrates how a user uses the image capturing system, according to the first embodiment;



FIG. 11 is a schematic block diagram illustrating a hardware configuration of a special-purpose image capturing device according to the first embodiment;



FIG. 12 is a schematic block diagram illustrating a hardware configuration of a general-purpose image capturing device according to the first embodiment;



FIG. 13 is a schematic block diagram illustrating a hardware configuration of a smart phone, according to the first embodiment;



FIG. 14 is a functional block diagram of the image capturing system according to the first embodiment;



FIGS. 15A and 15B are conceptual diagrams respectively illustrating a linked image capturing device management table, and a linked image capturing device configuration screen, according to the first embodiment;



FIG. 16 is a block diagram illustrating a functional configuration of an image and audio processing unit according to the first embodiment;



FIG. 17 is a block diagram illustrating a functional configuration of a corresponding area correction unit, according to an embodiment;



FIG. 18 is an illustration of a data structure of superimposed display metadata according to the first embodiment;



FIGS. 19A and 19B are conceptual diagrams respectively illustrating a plurality of grid areas in a second area, and a plurality of grid areas in a third area, according to the first embodiment;



FIG. 20 is a data sequence diagram illustrating operation of capturing the image, performed by the image capturing system, according to the first embodiment;



FIG. 21 is a conceptual diagram illustrating operation of generating a superimposed display metadata, according to the first embodiment;



FIGS. 22A and 22B are conceptual diagrams for describing determination of a peripheral area image, according to the first embodiment;



FIG. 23 is a conceptual diagram illustrating processing performed by the corresponding area correction unit of FIG. 17, according to an embodiment;



FIG. 24 is an illustration for describing a concept of a motion vector, according to an embodiment;



FIG. 25A is a graph illustrating correspondences between validity based on similarity;



FIG. 25B is a graph illustrating correspondences between validity based on luminance variance;



FIG. 26 is a conceptual diagram illustrating processing to correct a representative point using a corrected motion vector;



FIG. 27 is a conceptual diagram illustrating processing performed by the corresponding area correction unit, according to another embodiment;



FIG. 28 is a diagram illustrating all representative points, which are obtained when the second corresponding area is divided in to a number of blocks equal to a number of blocks of the planar image, according to an embodiment;



FIG. 29 is an illustration for describing processing to correct a motion vector, according to an embodiment;



FIGS. 30A to 30C are conceptual diagrams illustrating processing to correct a motion vector, when an unshared point is corrected (FIG. 30A), when a shared point of two blocks is corrected (FIG. 30B), and when a shared point of four blocks is corrected (FIG. 30C), according to an embodiment;



FIGS. 31A to 31D are diagrams for describing effectiveness of block matching and correction processing, according to an embodiment;



FIGS. 32A and 32B are conceptual diagrams for explaining operation of dividing the second area into a plurality of grid areas, according to the first embodiment;



FIG. 33 is a conceptual diagram for explaining determination of the third area in the equirectangular projection image, according to the first embodiment;



FIGS. 34A, 34B, and 34C are conceptual diagrams illustrating operation of generating a correction parameter, according to the first embodiment;



FIG. 35 is a conceptual diagram illustrating operation of superimposing images, with images being processed or generated, according to the first embodiment;



FIG. 36 is a conceptual diagram illustrating a two-dimensional view of the spherical image superimposed with the planar image, according to the first embodiment;



FIG. 37 is a conceptual diagram illustrating a three-dimensional view of the spherical image superimposed with the planar image, according to the first embodiment;



FIGS. 38A and 38B are conceptual diagrams illustrating a two-dimensional view of a spherical image superimposed with a planar image, without using the location parameter, according to a comparative example;



FIGS. 39A and 39B are conceptual diagrams illustrating a two-dimensional view of the spherical image superimposed with the planar image, using the location parameter, in the first embodiment;



FIGS. 40A, 40B, 40C, and 40D are illustrations of a wide-angle image without superimposed display, a telephoto image without superimposed display, a wide-angle image with superimposed display, and a telephoto image with superimposed display, according to the first embodiment;



FIG. 41 is a schematic view illustrating an image capturing system according to a second embodiment;



FIG. 42 is a schematic diagram illustrating a hardware configuration of an image processing server according to the second embodiment;



FIG. 43 is a schematic block diagram illustrating a functional configuration of the image capturing system of FIG. 31 according to the second embodiment;



FIG. 44 is a block diagram illustrating a functional configuration of an image and audio processing unit according to the second embodiment; and



FIG. 45 is a data sequence diagram illustrating operation of capturing the image, performed by the image capturing system, according to the second embodiment.





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.


DETAILED DESCRIPTION

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 FIGS. 1 to 7, operation of generating a spherical image is described according to an embodiment.


First, referring to FIGS. 1A to 1D, an external view of a special-purpose (special) image capturing device 1, is described according to the embodiment. The special image capturing device 1 is a digital camera for capturing images from which a 360-degree spherical image is generated. FIGS. 1A to 1D are respectively a left side view, a rear view, a plan view, and a bottom view of the special image capturing device 1.


As illustrated in FIGS. 1A to 1D, the special image capturing device 1 has an upper part, which is provided with a fish-eye lens 102a on a front side (anterior side) thereof, and a fish-eye lens 102b on a back side (rear side) thereof. The special image capturing device 1 includes imaging elements (imaging sensors) 103a and 103b in its inside. The imaging elements 103a and 103b respectively capture images of an object or surroundings via the lenses 102a and 102b, to each obtain a hemispherical image (the image with an angle of view of 180 degrees or greater). As illustrated in FIG. 1B, the special image capturing device 1 further includes a shutter button 115a on a rear side of the special image capturing device 1, which is opposite of the front side of the special image capturing device 1. As illustrated in FIG. 1A, the left side of the special image capturing device 1 is provided with a power button 115b, a Wireless Fidelity (Wi-Fi) button 115c, and an image capturing mode button 115d. Any one of the power button 115b and the Wi-Fi button 115c switches between ON and OFF, according to selection (pressing) by the user. The image capturing mode button 115d switches between a still-image capturing mode and a moving image capturing mode, according to selection (pressing) by the user. The shutter button 115a, power button 115b, Wi-Fi button 115c, and image capturing mode button 115d are a part of an operation unit 115. The operation unit 115 is any section that receives a user instruction, and is not limited to the above-described buttons or switches.


As illustrated in FIG. 1D, the special image capturing device 1 is provided with a tripod mount hole 151 at a center of its bottom face 150. The tripod mount hole 151 receives a screw of a tripod, when the special image capturing device 1 is mounted on the tripod. In this embodiment, the tripod mount hole 151 is where the generic image capturing device 3 is attached via an adapter 9, described later referring to FIG. 9. The bottom face 150 of the special image capturing device 1 further includes a Micro Universal Serial Bus (Micro USB) terminal 152, on its left side. The bottom face 150 further includes a High-Definition Multimedia Interface (HDMI, Registered Trademark) terminal 153, on its right side.


Next, referring to FIG. 2, a description is given of a situation where the special image capturing device 1 is used. FIG. 2 illustrates an example of how the user uses the special image capturing device 1. As illustrated in FIG. 2, for example, the special image capturing device 1 is used for capturing objects surrounding the user who is holding the special image capturing device 1 in his or her hand. The imaging elements 103a and 103b illustrated in FIGS. 1A to 1D capture the objects surrounding the user to obtain two hemispherical images.


Next, referring to FIGS. 3A to 3C and FIGS. 4A and 4B, a description is given of an overview of an operation of generating an equirectangular projection image EC and a spherical image CE from the images captured by the special image capturing device 1. FIG. 3A is a view illustrating a hemispherical image (front side) captured by the special image capturing device 1. FIG. 3B is a view illustrating a hemispherical image (back side) captured by the special image capturing device 1. FIG. 3C is a view illustrating an image in equirectangular projection, which is referred to as an “equirectangular projection image” (or equidistant cylindrical projection image) EC. FIG. 4A is a conceptual diagram illustrating an example of how the equirectangular projection image maps to a surface of a sphere. FIG. 4B is a view illustrating the spherical image.


As illustrated in FIG. 3A, an image captured by the imaging element 103a is a curved hemispherical image (front side) taken through the fish-eye lens 102a. Also, as illustrated in FIG. 3B, an image captured by the imaging element 103b is a curved hemispherical image (back side) taken through the fish-eye lens 102b. The hemispherical image (front side) and the hemispherical image (back side), which are reversed by 180-degree from each other, are combined by the special image capturing device 1. This results in generation of the equirectangular projection image EC as illustrated in FIG. 3C.


The equirectangular projection image is mapped on the sphere surface using Open Graphics Library for Embedded Systems (OpenGL ES) as illustrated in FIG. 4A. This results in generation of the spherical image CE as illustrated in FIG. 4B. In other words, the spherical image CE is represented as the equirectangular projection image EC, which corresponds to a surface facing a center of the sphere CS. It should be noted that OpenGL ES is a graphic library used for visualizing two-dimensional (2D) and three-dimensional (3D) data. The spherical image CE is either a still image or a moving image.


Since the spherical image CE is an image attached to the sphere surface, as illustrated in FIG. 4B, a part of the image may look distorted when viewed from the user, providing a feeling of strangeness. To resolve this strange feeling, an image of a predetermined area, which is a part of the spherical image CE, is displayed as a flat image having fewer curves. The predetermined area is, for example, a part of the spherical image CE that is viewable by the user. In this disclosure, the image of the predetermined area is referred to as a “predetermined-area image” Q. Hereinafter, a description is given of displaying the predetermined-area image Q with reference to FIG. 5 and FIGS. 6A and 6B.



FIG. 5 is a view illustrating positions of a virtual camera IC and a predetermined area T in a case in which the spherical image is represented as a surface area of a three-dimensional solid sphere. The virtual camera IC corresponds to a position of a point of view (viewpoint) of a user who is viewing the spherical image CE represented as a surface area of the three-dimensional solid sphere CS. FIG. 6A is a perspective view of the spherical image CE illustrated in FIG. 5. FIG. 6B is a view illustrating the predetermined-area image Q when displayed on a display. In FIG. 6A, the spherical image CE illustrated in FIG. 4B is represented as a surface area of the three-dimensional solid sphere CS. Assuming that the spherical image CE is a surface area of the solid sphere CS, the virtual camera IC is inside of the spherical image CE as illustrated in FIG. 5. The predetermined area T in the spherical image CE is an imaging area of the virtual camera IC. Specifically, the predetermined area T is specified by predetermined-area information indicating an imaging direction and an angle of view of the virtual camera IC in a three-dimensional virtual space containing the spherical image CE.


The predetermined-area image Q, which is an image of the predetermined area T illustrated in FIG. 6A, is displayed on a display as an image of an imaging area of the virtual camera IC, as illustrated in FIG. 6B. FIG. 6B illustrates the predetermined-area image Q represented by the predetermined-area information that is set by default. The following explains the position of the virtual camera IC, using an imaging direction (ea, aa) and an angle of view α of the virtual camera IC.


Referring to FIG. 7, a relation between the predetermined-area information and the image of the predetermined area T is described according to the embodiment. FIG. 7 is a view illustrating a relation between the predetermined-area information and the image of the predetermined area T. As illustrated in FIG. 7, “ea” denotes an elevation angle, “aa” denotes an azimuth angle, and “a” denotes an angle of view, respectively, of the virtual camera IC. The position of the virtual camera IC is adjusted, such that the point of gaze of the virtual camera IC, indicated by the imaging direction (ea, aa), matches the central point CP of the predetermined area T as the imaging area of the virtual camera IC. The predetermined-area image Q is an image of the predetermined area T, in the spherical image CE. “f” denotes a distance from the virtual camera IC to the central point CP of the predetermined area T. “L” denotes a distance between the central point CP and a given vertex of the predetermined area T (2L is a diagonal line). In FIG. 7, a trigonometric function equation generally expressed by the following Equation 1 is satisfied.






L/f=tan(α/2)  (Equation 1)


First Embodiment

Referring to FIGS. 8 to 30D, the image capturing system according to a first embodiment of the present invention is described.


<Overview of Image Capturing System>


First, referring to FIG. 8, an overview of the image capturing system is described according to the first embodiment. FIG. 8 is a schematic diagram illustrating a configuration of the image capturing system according to the embodiment.


As illustrated in FIG. 8, the image capturing system includes the special image capturing device 1, a general-purpose (generic) capturing device 3, a smart phone 5, and an adapter 9. The special image capturing device 1 is connected to the generic image capturing device 3 via the adapter 9.


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 FIGS. 1 to 7.


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.



FIG. 9 is a perspective view illustrating the adapter 9 according to the embodiment. As illustrated in FIG. 9, the adapter 9 includes a shoe adapter 901, a bolt 902, an upper adjuster 903, and a lower adjuster 904. The shoe adapter 901 is attached to an accessory shoe of the generic image capturing device 3 as it slides. The bolt 902 is provided at a center of the shoe adapter 901, which is to be screwed into the tripod mount hole 151 of the special image capturing device 1. The bolt 902 is provided with the upper adjuster 903 and the lower adjuster 904, each of which is rotatable around the central axis of the bolt 902. The upper adjuster 903 secures the object attached with the bolt 902 (such as the special image capturing device 1). The lower adjuster 904 secures the object attached with the shoe adapter 901 (such as the generic image capturing device 3).



FIG. 10 illustrates how a user uses the image capturing device, according to the embodiment. As illustrated in FIG. 10, the user puts his or her smart phone 5 into his or her pocket. The user captures an image of an object using the generic image capturing device 3 to which the special image capturing device 1 is attached by the adapter 9. While the smart phone 5 is placed in the pocket of the user's shirt, the smart phone 5 may be placed in any area as long as it is wirelessly communicable with the special image capturing device 1 and the generic image capturing device 3.


Hardware Configuration


Next, referring to FIGS. 11 to 13, hardware configurations of the special image capturing device 1, generic image capturing device 3, and smart phone 5 are described according to the embodiment.


<Hardware Configuration of Special Image Capturing Device>


First, referring to FIG. 11, a hardware configuration of the special image capturing device 1 is described according to the embodiment. FIG. 11 illustrates the hardware configuration of the special image capturing device 1. The following describes a case in which the special image capturing device 1 is a spherical (omnidirectional) image capturing device having two imaging elements. However, the special image capturing device 1 may include any suitable number of imaging elements, providing that it includes at least two imaging elements. In addition, the special image capturing device 1 is not necessarily an image capturing device dedicated to omnidirectional image capturing. Alternatively, an external omnidirectional image capturing unit may be attached to a general-purpose digital camera or a smartphone to implement an image capturing device having substantially the same function as that of the special image capturing device 1.


As illustrated in FIG. 11, the special image capturing device 1 includes an imaging unit 101, an image processor 104, an imaging controller 105, a microphone 108, an audio processor 109, a central processing unit (CPU) 111, a read only memory (ROM) 112, a static random access memory (SRAM) 113, a dynamic random access memory (DRAM) 114, the operation unit 115, a network interface (I/F) 116, a communication circuit 117, an antenna 117a, an electronic compass 118, a gyro sensor 119, an acceleration sensor 120, and a Micro USB terminal 121.


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 FIG. 3C.


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 FIG. 12, a hardware configuration of the generic image capturing device 3 is described according to the embodiment. FIG. 12 illustrates the hardware configuration of the generic image capturing device 3. As illustrated in FIG. 12, the generic image capturing device 3 includes an imaging unit 301, an image processor 304, an imaging controller 305, a microphone 308, an audio processor 309, a bus 310, a CPU 311, a ROM 312, a SRAM 313, a DRAM 314, an operation unit 315, a network I/F 316, a communication circuit 317, an antenna 317a, an electronic compass 318, and a display 319. The image processor 304 and the imaging controller 305 are each connected to the CPU 311 via the bus 310.


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 FIG. 12, in the imaging unit 301 of the generic image capturing device 3, a lens unit 306 having a plurality of lenses, a mechanical shutter button 307, and the imaging element 303 are disposed in this order from a side facing the outside (that is, a side to face the object to be captured).


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 FIG. 13, a hardware configuration of the smart phone 5 is described according to the embodiment. FIG. 13 illustrates the hardware configuration of the smart phone 5. As illustrated in FIG. 13, the smart phone 5 includes a CPU 501, a ROM 502, a RAM 503, an EEPROM 504, a Complementary Metal Oxide Semiconductor (CMOS) sensor 505, an imaging element I/F 513a, an acceleration and orientation sensor 506, a medium I/F 508, and a GPS receiver 509.


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 FIGS. 11 to 14, a functional configuration of the image capturing system is described according to the embodiment. FIG. 14 is a schematic block diagram illustrating functional configurations of the special image capturing device 1, generic image capturing device 3, and smart phone 5, in the image capturing system, according to the embodiment.


<Functional Configuration of Special Image Capturing Device>


Referring to FIGS. 11 and 14, a functional configuration of the special image capturing device 1 is described according to the embodiment. As illustrated in FIG. 14, the special image capturing device 1 includes an acceptance unit 12, an image capturing unit 13, an audio collection unit 14, an image and audio processing unit 15, a determiner 17, a short-range communication unit 18, and a storing and reading unit 19. These units are functions that are implemented by or that are caused to function by operating any of the elements illustrated in FIG. 11 in cooperation with the instructions of the CPU 111 according to the special image capturing device control program expanded from the SRAM 113 to the DRAM 114.


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 FIG. 11.


Still referring to FIGS. 11 and 14, each functional unit of the special image capturing device 1 is described according to the embodiment.


The acceptance unit 12 of the special image capturing device 1 is implemented by the operation unit 115 illustrated in FIG. 11, which operates under control of the CPU 111. The acceptance unit 12 receives an instruction input from the operation unit 115 according to a user operation.


The image capturing unit 13 is implemented by the imaging unit 101, the image processor 104, and the imaging controller 105, illustrated in FIG. 11, each operating under control of the CPU 111. The image capturing unit 13 captures an image of the object or surroundings to obtain captured image data. As the captured image data, the two hemispherical images, from which the spherical image is generated, are obtained as illustrated in FIGS. 3A and 3B.


The audio collection unit 14 is implemented by the microphone 108 and the audio processor 109 illustrated in FIG. 11, each of which operates under control of the CPU 111. The audio collection unit 14 collects sounds around the special image capturing device 1.


The image and audio processing unit 15 is implemented by the instructions of the CPU 111, illustrated in FIG. 11. The image and audio processing unit 15 applies image processing to the captured image data obtained by the image capturing unit 13. The image and audio processing unit 15 applies audio processing to audio obtained by the audio collection unit 14. For example, the image and audio processing unit 15 generates data of the equirectangular projection image (FIG. 3C), using two hemispherical images (FIGS. 3A and 3B) respectively obtained by the imaging elements 103a and 103b.


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 FIG. 11, stores various data or information in the memory 1000 or reads out various data or information from the memory 1000.


<Functional Configuration of Generic Image Capturing Device>


Next, referring to FIGS. 12 and 14, a functional configuration of the generic image capturing device 3 is described according to the embodiment. As illustrated in FIG. 14, the generic image capturing device 3 includes an acceptance unit 32, an image capturing unit 33, an audio collection unit 34, an image and audio processing unit 35, a display control 36, a determiner 37, a short-range communication unit 38, and a storing and reading unit 39. These units are functions that are implemented by or that are caused to function by operating any of the elements illustrated in FIG. 12 in cooperation with the instructions of the CPU 311 according to the image capturing device control program expanded from the SRAM 313 to the DRAM 314.


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 FIG. 12.


The acceptance unit 32 of the generic image capturing device 3 is implemented by the operation unit 315 illustrated in FIG. 12, which operates under control of the CPU 311. The acceptance unit 32 receives an instruction input from the operation unit 315 according to a user operation.


The image capturing unit 33 is implemented by the imaging unit 301, the image processor 304, and the imaging controller 305, illustrated in FIG. 12, each of which operates under control of the CPU 311. The image capturing unit 13 captures an image of the object or surroundings to obtain captured image data. In this example, the captured image data is planar image data, captured with a perspective projection method.


The audio collection unit 34 is implemented by the microphone 308 and the audio processor 309 illustrated in FIG. 12, each of which operates under control of the CPU 311. The audio collection unit 34 collects sounds around the generic image capturing device 3.


The image and audio processing unit 35 is implemented by the instructions of the CPU 311, illustrated in FIG. 12. The image and audio processing unit 35 applies image processing to the captured image data obtained by the image capturing unit 33. The image and audio processing unit 35 applies audio processing to audio obtained by the audio collection unit 34. The di splay control 36, which is implemented by the instructions of the CPU 311 illustrated in FIG. 12, controls the display 319 to display a planar image P based on the captured image data that is being captured or that has been captured.


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 FIG. 12, stores various data or information in the memory 3000 or reads out various data or information from the memory 3000.


<Functional Configuration of Smart Phone>


Referring now to FIGS. 13 to 16, a functional configuration of the smart phone 5 is described according to the embodiment. As illustrated in FIG. 14, the smart phone 5 includes a long-range communication unit 51, an acceptance unit 52, an image capturing unit 53, an audio collection unit 54, an image and audio processing unit 55, a display control 56, a determiner 57, the short-range communication unit 58, and a storing and reading unit 59. These units are functions that are implemented by or that are caused to function by operating any of the hardware elements illustrated in FIG. 13 in cooperation with the instructions of the CPU 501 according to the control program for the smart phone 5, expanded from the EEPROM 504 to the RAM 503.


The smart phone 5 further includes a memory 5000, which is implemented by the ROM 502, RAM 503 and EEPROM 504 illustrated in FIG. 13. The memory 5000 stores a linked image capturing device management DB 5001. The linked image capturing device management DB 5001 is implemented by a linked image capturing device management table illustrated in FIG. 15A. FIG. 15A is a conceptual diagram illustrating the linked image capturing device management table, according to the embodiment.


Referring now to FIG. 15A, the linked image capturing device management table is described according to the embodiment. As illustrated in FIG. 15A, the linked image capturing device management table stores, for each image capturing device, linking information indicating a relation to the linked image capturing device, an IP address of the image capturing device, and a device name of the image capturing device, in association with one another. The linking information indicates whether the image capturing device is “main” device or “sub” device in performing the linking function. The image capturing device as the “main” device, starts capturing the image in response to pressing of the shutter button provided for that device. The image capturing device as the “sub” device, starts capturing the image in response to pressing of the shutter button provided for the “main” device. The IP address is one example of destination information of the image capturing device. The IP address is used in case the image capturing device communicates using Wi-Fi. Alternatively, a manufacturer's identification (ID) or a product ID may be used in case the image capturing device communicates using a wired USB cable. Alternatively, a Bluetooth Device (BD) address is used in case the image capturing device communicates using wireless communication such as Bluetooth.


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 FIG. 13, to transmit or receive various data or information to or from other device (for example, other smart phone or server) through a communication network such as the Internet.


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 FIG. 13, the display 517 and the touch panel 521 may be integrated as one device. Further, the smart phone 5 may include any hardware key, such as a button, to receive the user instruction, in addition to the touch panel 521.


The image capturing unit 53 is implemented by the CMOS sensors 505 and 512, which operate under control of the CPU 501, illustrated in FIG. 13. The image capturing unit 13 captures an image of the object or surroundings to obtain captured image data.


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 FIG. 13. The image and audio processing unit 55 applies image processing to an image of the object that has been captured by the image capturing unit 53. The image and audio processing unit 15 applies audio processing to audio obtained by the audio collection unit 54.


The display control 56, which is implemented by the instructions of the CPU 501 illustrated in FIG. 13, controls the display 517 to display the planar image P based on the captured image data that is being captured or that has been captured by the image capturing unit 53. The display control 56 superimposes the planar image P, on the spherical image CE, using superimposed display metadata, generated by the image and audio processing unit 55. 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.


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 FIG. 13, to perform various determinations.


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 FIG. 13, stores various data or information in the memory 5000 or reads out various data or information from the memory 5000. For example, the superimposed display metadata may be stored in the memory 5000. In this embodiment, the storing and reading unit 59 functions as an obtainer that obtains various data from the memory 5000.


Referring to FIG. 16, a functional configuration of the image and audio processing unit 55 is described according to the embodiment. FIG. 16 is a block diagram illustrating the functional configuration of the image and audio processing unit 55 according to the embodiment.


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 FIG. 20. The superimposing unit 55b performs processing of S23, which is processing to superimpose the images using the superimposed display metadata, as illustrated in FIG. 20.


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. FIG. 21 is a conceptual diagram illustrating operation of generating the superimposed display metadata, with images processed or generated in such operation.


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 FIG. 20, the extractor 550 extracts feature points from the rectangular, equirectangular projection image EC in equirectangular projection (S110), and the rectangular, planar image P in perspective projection (S110), based on local features of each of these images including the same object. Further, the extractor 550 extracts feature points from the rectangular, planar image P (S110), and a peripheral area image PI converted by the projection converter 556 (S150), based on local features of each of these images having the same object. In this embodiment, the equirectangular projection method is one example of a first projection method, and the perspective projection method is one example of a second projection method. The equirectangular projection image is one example of the first projection image, and the planar image P is one example of the second projection image.


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 FIG. 21, the central point CP1 may be calculated using the equation 2 with an intersection of diagonal lines of the planar image P, even when the planar image P is a square, trapezoid, or rhombus. When the planar image P has a shape of rectangle or square, the central point of the diagonal line may be set as the central point CP1. In such case, the central points of the diagonal lines of the vertices p1 and p3 are calculated, respectively, using the equation 3 below.






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 FIG. 20, in detail. As described above referring to FIGS. 3 to 5, the equirectangular projection image EC covers a surface of the sphere CS, to generate the spherical image CE. Therefore, each pixel in the equirectangular projection image EC corresponds to each pixel in the surface of the sphere CS, that is, the three-dimensional, spherical image. The projection converter 556 applies the following transformation equation. Here, the coordinate system used for the equirectangular projection image EC is expressed with (latitude, longitude)=(ea, aa), and the rectangular coordinate system used for the three-dimensional sphere CS is expressed with (x, y, z).





(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 FIGS. 22A and 22B, determination of a peripheral area image P1 is described according to the embodiment. FIGS. 22A and 22B are conceptual diagrams for describing determination of the peripheral area image PI.


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 FIG. 22B is a rectangle, circumscribed around a circle containing the diagonal angle of view α of the planar image P illustrated in FIG. 22A. The vertical angle of view α is calculated from the diagonal angle of a square and the focal length of the planar image P, using Equations 11 and 12.





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 FIGS. 16 and 21, the second area calculator 558 calculates the feature value fv2 of a plurality of feature points fp2 in the planar image P, and the feature value fv3 of a plurality of feature points fp3 in the peripheral area image PI. The second area calculator 558 specifies corresponding points between the images, based on similarity between the feature value fv2 and the feature value fv3. Based on the corresponding points between the images, the second area calculator 558 calculates the homography for transformation between the planar image P and the peripheral area image PI. The second area calculator 558 then applies second homography transformation to the planar image P (S160). Accordingly, the second area calculator 558 obtains a second (corresponding) area CA02 (“second area CA02”), in the peripheral area image PI, which corresponds to the planar image P (S170).


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 FIGS. 17 and 23 to 31D. FIG. 17 illustrates the details of the corresponding area correction unit 559.


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.



FIG. 23 is a conceptual diagram illustrating processing performed by the corresponding area correction unit 559. The dividing unit 21 divides the planar image P into a plurality of blocks. In this example, the planar image P is divided into nine blocks. However, the planar image P may be divided into any number of blocks. Two or more blocks may be used here although the number of blocks depends on the size or characteristics of an image. For example, four through sixteen blocks may be suitable for search and may facilitate block matching.


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 FIG. 23, the position of the second area CA02 in the peripheral area image PI is to be corrected since the positions of actual corresponding blocks, which are calculated by the matching unit 22, are different.


The motion vector calculation unit 23 calculates a motion vector for correcting the position of each block. FIG. 24 illustrates the concept of motion vectors. As illustrated in FIG. 24, first, a plurality of representative points RP01 to RP04 for determining motion vectors are set in advance. The representative points according to this embodiment are described below.


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 FIG. 24 may be simplified, the respective blocks may have different motion vectors. Alternatively, the respective blocks may have the same motion vector. While four representative points are selected as initial positions, four or more representative points may be selected, as described below.


The offsets from the representative points RP01 to RP04 of the second area CA02 to corners of the blocks illustrated in FIG. 24, which are closest to the four vertices of the peripheral area image P1, corresponds to motion vectors MV01 to MV04. Corresponding blocks are not necessarily accurately matched. In FIG. 24, in a region including no object, such as the sky region, matching is not likely to be performed accurately. For this reason, it is undesirable to move the representative points RP01 to RP04 in accordance with the motion vectors MV01 to MV04.


Accordingly, the motion vector correction unit 24 corrects a motion vector. FIGS. 25A and 25B illustrate a correction process based on similarity and luminance variance. FIG. 25A illustrates validity X based on similarity, and FIG. 25B illustrates validity Y based on luminance variance.


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.









V
=


1
n






n
=
1

n




(


x
i

-

x
_


)

2







(

Equation





20

)







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. FIG. 26 illustrates a concept of a process for correcting representative points by using corrected motion vectors. The upper left block and the upper right block have high similarity but low luminance variance and are thus determined to present an image having a few feature points. The reliability of the matching result for these blocks is low. That is, the validity Y is set to 0, resulting in the correction validity being equal to 0. No correction is performed. Accordingly, the motion vectors have values close to 0, and the positions determined by the second area calculator 558 are used substantially as is.


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 FIG. 26, switching the validity of blocks near the four vertices is illustrated by way of example. Alternatively, all the blocks may be used.


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 FIGS. 27 to 30C. FIG. 27 is a conceptual diagram illustrating another process performed by the corresponding area correction unit 559. In FIG. 23, the four representative points RP01 to RP04 for four blocks in the peripheral area image PI are illustrated. In FIG. 27, 16 representative points RP011 to RP044 for all the blocks obtained as a result of division (here, nine blocks) are illustrated.



FIG. 28 illustrates all the representative points, which are obtained when the second area CA02 is divided into a number of blocks equal to the number of blocks of the planar image P. FIGS. 29 and 30A to 30C illustrate a concept of correction of motion vectors in the example illustrated in FIG. 28. FIGS. 30A to 30C illustrate a concept of correction of motion vectors. FIG. 30A is a conceptual diagram of a correction position at an unshared point, FIG. 30B is a conceptual diagram of a correction position at a shared point for two blocks, and FIG. 30C is a conceptual diagram of a correction position at a shared point for four blocks.


As illustrated in FIGS. 29 and 30A, the second area CA02 is divided into blocks and representative points at the four vertices of the second area CA02 are located in the blocks located at the four vertices of the second area CA02. A point BP11 is indicated by a motion vector MV011 from the representative point RP011, and a corrected motion vector MV11 is determined for the point BP11. In this case, the motion vector MV011 and the corrected motion vector MV11 are equal.


As illustrated in FIGS. 29 and 30B, in the case of a representative point on the four side of the second area CA02 (except for the representative points at the four vertices of the second area CA02), for example, a corrected vector MV21 is determined for a center-of-gravity point G1 (BP21) of points BP12 and BP21, respectively indicated by motion vectors MV012 and MV021 from the representative point RP021.


As illustrated in FIGS. 29 and 30C, in the case of a representative point other than representative points on the four side of the second area CA02, for example, a corrected vector MV22 is determined for a center-of-gravity point G2 of points BP14, BP23, BP42, and BP51 indicated by motion vectors MV014, MV023, MV042, and MV051 from the representative point RP022.


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 FIGS. 31A to 31D are displayed. FIGS. 31A to 31D illustrate superimposition/combination locations before and after correction when block matching and the determination of validity of correction are performed.



FIG. 31A illustrates a superimposition/combination location L1 before correction using block matching and a superimposition/combination location L2 after correction using block matching. The region on the left-hand side of FIG. 31A is the blue sky region having very few feature points. The matching results without correction are affected by the blue sky region, and an incorrect area may be detected as the superimposition/combination location L1. If the superimposition/combination location L1 in the peripheral area image PI is converted so that the superimposition/combination location L1 has the same shape as the planar image P by using motion vectors, as illustrated in FIG. 31B, the object of interest (in the illustrated example, a light) is not located at the center of the screen, and the image is largely skewed, compared to the planar image P illustrated in FIG. 31D. FIG. 31D illustrates the planar image P taken using the generic image capturing device 3.


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 FIG. 31C, the object of interest is located at the center of the screen. The image illustrated in FIG. 31C appears similar to the image illustrated in FIG. 31D. In the image illustrated in FIG. 31C, the effects of the region having a few feature points are compensated for by block matching. Accordingly, block matching and correction based on validity determination may improve a result of matching between images with large parallax and also improve a result of matching between images having a few feature points.


Referring back to FIG. 16, the area divider 560 divides a part of the image into a plurality of grid areas. Referring to FIGS. 32A and 32B, operation of dividing the second area CA2 into a plurality of grid areas is described according to the embodiment. FIGS. 32A and 32B illustrate conceptual diagrams for explaining operation of dividing the second area into a plurality of grid areas, according to the embodiment.


As illustrated in FIG. 32A, the second area CA2 is a rectangle defined by four vertices each obtained with the second homography transformation, by the second area calculator 558. As illustrated in FIG. 32B, the area divider 560 divides the second area CA2 into a plurality of grid areas LA2. For example, the second area CA2 is equally divided into 30 grid areas in the horizontal direction, and into 20 grid areas in the vertical direction.


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. FIG. 32B shows an example case of the coordinate (LO00,00, LA00,00) of the upper left point TL.


Referring back to FIGS. 16 and 21, the projection reverse converter 562 reversely converts projection applied to the second area CA2, back to the equirectangular projection applied to the equirectangular projection image EC. With this projection transformation, the third area CA3 in the equirectangular projection image EC, which corresponds to the second area CA2, is determined. Specifically, the projection reverse converter 562 determines the third area CA3 in the equirectangular projection image EC, which contains a plurality of grid areas LA3 corresponding to the plurality of grid areas LA2 in the second area CA2. FIG. 33 illustrates an enlarged view of the third area CA3 illustrated in FIG. 21. FIG. 33 is a conceptual diagram for explaining determination of the third area CA3 in the equirectangular projection image EC. The planar image P is superimposed on the spherical image CE, which is generated from the equirectangular projection image EC, so as to fit in a portion defined by the third area CA3 by mapping. Through processing by the projection reverse converter 562, a location parameter is generated, which indicates the coordinate of each grid in each grid area LA3. The location parameter is illustrated in FIG. 18 and FIG. 19B. In this example, the gird may be referred to as a single point of a plurality of points.


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 FIG. 34A, is located at the same position of each grid area LA0 in the planar image P illustrated in FIG. 34C. That is, a shape of the second area CA2 illustrated in FIG. 34A is converted to a shape of the second area CA2′ illustrated in FIG. 34B. As each grid area LA2 is converted to the corresponding grid area LA2′, the grid area LA2′ becomes equal in shape to the corresponding grid area LA0 in the planar image P.


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.










(



Y




Cb




Cr



)

=



(



0.299


0.587


0.114





-
0.1687




-
0.3313



0.5




0.5



-
0.4187




-
0.0813




)



(



R




G




B



)


+

(



0




128




128



)






(

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 FIG. 18, a data structure of the superimposed display metadata is described according to the embodiment. FIG. 18 illustrates a data structure of the superimposed display metadata according to the embodiment.


As illustrated in FIG. 18, the superimposed display metadata includes equirectangular projection image information, planar image information, superimposed display information, and metadata generation information.


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 FIG. 18 uses an image file name as an example of image identifier, an image ID for uniquely identifying the image may be used instead.


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 FIG. 18, the attribute data includes positioning correction data (Pitch, Yaw, Roll) of the equirectangular projection image, which is obtained by the special image capturing device 1 in capturing the image. The positioning correction data is stored in compliance with a standard image recording format, such as Exchangeable image file format (Exif). Alternatively, the positioning correction data may be stored in any desired format defined by Google Photo Sphere schema (GPano). As long as an image is taken at the same place, the special image capturing device 1 captures the image in 360 degrees with any positioning. However, in displaying such spherical image CE, the positioning information and the center of image (point of gaze) should be specified. Generally, the spherical image CE is corrected for display, such that its zenith is right above the user capturing the image. With this correction, a horizontal line is displayed as a straight line, thus the displayed image have more natural look.


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 FIG. 18 uses an image file name as an example of image identifier, an image ID for uniquely identifying the image may be used instead.


The attribute data, included in the planar image information, is any information related to the planar image P. In the case of metadata of FIG. 18, the planar image information includes, as attribute data, a value of 35 mm equivalent focal length. The value of 35 mm equivalent focal length is not necessary to display the image on which the planar image P is superimposed on the spherical image CE. However, the value of 35 mm equivalent focal length may be referred to determine an angle of view when displaying superimposed images.


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 FIG. 21.


Referring to FIGS. 19A and 19B, the location parameter and the correction parameter are described in detail, according to the embodiment. FIG. 19A is a conceptual diagram illustrating a plurality of grid areas in the second area CA2, according to the embodiment. FIG. 19B is a conceptual diagram illustrating a plurality of grid areas in the third area CA3, according to the embodiment.


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 FIG. 19A, the second area CA2 is divided into 30 grid areas in the horizontal direction, and 20 grid areas in the vertical direction, resulting in 600 grid areas in total. Still referring to FIG. 19A, the coordinate of each grid in each grid area can be expressed by (LO00,00, LA00,00), (LO01,00, LA01,00), . . . , (LO30,20, LA30,20. The correction value of brightness and color of each grid in each grid area can be expressed by (R00,00, G00,00, B00,00), (R01,00, G01,00, B01,00), . . . , (R30,20, G30,20, B30,20). For simplicity, in FIG. 18A, only four vertices (grids) are each shown with the coordinate value, and the correction value for brightness and color. However, the coordinate value and the correction value for brightness and color, are assigned to each of all girds. The correction values R, G, B for brightness and color, corresponds to correction gains for red, green, and blue, respectively. In this example, the correction values R, G, B for brightness and color, are generated for a predetermined area centering on a specific grid. The specific grid is selected, such that the predetermined area of such grid does not overlap with a predetermined area of an adjacent specific gird.


As illustrated in FIG. 19B, the second area CA2 is reverse converted to the third area CA3 in equirectangular projection, which is the same projection with the projection of the equirectangular projection image EC. In this embodiment, the third area CA3 is equally divided into 30 grid areas in the horizontal direction, and 20 grid areas in the vertical direction, resulting in 600 grid areas in total. Referring to FIG. 18B, the coordinate of each grid in each area can be expressed by (LO′00,00, LA′00,00), (LO′01,00, LA′01,00), . . . , (LO′30,20 LA′30.20). The correction values of brightness and color of each grid in each grid area are the same as the correction values of brightness and color of each grid in each grid area in the second area CA2. For simplicity, in FIG. 19B, only four vertices (grids) are each shown with the coordinate value, and the correction value for brightness and color. However, the coordinate value and the correction value for brightness and color, are assigned to each of all girds.


Referring back to FIG. 18, the metadata generation information includes version information indicating a version of the superimposed display metadata.


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 FIG. 16, a functional configuration of the superimposing unit 55b is described according to the embodiment. The superimposing unit 55b includes a superimposed area generator 582, a correction unit 584, an image generator 586, an image superimposing unit 588, and a projection converter 590.


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 FIG. 7, the projection converter 590 converts projection, such that the predetermined area T of the spherical image CE, with the superimposed image S being superimposed, is displayed on the display 517, for example, in response to a user instruction for display. The projection transformation is performed based on the line of sight of the user (the direction of the virtual camera IC, represented by the central point CP of the predetermined area T), and the angle of view α of the predetermined area T. In projection transformation, the projection converter 590 converts a resolution of the predetermined area T, to match with a resolution of a display area of the display 517. Specifically, when the resolution of the predetermined area T is less than the resolution of the display area of the display 517, the projection converter 590 enlarges a size of the predetermined area T to match the display area of the display 517. In contrary, when the resolution of the predetermined area T is greater than the resolution of the display area of the display 517, the projection converter 590 reduces a size of the predetermined area T to match the display area of the display 517. Accordingly, the display control 56 displays the predetermined-area image Q, that is, the image of the predetermined area T, in the entire display area of the display 517.


<Operation>


Referring now to FIGS. 20 to 40, operation of capturing the image and displaying the image, performed by the image capturing system, is described according to the embodiment. First, referring to FIG. 20, operation of capturing the image, performed by the image capturing system, is described according to the embodiment. FIG. 20 is a data sequence diagram illustrating operation of capturing the image, according to the embodiment. The following describes the example case in which the object and surroundings of the object are captured. However, in addition to capturing the object, audio may be recorded by the audio collection unit 14 as the captured image is being generated.


As illustrated in FIG. 20, the acceptance unit 52 of the smart phone 5 accepts a user instruction to start linked image capturing (S11). In response to the user instruction to start linked image capturing, the display control 56 controls the display 517 to display a linked image capturing device configuration screen as illustrated in FIG. 15B. The screen of FIG. 15B includes, for each image capturing device available for use, a radio button to be selected when the image capturing device is selected as a main device, and a check box to be selected when the image capturing device is selected as a sub device. The screen of FIG. 15B further displays, for each image capturing device available for use, a device name and a received signal intensity level of the image capturing device. Assuming that the user selects one image capturing device as a main device, and other image capturing device as a sub device, and presses the “Confirm” key, the acceptance unit 52 of the smart phone 5 accepts the instruction for starting linked image capturing. In this example, more than one image capturing device may be selected as the sub device. For this reasons, more than one check boxes may be selected.


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 FIGS. 3A and 3B. The image and audio processing unit 15 then generates one equirectangular projection image as illustrated in FIG. 3C, based on these two hemispherical images. The storing and reading unit 19 stores data of the equirectangular projection image in the memory 1000.


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 FIG. 18. The short-range communication unit 58 of the smart phone 5 receives the planar image data, the image identifier, and the attribute data.


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 FIG. 17, the image identifier and the attribute data are a part of the equirectangular projection image information. The short-range communication unit 58 of the smart phone 5 receives the equirectangular projection image data, the image identifier, and the attribute data.


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 FIGS. 21 to 34, operation of generating superimposed display metadata is described in detail, according to the embodiment. Even when the generic image capturing device 3 and the special image capturing device 1 are equal in resolution of imaging element, the imaging element of the special image capturing device 1 captures a wide area to obtain the equirectangular projection image, from which the 360-degree spherical image CE is generated. Accordingly, the image data captured with the special image capturing device 1 tends to be low in definition per unit area.


<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 FIG. 17, the superimposed display metadata includes the location parameter and the correction parameter, each of which is generated as described below.


Referring to FIG. 20, the extractor 550 extracts a plurality of feature points fp1 from the rectangular, equirectangular projection image EC captured in equirectangular projection (S110). The extractor 550 further extracts a plurality of feature points fp2 from the rectangular, planar image P captured in perspective projection (S110).


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 FIG. 23 (FIG. 27), the dividing unit 21 illustrated in FIG. 17 divides the planar image P into a plurality of blocks (S161, S261). The matching unit 22 matches each block, divided by the dividing unit 21, with a corresponding area in the peripheral area image PI to be corrected (S162, S262).


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 FIG. 25 (FIG. 29, FIGS. 30A to 30C) (S164, S264).


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 FIG. 32B (S170).


As illustrated in FIG. 21, the projection reverse converter 562 converts (reverse converts) the second area CA2 from the perspective projection to the equirectangular projection, which is the same as the projection of the equirectangular projection image EC (S180). As illustrated in FIG. 33, the projection reverse converter 562 determines the third area CA3 in the equirectangular projection image EC, which contains a plurality of grid areas LA3 corresponding to the plurality of grid areas LA2 in the second area CA2. FIG. 33 is a conceptual diagram for explaining determination of the third area CA3 in the equirectangular projection image EC. Through processing by the projection reverse converter 562, a location parameter is generated, which indicates the coordinate of each grid in each grid area LA3. The location parameter is illustrated in FIG. 18 and FIG. 19B.


Referring to FIGS. 21 to 34C, operation of generating the correction parameter is described according to the embodiment. FIGS. 34A to 34C are conceptual diagrams illustrating operation of generating the correction parameter, according to the embodiment.


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 FIG. 34A, on corresponding four vertices of the planar image P, to obtain the second area CA2 as illustrated in FIG. 34B.


As illustrated in FIG. 34C, the area divider 560 divides the planar image P into a plurality of grid areas LA0, which are equal in shape and number to the plurality of grid areas LA2′ of the second area CA2′ (S200).


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 FIG. 18, the superimposed display metadata generator 570 generates the superimposed display metadata, using the equirectangular projection image information obtained from the special image capturing device 1, the planar image information obtained from the generic image capturing device 3, the area division number information previously set, the location parameter generated by the projection reverse converter 562, the correction parameter generated by the correction parameter generator 566, and the metadata generation information (S220). The superimposed display metadata is stored in the memory 5000 by the storing and reading unit 59.


Then, the operation of generating the superimposed display metadata performed at S22 of FIG. 20 ends. The display control 56, which cooperates with the storing and reading unit 59, superimposes the images, using the superimposed display metadata (S23).


<Superimposition>


Referring to FIGS. 35 to 40D, operation of superimposing images is described according to the embodiment. FIG. 35 is a conceptual diagram illustrating operation of superimposing images, with images being processed or generated, according to the embodiment.


The storing and reading unit 59 (obtainer) illustrated in FIG. 14 reads from the memory 5000, data of the equirectangular projection image EC in equirectangular projection, data of the planar image P in perspective projection, and the superimposed display metadata.


As illustrated in FIG. 35, using the location parameter, the superimposed area generator 582 specifies a part of the virtual sphere CS, which corresponds to the third area CA3, to generate a partial sphere PS (S310). The pixels other than the pixels corresponding to the grids having the positions defined by the location parameter are interpolated by linear interpolation.


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 FIG. 7, the projection converter 590 converts projection, such that the predetermined area T of the spherical image CE, with the superimposed image S being superimposed, is displayed on the display 517, for example, in response to a user instruction for display. The projection transformation is performed based on the line of sight of the user (the direction of the virtual camera IC, represented by the central point CP of the predetermined area T), and the angle of view α of the predetermined area T (S370). The projection converter 590 may further change a size of the predetermined area T according to the resolution of the display area of the display 517. Accordingly, the display control 56 displays the predetermined-area image Q, that is, the image of the predetermined area T, in the entire display area of the display 517 (S24). In this example, the predetermined-area image Q includes the superimposed image S superimposed with the planar image P.


Referring to FIGS. 36 to 40D, display of the superimposed image is described in detail, according to the embodiment. FIG. 36 is a conceptual diagram illustrating a two-dimensional view of the spherical image CE superimposed with the planar image P. The planar image P is superimposed on the spherical image CE illustrated in FIG. 5. As illustrated in FIG. 36, the high-definition superimposed image S is superimposed on the spherical image CE, which covers a surface of the sphere CS, to be within the inner side of the sphere CS, according to the location parameter.



FIG. 37 is a conceptual diagram illustrating a three-dimensional view of the spherical image CE superimposed with the planar image P. FIG. 37 represents a state in which the spherical image CE and the superimposed image S cover a surface of the sphere CS, and the predetermined-area image Q includes the superimposed image S.



FIGS. 38A and 38B are conceptual diagrams illustrating a two-dimensional view of a spherical image superimposed with a planar image, without using the location parameter, according to a comparative example. FIGS. 39A and 39B are conceptual diagrams illustrating a two-dimensional view of the spherical image CE superimposed with the planar image P, using the location parameter, in this embodiment.


As illustrated in FIG. 38A, it is assumed that the virtual camera IC, which corresponds to the user's point of view, is located at the center of the sphere CS, which is a reference point. The object P1, as an image capturing target, is represented by the object P2 in the spherical image CE. The object P1 is represented by the object P3 in the superimposed image S. Still referring to FIG. 38A, the object P2 and the object P3 are positioned along a straight line connecting the virtual camera IC and the object P1. This indicates that, even when the superimposed image S is displayed as being superimposed on the spherical image CE, the coordinate of the spherical image CE and the coordinate of the superimposed image S match.


As illustrated in FIG. 38B, if the virtual camera IC is moved away from the center of the sphere CS, the position of the object P2 stays on the straight line connecting the virtual camera IC and the object P1, but the position of the object P3 is slightly shifted to the position of an object P3′. The object P3′ is an object in the superimposed image S, which is positioned along the straight line connecting the virtual camera IC and the object P1. This will cause a difference in grid positions between the spherical image CE and the superimposed image S, by an amount of shift “g” between the object P3 and the object P3′. Accordingly, in displaying the superimposed image S, the coordinate of the superimposed image S is shifted from the coordinate of the spherical image CE.


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 FIGS. 39A and 39B, the superimposed image S is superimposed on the spherical image CE at right positions, while compensating the shift. More specifically, as illustrated in FIG. 39A, when the virtual camera IC is at the center of the sphere CS, the object P2 and the object P3 are positioned along the straight line connecting the virtual camera IC and the object P1. As illustrated in FIG. 39B, even when the virtual camera IC is moved away from the center of the sphere CS, the object P2 and the object P3 are positioned along the straight line connecting the virtual camera IC and the object P1. Even when the superimposed image S is displayed as being superimposed on the spherical image CE, the coordinate of the spherical image CE and the coordinate of the superimposed image S match.


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 FIGS. 40A to 40D. FIG. 40A illustrates the spherical image CE, when displayed as a wide-angle image. Here, the planar image P is not superimposed on the spherical image CE. FIG. 40B illustrates the spherical image CE, when displayed as a telephoto image. Here, the planar image P is not superimposed on the spherical image CE. FIG. 40C illustrates the spherical image CE, superimposed with the planar image P, when displayed as a wide-angle image. FIG. 40D illustrates the spherical image CE, superimposed with the planar image P, when displayed as a telephoto image. The dotted line in each of FIGS. 40A and 40C, which indicates the boundary of the planar image P, is shown for the descriptive purposes. Such dotted line may be displayed, or not displayed, on the display 517 to the user.


It is assumed that, while the spherical image CE without the planar image P being superimposed, is displayed as illustrated in FIG. 40A, a user instruction for enlarging an area indicated by the dotted area is received. In such case, as illustrated in FIG. 40B, the enlarged, low-definition image, which is a blurred image, is displayed to the user. As described above in this embodiment, it is assumed that, while the spherical image CE with the planar image P being superimposed, is displayed as illustrated in FIG. 40C, a user instruction for enlarging an area indicated by the dotted area is received. In such case, as illustrated in FIG. 40D, a high-definition image, which is a clear image, is displayed to the user. For example, assuming that the target object, which is shown within the dotted line, has a sign with some characters, even when the user enlarges that section, the user may not be able to read such characters if the image is blurred. If the high-definition planar image P is superimposed on that section, the high-quality image will be displayed to the user such that the user is able to read those characters.


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 FIG. 21, the smart phone 5 according to this embodiment determines the first area CA1 in the equirectangular projection image EC, which corresponds to the planar image P, to roughly determine the area where the planar image P is superimposed (S120). The smart phone 5 extracts a peripheral area PA, which is a part surrounding the point of gaze GP1 in the first area CA1, from the equirectangular projection image EC. The smart phone 5 further converts the peripheral area PA, from the equirectangular projection, to the perspective projection that is the projection of the planar image P, to generate a peripheral area image PI (S140). The smart phone 5 determines the second area CA2, which corresponds to the planar image P, in the peripheral area image P1 (S160), and reversely converts the projection applied to the second area CA2, back to the equirectangular projection applied to the equirectangular projection image EC. With this projection transformation, the third area CA3 in the equirectangular projection image EC, which corresponds to the second area CA2, is determined (S180). As illustrated in FIG. 40C, the high-definition planar image P is superimposed on a part of the predetermined-area image on the low-definition, spherical image CE. The planar image P fits in the spherical image CE, when displayed to the user.


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 FIG. 31C, a target object will be placed in a center of an image. The image illustrated in FIG. 31C appears similar to the image illustrated in FIG. 31D, which has been taken with the generic image capturing device. In the image illustrated in FIG. 31C, the effects of the region having a few feature points are compensated for by block matching. Accordingly, block matching and correction based on validity determination may improve a result of matching between images with large parallax and also improve a result of matching between images having a few feature points.


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 FIG. 39B, the superimposed image S is superimposed on the spherical image CE at right positions. This compensates the shift in grid due to the difference in projection, even when the position of the virtual camera IC changes.


Second Embodiment

Referring now to FIGS. 41 to 45, an image capturing system is described according to a second embodiment.


<Overview of Image Capturing System>


First, referring to FIG. 41, an overview of the image capturing system is described according to the second embodiment. FIG. 41 is a schematic block diagram illustrating a configuration of the image capturing system according to the second embodiment.


As illustrated in FIG. 41, compared to the image capturing system of the first embodiment described above, the image capturing system of this embodiment further includes an image processing server 7. In the second embodiment, the elements that are substantially same to the elements described in the first embodiment are assigned with the same reference numerals. For descriptive purposes, description thereof is omitted. The smart phone 5 and the image processing server 7 communicate with each other through the communication network 100 such as the Internet and the Intranet.


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 FIG. 42, a hardware configuration of the image processing server 7 is described according to the embodiment. FIG. 42 illustrates a hardware configuration of the image processing server 7 according to the embodiment. Since the special image capturing device 1, the generic image capturing device 3, and the smart phone 5 are substantially the same in hardware configuration, as described in the first embodiment, description thereof is omitted.


<Hardware Configuration of Image Processing Server>



FIG. 42 is a schematic block diagram illustrating a hardware configuration of the image processing server 7, according to the embodiment. Referring to FIG. 42, the image processing server 7, which is implemented by the general-purpose computer, includes a CPU 701, a ROM 702, a RAM 703, a HD 704, a HDD 705, a medium I/F 707, a display 708, a network I/F 709, a keyboard 711, a mouse 712, a CD-RW drive 714, and a bus line 710. Since the image processing server 7 operates as a server, an input device such as the keyboard 711 and the mouse 712, or an output device such as the display 708 does not have to be provided.


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 FIG. 42 such as the CPU 701.


<Functional Configuration of Image Capturing System>


Referring now to FIGS. 43 and 44, a functional configuration of the image capturing system of FIG. 41 is described according to the second embodiment. FIG. 43 is a schematic block diagram illustrating a functional configuration of the image capturing system of FIG. 41 according to the second embodiment. Since the special image capturing device 1, the generic image capturing device 3, and the smart phone 5 are substantially same in functional configuration, as described in the first embodiment, description thereof is omitted. In this embodiment, however, the image and audio processing unit 55 of the smart phone 5 does not have to be provided with all of the functional units illustrated in FIG. 16.


<Functional Configuration of Image Processing Server>


As illustrated in FIG. 43, the image processing server 7 includes a long-range communication unit 71, an acceptance unit 72, an image and audio processing unit 75, a display control 76, a determiner 77, and a storing and reading unit 79. These units are functions that are implemented by or that are caused to function by operating any of the elements illustrated in FIG. 42 in cooperation with the instructions of the CPU 701 according to the control program expanded from the HD 704 to the RAM 703.


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 FIG. 42.


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 FIG. 42, to transmit or receive various data or information to or from other device (for example, other smart phone or server) through the communication network such as the Internet.


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 FIG. 42, to perform various determinations.


The storing and reading unit 79, which is implemented by instructions of the CPU 701 illustrated in FIG. 42, stores various data or information in the memory 7000 and read out various data or information from the memory 7000. For example, the superimposed display metadata may be stored in the memory 7000. In this embodiment, the storing and reading unit 79 functions as an obtainer that obtains various data from the memory 7000.


(Functional configuration of Image and Audio Processing Unit)


Referring to FIG. 44, a functional configuration of the image and audio processing unit 75 is described according to the embodiment. FIG. 44 is a block diagram illustrating the functional configuration of the image and audio processing unit 75 according to the embodiment.


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 FIG. 45. The superimposing unit 75b performs processing of S45, which is processing to superimpose the images using the superimposed display metadata, as illustrated in FIG. 45.


(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 FIG. 44, a functional configuration of the superimposing unit 75b is described according to the embodiment. The superimposing unit 75b includes a superimposed area generator 782, a correction unit 784, an image generator 786, an image superimposing unit 788, and a projection converter 790. These elements of the superimposing unit 75b are substantially similar in function to the superimposed area generator 582, correction unit 584, image generator 586, image superimposing unit 588, and projection converter 590 of the superimposing unit 55b, respectively. Accordingly, the description thereof is omitted.


<Operation>


Referring to FIG. 45, operation of capturing the image, performed by the image capturing system of FIG. 41, is described according to the second embodiment. Referring to FIG. 45, operation of capturing the image, performed by the image capturing system of FIG. 31, is described according to the second embodiment. FIG. 45 is a data sequence diagram illustrating operation of capturing the image, according to the second embodiment. S31 to S41 are performed in a substantially similar manner as described above referring to S11 to S21 according to the first embodiment, and description thereof is omitted.


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 FIG. 44 generates superimposed display metadata (S44). Further, the superimposing unit 75b superimposes images using the superimposed display metadata (S45). More specifically, the superimposing unit 75b superimposes the planar image on the equirectangular projection image. S44 and S45 are performed in a substantially similar manner as described above referring to S22 and S23 of FIG. 20, and description thereof is omitted.


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 FIG. 14, the equirectangular projection image data, planar image data, and superimposed display metadata, may not be stored in a memory of the smart phone 5. For example, any of the equirectangular projection image data, planar image data, and superimposed display metadata may be stored in any server on the network.


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 FIG. 34 generates superimposed display metadata. At the smart phone 5, the superimposing unit 75b illustrated in FIG. 44 superimposes one image on other image, in a substantially similar manner in the case of the superimposing unit 55b in FIG. 16. The display control 56 illustrated in FIG. 14 processes display of the superimposed images.


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.

Claims
  • 1. An image processing apparatus comprising processing circuitry configured to: obtain a first image in first projection, and a second image in second projection;transform 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;identify a plurality of feature points, respectively, in the second image and the third image;determine 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;correct 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;transform 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; andstore, 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.
  • 2. The image processing apparatus of claim 1, wherein, in a process of correcting, the processing circuitry is configured to: divide the second image into the plurality of blocks;determine an area of the third image that corresponds to each one of the plurality of blocks of the second image, to obtain the plurality of blocks of the third image that match the plurality of blocks of the second image;calculate, for each representative point of the second corresponding area, a motion vector from the representative point to a point of the corresponding block of the third image that corresponds to the representative point; andcorrect the representative point of the second corresponding area based on the motion vector, to generate the corrected second corresponding area.
  • 3. The image processing apparatus of claim 2, wherein the processing circuitry is configured to: correct the motion vector that is calculated, based on similarity between the first image and the third image; andcorrect the representative point of the second corresponding area, based on the corrected motion vector.
  • 4. The image processing apparatus of claim 2, wherein the processing circuitry is configured to: correct the motion vector that is calculated, based on light variance in the third image; andcorrect the representative point of the second corresponding area, based on the corrected motion vector.
  • 5. The image processing apparatus of claim 1, wherein the first image is an equirectangular projection image, and the second image is a perspective projection image.
  • 6. The image processing apparatus of claim 1, wherein the image processing apparatus includes at least one of a smart phone, tablet personal computer, notebook computer, desktop computer, and server computer.
  • 7. An image capturing system comprising: the image processing apparatus of claim 1; anda first image capturing device configured to capture surroundings of a target object to obtain the first image in the first projection and transmit the first image in the first projection to the image processing apparatus; anda second image capturing device configured to capture the target object to obtain the second image in the second projection and transmit the second image in the second projection to the image processing apparatus.
  • 8. An image processing method comprising: obtaining a first image in first projection, and a second image in second projection;transforming 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,identifying a plurality of feature points, respectively, in the second image and the third image;determining 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;correcting 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;transforming projection of a plurality of points in the corrected second 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; andstoring, 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.
  • 9. The image processing method of claim 8, wherein the correcting includes: dividing the second image into the plurality of blocks;determining an area of the third image that corresponds to each one of the plurality of blocks of the second image, to obtain the plurality of blocks of the third image that match the plurality of blocks of the second image;calculating, for each representative point of the second corresponding area, a motion vector from the representative point to a point of the corresponding block of the third image that corresponds to the representative point; andcorrecting the representative point of the second corresponding area based on the motion vector, to generate the corrected second corresponding area.
  • 10. A non-transitory recording medium which, when executed by one or more processors, cause the processors to perform an image processing method, comprising: obtaining a first image in first projection, and a second image in second projection;transforming 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;identifying a plurality of feature points, respectively, in the second image and the third image;determining 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;correcting 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;transforming projection of a plurality of points in the corrected second 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; andstoring, 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.
Priority Claims (2)
Number Date Country Kind
2018-070486 Mar 2018 JP national
2019-046780 Mar 2019 JP national