InferotemporalCortexServiceMysql.H
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 #ifndef NEOVISIONII_InferotemporalCortexSERVICE_H_DEFINED
00039 #define NEOVISIONII_InferotemporalCortexSERVICE_H_DEFINED
00040
00041 #include <mysql++.h>
00042 #include <Ice/Ice.h>
00043 #include <Ice/Service.h>
00044 #include <IceUtil/Thread.h>
00045 #include <IceStorm/IceStorm.h>
00046 #include "Ice/BrainObjects.ice.H"
00047 #include "Ice/SimEvents.ice.H"
00048 #include "Ice/ImageIce.ice.H"
00049 #include "Ice/IceImageUtils.H"
00050 #include "Component/ModelManager.H"
00051 #include "Component/ModelComponent.H"
00052 #include "Component/ModelOptionDef.H"
00053 #include "Image/Image.H"
00054 #include "Media/FrameSeries.H"
00055 #include "Transport/FrameInfo.H"
00056 #include "Raster/GenericFrame.H"
00057 #include "SIFT/ScaleSpace.H"
00058 #include "SIFT/VisualObject.H"
00059 #include "SIFT/Keypoint.H"
00060 #include "SIFT/VisualObjectDB.H"
00061 #include "Util/CpuTimer.H"
00062
00063 class InferotemporalCortexI : public ModelComponent, public BrainObjects::InferotemporalCortex, public IceUtil::Thread
00064 {
00065 public:
00066 struct TopicInfo
00067 {
00068 TopicInfo(const char* _name, IceStorm::TopicPrx& prx) :
00069 name(_name), topicPrx(prx)
00070 {}
00071 std::string name;
00072 IceStorm::TopicPrx topicPrx;
00073 };
00074
00075 InferotemporalCortexI(OptionManager& mgr,
00076 nub::ref<OutputFrameSeries> ofs,
00077 const std::string& descrName = "InferotemporalCortexService",
00078 const std::string& tagName = "InferotemporalCortexService");
00079
00080 ~InferotemporalCortexI();
00081
00082 virtual void evolve(const SimEvents::EventMessagePtr& eMsg,
00083 const Ice::Current&);
00084
00085 virtual void run();
00086
00087 void initSimEvents(Ice::CommunicatorPtr icPtr, Ice::ObjectPrx objectPrx);
00088 void unsubscribeSimEvents();
00089
00090
00091
00092 bool initVDB();
00093
00094
00095 std::string getBestLabel(const size_t mincount);
00096
00097
00098 std::string matchObject(Image<PixRGB<byte> > &ima, float &score);
00099
00100
00101
00102
00103 private:
00104 nub::ref<OutputFrameSeries> itsOfs;
00105 SimEvents::EventsPrx itsEventsPub;
00106 std::vector<TopicInfo> itsTopicsSubscriptions;
00107 Ice::ObjectPrx itsObjectPrx;
00108 std::string itsVDBFile;
00109 VisualObjectDB itsVDB;
00110 bool itsUseColor;
00111 uint itsMaxLabelHistory;
00112 std::deque<std::string> itsRecentLabels;
00113 bool itsTrainingMode;
00114 mysqlpp::Connection *itsDBCon;
00115 Image<PixRGB<byte> > itsCurrentImg;
00116 IceUtil::Mutex itsImgMutex;
00117 CpuTimer itsTimer;
00118
00119
00120 };
00121
00122
00123
00124
00125
00126
00127
00128
00129 #endif // NEURO_ENVVISUALCORTEX_H_DEFINED