Commit 49399734 authored by Pavel Rojtberg's avatar Pavel Rojtberg

cnn_3dobj: fix include and allow compilation of samples

caffe/vision_layers.hpp is gone. also fix some warnings.
parent bd619c55
...@@ -32,13 +32,17 @@ configure_file(${CMAKE_CURRENT_SOURCE_DIR}/cnn_3dobj_config.hpp.in ...@@ -32,13 +32,17 @@ configure_file(${CMAKE_CURRENT_SOURCE_DIR}/cnn_3dobj_config.hpp.in
include_directories(${CMAKE_CURRENT_BINARY_DIR}) include_directories(${CMAKE_CURRENT_BINARY_DIR})
if(${Caffe_FOUND}) include_directories(${Caffe_INCLUDE_DIR})
include_directories(${Caffe_INCLUDE_DIR})
endif()
set(the_description "CNN for 3D object recognition and pose estimation including a completed Sphere View on 3D objects") set(the_description "CNN for 3D object recognition and pose estimation including a completed Sphere View on 3D objects")
ocv_define_module(cnn_3dobj opencv_core opencv_imgproc opencv_viz opencv_highgui OPTIONAL WRAP python) ocv_define_module(cnn_3dobj opencv_core opencv_imgproc ${Caffe_LIBS} ${Glog_LIBS} ${Protobuf_LIBS} OPTIONAL opencv_features2d opencv_viz opencv_calib3d WRAP python)
if(${Caffe_FOUND}) if(TARGET opencv_test_cnn_3dobj)
target_link_libraries(opencv_cnn_3dobj ${Caffe_LIBS} ${Glog_LIBS} ${Protobuf_LIBS}) target_link_libraries(opencv_test_cnn_3dobj boost_system)
endif() endif()
foreach(exe_TGT demo_classify demo_video demo_sphereview_data demo_model_analysis)
if(TARGET example_cnn_3dobj_${exe_TGT})
target_link_libraries(example_cnn_3dobj_${exe_TGT} boost_system)
endif()
endforeach()
endif() endif()
# Caffe package for CNN Triplet training # Caffe package for CNN Triplet training
unset(Caffe_FOUND) unset(Caffe_FOUND)
find_path(Caffe_INCLUDE_DIR NAMES caffe/caffe.hpp caffe/common.hpp caffe/net.hpp caffe/proto/caffe.pb.h caffe/util/io.hpp caffe/vision_layers.hpp find_path(Caffe_INCLUDE_DIR NAMES caffe/caffe.hpp caffe/common.hpp caffe/net.hpp caffe/proto/caffe.pb.h caffe/util/io.hpp
HINTS HINTS
/usr/local/include) /usr/local/include)
......
...@@ -65,7 +65,6 @@ the use of this software, even if advised of the possibility of such damage. ...@@ -65,7 +65,6 @@ the use of this software, even if advised of the possibility of such damage.
#include <caffe/net.hpp> #include <caffe/net.hpp>
#include <caffe/proto/caffe.pb.h> #include <caffe/proto/caffe.pb.h>
#include <caffe/util/io.hpp> #include <caffe/util/io.hpp>
#include <caffe/vision_layers.hpp>
#endif #endif
#include "opencv2/viz/vizcore.hpp" #include "opencv2/viz/vizcore.hpp"
......
cmake_minimum_required(VERSION 2.8)
SET(CMAKE_CXX_FLAGS_DEBUG "$ENV{CXXFLAGS} -O0 -Wall -g -ggdb ")
SET(CMAKE_CXX_FLAGS_RELEASE "$ENV{CXXFLAGS} -O3 -Wall")
project(cnn_3dobj)
find_package(OpenCV REQUIRED)
set(SOURCES_generator demo_sphereview_data.cpp)
include_directories(${OpenCV_INCLUDE_DIRS})
add_executable(sphereview_test ${SOURCES_generator})
target_link_libraries(sphereview_test opencv_core opencv_imgproc opencv_highgui opencv_cnn_3dobj opencv_xfeatures2d)
set(SOURCES_classifier demo_classify.cpp)
add_executable(classify_test ${SOURCES_classifier})
target_link_libraries(classify_test opencv_core opencv_imgproc opencv_highgui opencv_cnn_3dobj opencv_xfeatures2d)
set(SOURCES_modelanalysis demo_model_analysis.cpp)
add_executable(model_test ${SOURCES_modelanalysis})
target_link_libraries(model_test opencv_core opencv_imgproc opencv_highgui opencv_cnn_3dobj opencv_xfeatures2d)
set(SOURCES_video demo_video.cpp)
add_executable(video_test ${SOURCES_video})
target_link_libraries(video_test opencv_core opencv_imgproc opencv_highgui opencv_cnn_3dobj opencv_xfeatures2d)
...@@ -38,7 +38,7 @@ ...@@ -38,7 +38,7 @@
* @author Yida Wang * @author Yida Wang
*/ */
#include <opencv2/cnn_3dobj.hpp> #include <opencv2/cnn_3dobj.hpp>
#include <opencv2/features2d/features2d.hpp> #include <opencv2/features2d.hpp>
#include <iomanip> #include <iomanip>
using namespace cv; using namespace cv;
using namespace std; using namespace std;
...@@ -48,7 +48,7 @@ using namespace cv::cnn_3dobj; ...@@ -48,7 +48,7 @@ using namespace cv::cnn_3dobj;
* @function listDir * @function listDir
* @brief Making all files names under a directory into a list * @brief Making all files names under a directory into a list
*/ */
void listDir(const char *path, std::vector<String>& files, bool r) static void listDir(const char *path, std::vector<String>& files, bool r)
{ {
DIR *pDir; DIR *pDir;
struct dirent *ent; struct dirent *ent;
...@@ -82,7 +82,7 @@ void listDir(const char *path, std::vector<String>& files, bool r) ...@@ -82,7 +82,7 @@ void listDir(const char *path, std::vector<String>& files, bool r)
* @function featureWrite * @function featureWrite
* @brief Writing features of gallery images into binary files * @brief Writing features of gallery images into binary files
*/ */
int featureWrite(const Mat &features, const String &fname) static int featureWrite(const Mat &features, const String &fname)
{ {
ofstream ouF; ofstream ouF;
ouF.open(fname.c_str(), std::ofstream::binary); ouF.open(fname.c_str(), std::ofstream::binary);
...@@ -131,7 +131,6 @@ int main(int argc, char** argv) ...@@ -131,7 +131,6 @@ int main(int argc, char** argv)
String feature_blob = parser.get<String>("feature_blob"); String feature_blob = parser.get<String>("feature_blob");
int num_candidate = parser.get<int>("num_candidate"); int num_candidate = parser.get<int>("num_candidate");
String device = parser.get<String>("device"); String device = parser.get<String>("device");
int dev_id = parser.get<int>("dev_id");
int gallery_out = parser.get<int>("gallery_out"); int gallery_out = parser.get<int>("gallery_out");
/* Initialize a net work with Device */ /* Initialize a net work with Device */
cv::cnn_3dobj::descriptorExtractor descriptor(device); cv::cnn_3dobj::descriptorExtractor descriptor(device);
...@@ -167,7 +166,7 @@ int main(int argc, char** argv) ...@@ -167,7 +166,7 @@ int main(int argc, char** argv)
{ {
std::cout << std::endl << "---------- Features of gallery images ----------" << std::endl; std::cout << std::endl << "---------- Features of gallery images ----------" << std::endl;
/* Print features of the reference images. */ /* Print features of the reference images. */
for (unsigned int i = 0; i < feature_reference.rows; i++) for (int i = 0; i < feature_reference.rows; i++)
std::cout << feature_reference.row(i) << endl; std::cout << feature_reference.row(i) << endl;
std::cout << std::endl << "---------- Saving features of gallery images into feature.bin ----------" << std::endl; std::cout << std::endl << "---------- Saving features of gallery images into feature.bin ----------" << std::endl;
featureWrite(feature_reference, "feature.bin"); featureWrite(feature_reference, "feature.bin");
...@@ -179,7 +178,7 @@ int main(int argc, char** argv) ...@@ -179,7 +178,7 @@ int main(int argc, char** argv)
std::cout << std::endl << "---------- Features of gallery images ----------" << std::endl; std::cout << std::endl << "---------- Features of gallery images ----------" << std::endl;
std::vector<std::pair<String, float> > prediction; std::vector<std::pair<String, float> > prediction;
/* Print features of the reference images. */ /* Print features of the reference images. */
for (unsigned int i = 0; i < feature_reference.rows; i++) for (int i = 0; i < feature_reference.rows; i++)
std::cout << feature_reference.row(i) << endl; std::cout << feature_reference.row(i) << endl;
cv::Mat feature_test; cv::Mat feature_test;
descriptor.extract(img, feature_test, feature_blob); descriptor.extract(img, feature_test, feature_blob);
......
...@@ -50,7 +50,7 @@ using namespace cv::cnn_3dobj; ...@@ -50,7 +50,7 @@ using namespace cv::cnn_3dobj;
* @function listDir * @function listDir
* @brief Making all files names under a directory into a list * @brief Making all files names under a directory into a list
*/ */
void listDir(const char *path, std::vector<String>& files, bool r) static void listDir(const char *path, std::vector<String>& files, bool r)
{ {
DIR *pDir; DIR *pDir;
struct dirent *ent; struct dirent *ent;
...@@ -144,7 +144,7 @@ int main(int argc, char *argv[]) ...@@ -144,7 +144,7 @@ int main(int argc, char *argv[])
obj_dist = 370; obj_dist = 370;
bg_dist = 400; bg_dist = 400;
} }
if (label_class == 5 | label_class == 10 | label_class == 11 | label_class == 12) if (label_class == 5 || label_class == 10 || label_class == 11 || label_class == 12)
ite_depth = ite_depth + 1; ite_depth = ite_depth + 1;
cv::cnn_3dobj::icoSphere ViewSphere(10,ite_depth); cv::cnn_3dobj::icoSphere ViewSphere(10,ite_depth);
std::vector<cv::Point3d> campos; std::vector<cv::Point3d> campos;
...@@ -250,7 +250,6 @@ int main(int argc, char *argv[]) ...@@ -250,7 +250,6 @@ int main(int argc, char *argv[])
cam_y_dir.y = cam_head_y; cam_y_dir.y = cam_head_y;
cam_y_dir.z = cam_head_z; cam_y_dir.z = cam_head_z;
char* temp = new char; char* temp = new char;
char* bgname = new char;
std::vector<String> name_bkg; std::vector<String> name_bkg;
if (bakgrdir.size() != 0) if (bakgrdir.size() != 0)
{ {
...@@ -262,7 +261,7 @@ int main(int argc, char *argv[]) ...@@ -262,7 +261,7 @@ int main(int argc, char *argv[])
} }
} }
/* Images will be saved as .png files. */ /* Images will be saved as .png files. */
int cnt_img; size_t cnt_img;
srand((int)time(0)); srand((int)time(0));
do do
{ {
......
#include <opencv2/viz/vizcore.hpp> #include <opencv2/viz/vizcore.hpp>
#include <opencv2/calib3d/calib3d.hpp> #include <opencv2/calib3d.hpp>
#include <iostream> #include <iostream>
#include <fstream> #include <fstream>
#include <opencv2/cnn_3dobj.hpp> #include <opencv2/cnn_3dobj.hpp>
#include <opencv2/features2d/features2d.hpp> #include <opencv2/features2d.hpp>
#include <iomanip> #include <iomanip>
using namespace cv; using namespace cv;
using namespace std; using namespace std;
...@@ -12,7 +12,7 @@ using namespace cv::cnn_3dobj; ...@@ -12,7 +12,7 @@ using namespace cv::cnn_3dobj;
* @function listDir * @function listDir
* @brief Making all files names under a directory into a list * @brief Making all files names under a directory into a list
*/ */
void listDir(const char *path, std::vector<String>& files, bool r) static void listDir(const char *path, std::vector<String>& files, bool r)
{ {
DIR *pDir; DIR *pDir;
struct dirent *ent; struct dirent *ent;
...@@ -46,12 +46,12 @@ void listDir(const char *path, std::vector<String>& files, bool r) ...@@ -46,12 +46,12 @@ void listDir(const char *path, std::vector<String>& files, bool r)
* @function cvcloud_load * @function cvcloud_load
* @brief load bunny.ply * @brief load bunny.ply
*/ */
Mat cvcloud_load(Mat feature_reference) static Mat cvcloud_load(Mat feature_reference)
{ {
Mat cloud(1, feature_reference.rows, CV_32FC3); Mat cloud(1, feature_reference.rows, CV_32FC3);
Point3f* data = cloud.ptr<cv::Point3f>(); Point3f* data = cloud.ptr<cv::Point3f>();
float dummy1, dummy2;
for(size_t i = 0; i < feature_reference.rows; ++i) for(int i = 0; i < feature_reference.rows; ++i)
{ {
data[i].x = feature_reference.at<float>(i,0); data[i].x = feature_reference.at<float>(i,0);
data[i].y = feature_reference.at<float>(i,1); data[i].y = feature_reference.at<float>(i,1);
...@@ -102,7 +102,7 @@ int main(int argc, char **argv) ...@@ -102,7 +102,7 @@ int main(int argc, char **argv)
String feature_blob = parser.get<String>("feature_blob"); String feature_blob = parser.get<String>("feature_blob");
int num_candidate = parser.get<int>("num_candidate"); int num_candidate = parser.get<int>("num_candidate");
String device = parser.get<String>("device"); String device = parser.get<String>("device");
int dev_id = parser.get<int>("dev_id");
ifstream namelist_model(caffemodellist.c_str(), ios::in); ifstream namelist_model(caffemodellist.c_str(), ios::in);
vector<String> caffemodel; vector<String> caffemodel;
char *buf = new char[512]; char *buf = new char[512];
...@@ -198,7 +198,6 @@ int main(int argc, char **argv) ...@@ -198,7 +198,6 @@ int main(int argc, char **argv)
} }
vector<Mat> img_merge; vector<Mat> img_merge;
/* Part2: Start to have a show */ /* Part2: Start to have a show */
bool camera_pov = true;
viz::Viz3d myWindow0("Instruction"); viz::Viz3d myWindow0("Instruction");
viz::Viz3d myWindow1("Point Cloud"); viz::Viz3d myWindow1("Point Cloud");
viz::Viz3d myWindow2("Prediction sample"); viz::Viz3d myWindow2("Prediction sample");
...@@ -246,7 +245,7 @@ int main(int argc, char **argv) ...@@ -246,7 +245,7 @@ int main(int argc, char **argv)
myWindowS.setWindowSize(Size(1300,700)); myWindowS.setWindowSize(Size(1300,700));
myWindowS.setWindowPosition(Point(0,0)); myWindowS.setWindowPosition(Point(0,0));
myWindowS.setBackgroundColor(viz::Color::white()); myWindowS.setBackgroundColor(viz::Color::white());
for (int i = 0; i < slide.size(); ++i) for (size_t i = 0; i < slide.size(); ++i)
{ {
/// Create a triangle widget /// Create a triangle widget
viz::WImageOverlay slide1(slide[i],Rect(0, 0, 1300, 700)); viz::WImageOverlay slide1(slide[i],Rect(0, 0, 1300, 700));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment