Docs updated, added InputArray, fixes for makePtr,...
This commit is contained in:

committed by
Alexander Shishkov

parent
f99be6bda6
commit
c9ace38897
@@ -40,13 +40,13 @@ Explanation
|
||||
loadExposureSeq(argv[1], images, times);
|
||||
|
||||
Firstly we load input images and exposure times from user-defined folder. The folder should contain images and *list.txt* - file that contains file names and inverse exposure times.
|
||||
|
||||
|
||||
For our image sequence the list is following:
|
||||
|
||||
.. code-block:: none
|
||||
|
||||
|
||||
.. code-block:: none
|
||||
|
||||
memorial00.png 0.03125
|
||||
memorial01.png 0.0625
|
||||
memorial01.png 0.0625
|
||||
...
|
||||
memorial15.png 1024
|
||||
|
||||
@@ -57,9 +57,9 @@ Explanation
|
||||
Mat response;
|
||||
Ptr<CalibrateDebevec> calibrate = createCalibrateDebevec();
|
||||
calibrate->process(images, response, times);
|
||||
|
||||
|
||||
It is necessary to know camera response function (CRF) for a lot of HDR construction algorithms. We use one of the calibration algorithms to estimate inverse CRF for all 256 pixel values.
|
||||
|
||||
|
||||
3. **Make HDR image**
|
||||
|
||||
.. code-block:: cpp
|
||||
@@ -67,39 +67,39 @@ Explanation
|
||||
Mat hdr;
|
||||
Ptr<MergeDebevec> merge_debevec = createMergeDebevec();
|
||||
merge_debevec->process(images, hdr, times, response);
|
||||
|
||||
|
||||
We use Debevec's weighting scheme to construct HDR image using response calculated in the previous item.
|
||||
|
||||
|
||||
4. **Tonemap HDR image**
|
||||
|
||||
.. code-block:: cpp
|
||||
|
||||
|
||||
Mat ldr;
|
||||
Ptr<TonemapDurand> tonemap = createTonemapDurand(2.2f);
|
||||
tonemap->process(hdr, ldr);
|
||||
|
||||
|
||||
Since we want to see our results on common LDR display we have to map our HDR image to 8-bit range preserving most details. It is the main goal of tonemapping methods. We use tonemapper with bilateral filtering and set 2.2 as the value for gamma correction.
|
||||
|
||||
|
||||
5. **Perform exposure fusion**
|
||||
|
||||
.. code-block:: cpp
|
||||
|
||||
|
||||
Mat fusion;
|
||||
Ptr<MergeMertens> merge_mertens = createMergeMertens();
|
||||
merge_mertens->process(images, fusion);
|
||||
|
||||
There is an alternative way to merge our exposures in case when we don't need HDR image. This process is called exposure fusion and produces LDR image that doesn't require gamma correction. It also doesn't use exposure values of the photographs.
|
||||
|
||||
|
||||
6. **Write results**
|
||||
|
||||
.. code-block:: cpp
|
||||
|
||||
|
||||
imwrite("fusion.png", fusion * 255);
|
||||
imwrite("ldr.png", ldr * 255);
|
||||
imwrite("hdr.hdr", hdr);
|
||||
|
||||
|
||||
Now it's time to look at the results. Note that HDR image can't be stored in one of common image formats, so we save it to Radiance image (.hdr). Also all HDR imaging functions return results in [0, 1] range so we should multiply result by 255.
|
||||
|
||||
|
||||
Results
|
||||
=======
|
||||
|
||||
@@ -111,7 +111,7 @@ Tonemapped image
|
||||
:width: 242pt
|
||||
:alt: Tonemapped image
|
||||
:align: center
|
||||
|
||||
|
||||
Exposure fusion
|
||||
------------------
|
||||
|
||||
|
Reference in New Issue
Block a user