#include #include #include #include "core/opencvutils.h" using namespace cv; namespace br { /*! * \ingroup transforms * \brief Computes integral image. * \author Josh Klontz \cite jklontz */ class IntegralTransform : public UntrainableTransform { Q_OBJECT void project(const Template &src, Template &dst) const { integral(src, dst); } }; BR_REGISTER(Transform, IntegralTransform) /*! * \ingroup transforms * \brief Sliding window feature extraction from a multi-channel integral image. * \author Josh Klontz \cite jklontz */ class IntegralSamplerTransform : public UntrainableTransform { Q_OBJECT Q_PROPERTY(int scales READ get_scales WRITE set_scales RESET reset_scales STORED false) Q_PROPERTY(float scaleFactor READ get_scaleFactor WRITE set_scaleFactor RESET reset_scaleFactor STORED false) Q_PROPERTY(float stepFactor READ get_stepFactor WRITE set_stepFactor RESET reset_stepFactor STORED false) Q_PROPERTY(int minSize READ get_minSize WRITE set_minSize RESET reset_minSize STORED false) BR_PROPERTY(int, scales, 4) BR_PROPERTY(float, scaleFactor, 1.5) BR_PROPERTY(float, stepFactor, 0.25) BR_PROPERTY(int, minSize, 8) void project(const Template &src, Template &dst) const { typedef Eigen::Map< const Eigen::Matrix > InputDescriptor; typedef Eigen::Map< Eigen::Matrix > OutputDescriptor; const Mat &m = src.m(); if (m.depth() != CV_32S) qFatal("Expected CV_32S matrix depth."); const int channels = m.channels(); const int rowStep = channels * m.cols; int descriptors = 0; int currentSize = min(m.rows, m.cols)-1; for (int scale=0; scale()/(currentSize*currentSize); index++; } } currentSize /= scaleFactor; if (currentSize < minSize) break; } if (descriptors != index) qFatal("Allocated %d descriptors but computed %d.", descriptors, index); dst.m() = n; } }; BR_REGISTER(Transform, IntegralSamplerTransform) /*! * \ingroup transforms * \brief Computes magnitude and/or angle of image. * \author Josh Klontz \cite jklontz */ class GradientTransform : public UntrainableTransform { Q_OBJECT Q_ENUMS(Channel) Q_PROPERTY(Channel channel READ get_channel WRITE set_channel RESET reset_channel STORED false) public: enum Channel { Magnitude, Angle, MagnitudeAndAngle }; private: BR_PROPERTY(Channel, channel, Angle) void project(const Template &src, Template &dst) const { if (src.m().type() != CV_8UC1) qFatal("Requires CV_8UC1 input."); Mat dx, dy, magnitude, angle; Sobel(src, dx, CV_32F, 1, 0); Sobel(src, dy, CV_32F, 0, 1); cartToPolar(dx, dy, magnitude, angle, true); if ((channel == Magnitude) || (channel == MagnitudeAndAngle)) dst.append(magnitude); if ((channel == Angle) || (channel == MagnitudeAndAngle)) dst.append(angle); } }; BR_REGISTER(Transform, GradientTransform) /*! * \ingroup transforms * \brief Projects each row based on a computed word. * \author Josh Klontz \cite jklontz */ class WordWiseTransform : public Transform { Q_OBJECT Q_PROPERTY(br::Transform* getWords READ get_getWords WRITE set_getWords RESET reset_getWords) Q_PROPERTY(br::Transform* byWord READ get_byWord WRITE set_byWord RESET reset_byWord) Q_PROPERTY(int numWords READ get_numWords WRITE set_numWords RESET reset_numWords) BR_PROPERTY(br::Transform*, getWords, NULL) BR_PROPERTY(br::Transform*, byWord, NULL) BR_PROPERTY(int, numWords, 0) void train(const TemplateList &data) { getWords->train(data); TemplateList bins; getWords->project(data, bins); numWords = 0; foreach (const Template &t, bins) { double minVal, maxVal; minMaxLoc(t, &minVal, &maxVal); numWords = max(numWords, int(maxVal)+1); } TemplateList reworded; reworded.reserve(data.size()); foreach (const Template &t, data) reworded.append(reword(t)); byWord->train(reworded); } void project(const Template &src, Template &dst) const { byWord->project(reword(src), dst); } Template reword(const Template &src) const { Template words; getWords->project(src, words); QVector wordCounts(numWords, 0); for (int i=0; i(i,0)]++; Template reworded(src.file); reworded.reserve(numWords); for (int i=0; i indicies(numWords, 0); for (int i=0; i(i,0); src.m().row(i).copyTo(reworded[word].row(indicies[word]++)); } return reworded; } }; BR_REGISTER(Transform, WordWiseTransform) } // namespace br #include "integral.moc"