-
Notifications
You must be signed in to change notification settings - Fork 13
/
videoreconstruction.cpp
110 lines (90 loc) · 4.48 KB
/
videoreconstruction.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
#include <QApplication>
#include <QDir>
#include <GL/freeglut_std.h>
#include "glog/logging.h"
#include "ioutilities.h"
#include "meshvisualizer.h"
#include "singleimagereconstructor.hpp"
#include "videoreconstructor.hpp"
#include "boost/filesystem/operations.hpp"
#include "boost/filesystem/path.hpp"
#include "boost/program_options.hpp"
int main(int argc, char *argv[]) {
QApplication a(argc, argv);
glutInit(&argc, argv);
google::InitGoogleLogging(argv[0]);
namespace fs = boost::filesystem;
namespace po = boost::program_options;
const string home_directory = QDir::homePath().toStdString();
cout << "Home dir: " << home_directory << endl;
po::options_description desc("Options");
desc.add_options()
("settings_file", po::value<string>()->required(), "Input settings file")
("model_file", po::value<string>()->default_value(home_directory + "/Data/Multilinear/blendshape_core.tensor"), "Multilinear model file")
("id_prior_file", po::value<string>()->default_value(home_directory + "/Data/Multilinear/blendshape_u_0_aug.tensor"), "Identity prior file")
("exp_prior_file", po::value<string>()->default_value(home_directory + "/Data/Multilinear/blendshape_u_1_aug.tensor"), "Expression prior file")
("template_mesh_file", po::value<string>()->default_value(home_directory + "/Data/Multilinear/template.obj"), "Template mesh file")
("contour_points_file", po::value<string>()->default_value(home_directory + "/Data/Multilinear/contourpoints.txt"), "Contour points file")
("landmarks_file", po::value<string>()->default_value(home_directory + "/Data/Multilinear/landmarks_73.txt"), "Landmarks file")
("use_init_res", "Use existing recon results to initialize model params")
("init_recon_path", po::value<string>(), "Initialial reconstruction results path")
("direct_multi_recon", "Use direct multi-recon")
("no_selection", "Disable selection")
("no_failure_detection", "Disable feature points failure detection")
("no_progressive", "Diable progressive reconstruction");
po::variables_map vm;
try {
po::store(po::parse_command_line(argc, argv, desc), vm);
po::notify(vm);
if(vm.count("help")) {
cout << desc << endl;
return 1;
}
// nothing to do after successful parsing command line arguments
} catch(po::error& e) {
cerr << "Error: " << e.what() << endl;
cerr << desc << endl;
return 1;
}
const string model_filename(vm["model_file"].as<string>());
const string id_prior_filename(vm["id_prior_file"].as<string>());
const string exp_prior_filename(vm["exp_prior_file"].as<string>());
const string template_mesh_filename(vm["template_mesh_file"].as<string>());
const string contour_points_filename(vm["contour_points_file"].as<string>());
const string landmarks_filename(vm["landmarks_file"].as<string>());
const string settings_filename(vm["settings_file"].as<string>());
BasicMesh mesh(template_mesh_filename);
auto landmarks = LoadIndices(landmarks_filename);
auto contour_indices = LoadContourIndices(contour_points_filename);
// Create reconstructor and load the common resources
VideoReconstructor<Constraint2D> recon;
recon.LoadModel(model_filename);
recon.LoadPriors(id_prior_filename, exp_prior_filename);
recon.SetMesh(mesh);
recon.SetContourIndices(contour_indices);
recon.SetIndices(landmarks);
recon.SetSelectionState(!vm.count("no_selection"));
recon.SetFailureDetectionState(!vm.count("no_failure_detection"));
recon.SetProgressiveReconState(!vm.count("no_progressive"));
recon.SetDirectMultiRecon(vm.count("direct_multi_recon"));
recon.SetUseInitReconResults(vm.count("use_init_res"));
if(vm.count("use_init_res")) {
recon.SetInitReconResultsPath(vm["init_recon_path"].as<string>());
}
// Parse the setting file and load image related resources
fs::path settings_filepath(settings_filename);
vector<pair<string, string>> image_points_filenames = ParseSettingsFile(settings_filename);
for(auto& p : image_points_filenames) {
fs::path image_filename = settings_filepath.parent_path() / fs::path(p.first);
fs::path pts_filename = settings_filepath.parent_path() / fs::path(p.second);
cout << "[" << image_filename << ", " << pts_filename << "]" << endl;
auto image_points_pair = LoadImageAndPoints(image_filename.string(), pts_filename.string(), false);
recon.AddImagePointsPair(image_filename.string(), image_points_pair);
}
{
boost::timer::auto_cpu_timer t("Reconstruction finished in %w seconds.\n");
recon.Reconstruct();
}
//return a.exec();
return 0;
}