sft.cpp 6.03 KB
Newer Older
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
/*M///////////////////////////////////////////////////////////////////////////////////////
//
//  IMPORTANT: READ BEFORE DOWNLOADING, COPYING, INSTALLING OR USING.
//
//  By downloading, copying, installing or using the software you agree to this license.
//  If you do not agree to this license, do not download, install,
//  copy or use the software.
//
//
//                           License Agreement
//                For Open Source Computer Vision Library
//
// Copyright (C) 2000-2008, Intel Corporation, all rights reserved.
// Copyright (C) 2008-2012, Willow Garage Inc., all rights reserved.
// Third party copyrights are property of their respective owners.
//
// Redistribution and use in source and binary forms, with or without modification,
// are permitted provided that the following conditions are met:
//
//   * Redistribution's of source code must retain the above copyright notice,
//     this list of conditions and the following disclaimer.
//
//   * Redistribution's in binary form must reproduce the above copyright notice,
//     this list of conditions and the following disclaimer in the documentation
//     and/or other materials provided with the distribution.
//
//   * The name of the copyright holders may not be used to endorse or promote products
//     derived from this software without specific prior written permission.
//
// This software is provided by the copyright holders and contributors "as is" and
// any express or implied warranties, including, but not limited to, the implied
// warranties of merchantability and fitness for a particular purpose are disclaimed.
// In no event shall the Intel Corporation or contributors be liable for any direct,
// indirect, incidental, special, exemplary, or consequential damages
// (including, but not limited to, procurement of substitute goods or services;
// loss of use, data, or profits; or business interruption) however caused
// and on any theory of liability, whether in contract, strict liability,
// or tort (including negligence or otherwise) arising in any way out of
// the use of this software, even if advised of the possibility of such damage.
//
//M*/

43
// Training application for Soft Cascades.
44 45

#include <sft/common.hpp>
46
#include <iostream>
47
#include <sft/dataset.hpp>
48
#include <sft/config.hpp>
49

marina.kolpakova's avatar
marina.kolpakova committed
50 51
#include <opencv2/core/core_c.h>

52 53
int main(int argc, char** argv)
{
54
    using namespace sft;
marina.kolpakova's avatar
marina.kolpakova committed
55

56 57 58 59
    const string keys =
        "{help h usage ? |      | print this message              }"
        "{config c       |      | path to configuration xml       }"
    ;
60

61 62
    cv::CommandLineParser parser(argc, argv, keys);
    parser.about("Soft cascade training application.");
63

64 65 66 67 68
    if (parser.has("help"))
    {
        parser.printMessage();
        return 0;
    }
69

70 71 72 73 74
    if (!parser.check())
    {
        parser.printErrors();
        return 1;
    }
75

76 77 78
    string configPath = parser.get<string>("config");
    if (configPath.empty())
    {
79
        std::cout << "Configuration file is missing or empty. Could not start training." << std::endl;
80 81
        return 0;
    }
82

83 84 85 86
    std::cout << "Read configuration from file " << configPath << std::endl;
    cv::FileStorage fs(configPath, cv::FileStorage::READ);
    if(!fs.isOpened())
    {
87
        std::cout << "Configuration file " << configPath << " can't be opened." << std::endl;
88 89
        return 1;
    }
90

91 92 93 94
    // 1. load config
    sft::Config cfg;
    fs["config"] >> cfg;
    std::cout << std::endl << "Training will be executed for configuration:" << std::endl << cfg << std::endl;
95

96 97
    // 2. check and open output file
    cv::FileStorage fso(cfg.outXmlPath, cv::FileStorage::WRITE);
marina.kolpakova's avatar
marina.kolpakova committed
98
    if(!fso.isOpened())
99
    {
100
        std::cout << "Training stopped. Output classifier Xml file " << cfg.outXmlPath << " can't be opened." << std::endl;
101 102
        return 1;
    }
103

marina.kolpakova's avatar
marina.kolpakova committed
104 105 106
    fso << cfg.cascadeName
        << "{"
        << "stageType"   << "BOOST"
107
        << "featureType" << cfg.featureType
marina.kolpakova's avatar
marina.kolpakova committed
108 109 110 111 112 113
        << "octavesNum"  << (int)cfg.octaves.size()
        << "width"       << cfg.modelWinSize.width
        << "height"      << cfg.modelWinSize.height
        << "shrinkage"   << cfg.shrinkage
        << "octaves"     << "[";

114 115 116
    // 3. Train all octaves
    for (ivector::const_iterator it = cfg.octaves.begin(); it != cfg.octaves.end(); ++it)
    {
117
        // a. create random feature pool
118
        int nfeatures  = cfg.poolSize;
marina.kolpakova's avatar
marina.kolpakova committed
119 120
        cv::Size model = cfg.model(it);
        std::cout << "Model " << model << std::endl;
121 122 123 124 125 126

        int nchannels = (cfg.featureType == "HOG6MagLuv") ? 10: 8;

        std::cout << "number of feature channels is " << nchannels << std::endl;

        cv::Ptr<cv::FeaturePool> pool = cv::FeaturePool::create(model, nfeatures, nchannels);
127
        nfeatures = pool->size();
marina.kolpakova's avatar
marina.kolpakova committed
128 129


130 131 132
        int npositives = cfg.positives;
        int nnegatives = cfg.negatives;
        int shrinkage  = cfg.shrinkage;
marina.kolpakova's avatar
marina.kolpakova committed
133 134
        cv::Rect boundingBox = cfg.bbox(it);
        std::cout << "Object bounding box" << boundingBox << std::endl;
135

136
        typedef cv::Octave Octave;
137

138 139
        cv::Ptr<cv::ChannelFeatureBuilder> builder = cv::ChannelFeatureBuilder::create(cfg.featureType);
        std::cout << "Channel builder " << builder->info()->name() << std::endl;
140
        cv::Ptr<Octave> boost = Octave::create(boundingBox, npositives, nnegatives, *it, shrinkage, builder);
141

marina.kolpakova's avatar
marina.kolpakova committed
142
        std::string path = cfg.trainPath;
143
        sft::ScaledDataset dataset(path, *it);
144

145
        if (boost->train(&dataset, pool, cfg.weaks, cfg.treeDepth))
146
        {
marina.kolpakova's avatar
marina.kolpakova committed
147
            CvFileStorage* fout = cvOpenFileStorage(cfg.resPath(it).c_str(), 0, CV_STORAGE_WRITE);
148
            boost->write(fout, cfg.cascadeName);
marina.kolpakova's avatar
marina.kolpakova committed
149

marina.kolpakova's avatar
marina.kolpakova committed
150 151 152
            cvReleaseFileStorage( &fout);

            cv::Mat thresholds;
153
            boost->setRejectThresholds(thresholds);
marina.kolpakova's avatar
marina.kolpakova committed
154

155
            boost->write(fso, pool, thresholds);
marina.kolpakova's avatar
marina.kolpakova committed
156 157 158 159 160

            cv::FileStorage tfs(("thresholds." + cfg.resPath(it)).c_str(), cv::FileStorage::WRITE);
            tfs << "thresholds" << thresholds;

            std::cout << "Octave " << *it << " was successfully trained..." << std::endl;
marina.kolpakova's avatar
marina.kolpakova committed
161
        }
162
    }
163

marina.kolpakova's avatar
marina.kolpakova committed
164
    fso << "]" << "}";
165
    fso.release();
166 167
    std::cout << "Training complete..." << std::endl;
    return 0;
168
}