forked from smistad/Level-Set-Segmentation
-
Notifications
You must be signed in to change notification settings - Fork 0
/
main.cpp
76 lines (67 loc) · 2.61 KB
/
main.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
#include "levelSet.hpp"
#include "SIPL/Visualization.hpp"
#include "OpenCLManager.hpp"
#include "HelperFunctions.hpp"
#include <iostream>
#include "level-set-segmentation-config.h"
#include "OulConfig.hpp"
using namespace std;
void visualize(SIPL::Volume<float> * input, SIPL::Volume<char> * seg, float level, float window) {
SIPL::Visualization * v = new SIPL::Visualization(input, seg);
v->setLevel(input, level);
v->setWindow(input, window);
v->display();
}
int main(int argc, char ** argv) {
if(argc < 10) {
cout << endl;
cout << "OpenCL Level Set Segmentation by Erik Smistad 2013" << endl;
cout << "www.github.com/smistad/OpenCL-Level-Set-Segmentation/" << endl;
cout << "======================================================" << endl;
cout << "The speed function is defined as -alpha*(epsilon-(T-intensity))+(1-alpha)*curvature" << endl;
cout << "Usage: " << argv[0] << " inputFile.mhd seedX seedY seedZ seedRadius iterations threshold epsilon alpha [level window] [outputFile.mhd]" << endl;
cout << "If the level and window arguments are set, the segmentation result will be displayed as an overlay to the input volume " << endl;
return -1;
}
// Set initial mask
SIPL::int3 seedPosition(atoi(argv[2]), atoi(argv[3]), atoi(argv[4]));
float seedRadius = atof(argv[5]);
float level = -1.0f;
float window = -1.0f;
if(argc == 13 || argc == 12) {
level = atof(argv[10]);
window = atof(argv[11]);
}
std::string outputFilename = "";
if(argc == 13 || argc == 11) { // filename specified, write to disk
outputFilename = argc == 11 ? argv[10] : argv[12];
}
// Do level set
try {
SIPL::Volume<char> * segmentation = runLevelSet(
argv[1],
seedPosition,
seedRadius,
atoi(argv[6]),
atof(argv[7]),
atof(argv[8]),
atof(argv[9]),
KERNELS_DIR,
OUL_DIR
);
// Write to disk
if(outputFilename != "") {
std::cout << "Writing results to " << outputFilename << std::endl;
segmentation->save(outputFilename.c_str());
}
// Visualize result
if(window != -1.0f) {
SIPL::Volume<float> * input = new SIPL::Volume<float>(argv[1]);
visualize(input, segmentation, level, window);
} else {
delete segmentation;
}
} catch(cl::Error &e) {
cout << "OpenCL error occurred: " << e.what() << " " << oul::getCLErrorString(e.err()) << endl;
}
}