1
#include <opencv2/photo.hpp>
2
#include "opencv2/imgcodecs.hpp"
3
#include <opencv2/highgui.hpp>
11
void loadExposureSeq(String, vector<Mat>&, vector<float>&);
13
int main(int, char**argv)
17
loadExposureSeq(argv[1], images, times);
20
Ptr<CalibrateDebevec> calibrate = createCalibrateDebevec();
21
calibrate->process(images, response, times);
24
Ptr<MergeDebevec> merge_debevec = createMergeDebevec();
25
merge_debevec->process(images, hdr, times, response);
28
Ptr<TonemapDurand> tonemap = createTonemapDurand(2.2f);
29
tonemap->process(hdr, ldr);
32
Ptr<MergeMertens> merge_mertens = createMergeMertens();
33
merge_mertens->process(images, fusion);
35
imwrite("fusion.png", fusion * 255);
36
imwrite("ldr.png", ldr * 255);
37
imwrite("hdr.hdr", hdr);
42
void loadExposureSeq(String path, vector<Mat>& images, vector<float>& times)
44
path = path + std::string("/");
45
ifstream list_file((path + "list.txt").c_str());
48
while(list_file >> name >> val) {
49
Mat img = imread(path + name);
50
images.push_back(img);
51
times.push_back(1 / val);