EnvObjDetBrain.C
00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038 #include "Component/ModelManager.H"
00039 #include "Image/ShapeOps.H"
00040 #include "Image/DrawOps.H"
00041 #include "Image/FilterOps.H"
00042 #include "Image/ColorOps.H"
00043 #include "Image/Transforms.H"
00044 #include "Image/MathOps.H"
00045 #include "Image/fancynorm.H"
00046 #include "Neuro/EnvVisualCortex.H"
00047 #include "Image/Image.H"
00048 #include "Image/CutPaste.H"
00049 #include "Image/Rectangle.H"
00050 #include "Image/MatrixOps.H"
00051 #include "Image/Convolutions.H"
00052 #include "nub/ref.h"
00053 #include "Util/Types.H"
00054 #include "Util/MathFunctions.H"
00055 #include "Util/log.H"
00056 #include "TestSuite/ObjDetBrain.h"
00057
00058
00059
00060 #include <stdio.h>
00061 #include <vector>
00062 #include <string>
00063
00064 struct ObjectDBData
00065 {
00066 char name[255];
00067 };
00068
00069 class EnvBrain : public ObjDetBrain
00070 {
00071
00072 public:
00073 EnvBrain(const int argc, const char **argv) :
00074 itsArgc(argc),
00075 itsArgv(argv)
00076 {
00077
00078 }
00079
00080 ~EnvBrain()
00081 {
00082 }
00083
00084 void preTraining()
00085 {
00086 }
00087
00088 void onTraining(Image<PixRGB<byte> > &img, ObjectData& objData)
00089 {
00090 }
00091
00092 void postTraining()
00093 {
00094 }
00095
00096
00097 void preDetection()
00098 {
00099 }
00100
00101 std::vector<DetLocation> onDetection(Image<PixRGB<byte> > &img)
00102 {
00103
00104 std::vector<DetLocation> smap;
00105
00106 if (img.getWidth() > 0 &&
00107 img.getHeight() > 0)
00108 {
00109
00110 ModelManager manager("Saliency ObjDet");
00111
00112 nub::ref<EnvVisualCortex> itsVcc(new EnvVisualCortex(manager));
00113 manager.addSubComponent(itsVcc);
00114
00115 manager.exportOptions(MC_RECURSE);
00116
00117
00118 if (manager.parseCommandLine( itsArgc, itsArgv, "", 0, 0) == false)
00119 LFATAL("Can not process args");
00120
00121 manager.start();
00122
00123
00124 itsVcc->input(img);
00125
00126 Image<float> vcxMap = itsVcc->getVCXmap();
00127 vcxMap = rescale(vcxMap, img.getDims());
00128
00129 for(int j=0; j<vcxMap.getHeight(); j++)
00130 for(int i=0; i<vcxMap.getWidth(); i++)
00131 {
00132 smap.push_back(DetLocation(i,j, vcxMap.getVal(i, j)));
00133 }
00134 manager.stop();
00135 }
00136
00137 return smap;
00138 }
00139
00140 void postDetection()
00141 {
00142 }
00143
00144 private:
00145 const int itsArgc;
00146 const char** itsArgv;
00147
00148
00149 };
00150
00151
00152 extern "C" ObjDetBrain* createObjDetBrain(const int argc, const char** argv)
00153 {
00154 return new EnvBrain(argc, argv);
00155 }
00156
00157 extern "C" void destoryObjDetBrain(ObjDetBrain* brain)
00158 {
00159 delete brain;
00160 }
00161
00162
00163 int main(const int argc, const char **argv)
00164 {
00165 LFATAL("Use test-ObjDet");
00166 return 0;
00167 }
00168
00169
00170
00171
00172
00173