代码拉取完成,页面将自动刷新
#ifndef FEATURE_EXTRACTOR_HPP
#define FEATURE_EXTRACTOR_HPP
#include <stdio.h>
#include <stdlib.h>
#include <iostream>
#include <string>
#include <math.h>
#include <vector>
#include <numeric>
#include <opencv2/core/core.hpp>
#include "parameters.hpp"
#include "ffttools.hpp"
#include "recttools.hpp"
#include "fhog.hpp"
#include "debug.hpp"
#ifdef USE_SIMD
#include "gradient.hpp"
#endif
#ifdef USE_CAFFE
#include <caffe/caffe.hpp>
#include <caffe/util/io.hpp>
#include <caffe/caffe.hpp>
#endif
namespace eco
{
class FeatureExtractor
{
public:
FeatureExtractor() {}
virtual ~FeatureExtractor(){};
ECO_FEATS extractor(const cv::Mat image,
const cv::Point2f pos,
const vector<float> scales,
const EcoParameters ¶ms,
const bool &is_color_image);
cv::Mat sample_patch(const cv::Mat im,
const cv::Point2f pos,
cv::Size2f sample_sz,
cv::Size2f input_sz);
#ifdef USE_SIMD
vector<cv::Mat> get_hog_features_simd(const vector<cv::Mat> ims);
#else
vector<cv::Mat> get_hog_features(const vector<cv::Mat> ims);
#endif
vector<cv::Mat> hog_feature_normalization(vector<cv::Mat> &hog_feat_maps);
inline vector<cv::Mat> get_hog_feats() const { return hog_feat_maps_; }
vector<cv::Mat> get_cn_features(const vector<cv::Mat> ims);
vector<cv::Mat> cn_feature_normalization(vector<cv::Mat> &cn_feat_maps);
inline vector<cv::Mat> get_cn_feats() const { return cn_feat_maps_; }
#ifdef USE_CAFFE
ECO_FEATS get_cnn_layers(vector<cv::Mat> im, const cv::Mat &deep_mean_mat);
cv::Mat sample_pool(const cv::Mat &im, int smaple_factor, int stride);
void cnn_feature_normalization(ECO_FEATS &feature);
inline ECO_FEATS get_cnn_feats() const { return cnn_feat_maps_; }
#endif
private:
EcoParameters params_;
HogFeatures hog_features_;
int hog_feat_ind_ = -1;
vector<cv::Mat> hog_feat_maps_;
ColorspaceFeatures colorspace_features_;
int colorspace_feat_ind_ = -1;
vector<cv::Mat> colorspace_feat_maps_;
CnFeatures cn_features_;
int cn_feat_ind_ = -1;
vector<cv::Mat> cn_feat_maps_;
IcFeatures ic_features_;
int ic_feat_ind_ = -1;
vector<cv::Mat> ic_feat_maps_;
#ifdef USE_CAFFE
boost::shared_ptr<caffe::Net<float>> net_;
CnnFeatures cnn_features_;
int cnn_feat_ind_ = -1;
ECO_FEATS cnn_feat_maps_;
#endif
};
} // namespace eco
#endif
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。