VisualTrackerService.H

00001 /*!@file Neuro/VisualTrackerService.H */
00002 
00003 // //////////////////////////////////////////////////////////////////// //
00004 // The iLab Neuromorphic Vision C++ Toolkit - Copyright (C) 2000-2005   //
00005 // by the University of Southern California (USC) and the iLab at USC.  //
00006 // See http://iLab.usc.edu for information about this project.          //
00007 // //////////////////////////////////////////////////////////////////// //
00008 // Major portions of the iLab Neuromorphic Vision Toolkit are protected //
00009 // under the U.S. patent ``Computation of Intrinsic Perceptual Saliency //
00010 // in Visual Environments, and Applications'' by Christof Koch and      //
00011 // Laurent Itti, California Institute of Technology, 2001 (patent       //
00012 // pending; application number 09/912,225 filed July 23, 2001; see      //
00013 // http://pair.uspto.gov/cgi-bin/final/home.pl for current status).     //
00014 // //////////////////////////////////////////////////////////////////// //
00015 // This file is part of the iLab Neuromorphic Vision C++ Toolkit.       //
00016 //                                                                      //
00017 // The iLab Neuromorphic Vision C++ Toolkit is free software; you can   //
00018 // redistribute it and/or modify it under the terms of the GNU General  //
00019 // Public License as published by the Free Software Foundation; either  //
00020 // version 2 of the License, or (at your option) any later version.     //
00021 //                                                                      //
00022 // The iLab Neuromorphic Vision C++ Toolkit is distributed in the hope  //
00023 // that it will be useful, but WITHOUT ANY WARRANTY; without even the   //
00024 // implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR      //
00025 // PURPOSE.  See the GNU General Public License for more details.       //
00026 //                                                                      //
00027 // You should have received a copy of the GNU General Public License    //
00028 // along with the iLab Neuromorphic Vision C++ Toolkit; if not, write   //
00029 // to the Free Software Foundation, Inc., 59 Temple Place, Suite 330,   //
00030 // Boston, MA 02111-1307 USA.                                           //
00031 // //////////////////////////////////////////////////////////////////// //
00032 //
00033 // Primary maintainer for this file: Lior Elazary
00034 // $HeadURL: svn://isvn.usc.edu/software/invt/trunk/saliency/src/NeovisionII/VisualTrackerService.H $
00035 // $Id: VisualTrackerService.H 12281 2009-12-17 09:00:36Z itti $
00036 //
00037 
00038 #ifndef NEOVISIONII_VISUALTRACERSERVICE_H_DEFINED
00039 #define NEOVISIONII_VISUALTRACERSERVICE_H_DEFINED
00040 
00041 #include <Ice/Ice.h>
00042 #include <Ice/Service.h>
00043 #include <IceUtil/Thread.h>
00044 #include <IceStorm/IceStorm.h>
00045 #include "Ice/BrainObjects.ice.H"
00046 #include "Image/OpenCVUtil.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 
00058 class VisualTrackerI : public ModelComponent, public BrainObjects::VisualTracker
00059 {
00060 public:
00061   struct TopicInfo
00062   {
00063     TopicInfo(const char* _name, IceStorm::TopicPrx& prx) :
00064       name(_name), topicPrx(prx)
00065     {}
00066     std::string name;
00067     IceStorm::TopicPrx topicPrx;
00068   };
00069 
00070   VisualTrackerI(OptionManager& mgr,
00071         const std::string& descrName = "VisualTrackerService",
00072         const std::string& tagName = "VisualTrackerService");
00073 
00074   ~VisualTrackerI();
00075 
00076   virtual void evolve(const SimEvents::EventMessagePtr& eMsg,
00077       const Ice::Current&);
00078 
00079   void initSimEvents(Ice::CommunicatorPtr icPtr, Ice::ObjectPrx objectPrx); //Init the SimEvents by attaching to a topic and getting a messagePrx
00080   void unsubscribeSimEvents();
00081 
00082   //tracker methods
00083   void initTracker(Dims imageDims, int nPoints = 1, int wz = 10);
00084   void setTargets(const Image<byte>& grey);
00085   Point2D<int> trackObjects(const Image<byte>& grey);
00086 
00087 
00088 
00089 private:
00090   OModelParam<int> itsTrackIOR; //number of frames to wait before disengaging the tracker
00091 
00092   SimEvents::EventsPrx itsEventsPub; //the Event publisher
00093   std::vector<TopicInfo> itsTopicsSubscriptions; //out subscription to the various topics
00094   Ice::ObjectPrx itsObjectPrx; //Our proxy
00095   bool itsInitTracker; //do we need to init the tracker
00096   bool itsInitTargets; //initalize the target
00097   bool itsTracking; //Are we tracking anything
00098   SimEvents::TrackInfoSeq itsTrackLocs;
00099   unsigned long itsTrackFrames; //the number of frames we have been tracking
00100 
00101 #ifdef HAVE_OPENCV
00102     int win_size;
00103     int MAX_COUNT;
00104     int count;
00105     CvPoint2D32f* points[2], *swap_points;
00106     IplImage *pyramid;
00107     IplImage *prev_pyramid;
00108     Image<byte> prev_grey;
00109     char* status;
00110     float* track_error;
00111     int flags;
00112 #endif
00113 
00114 
00115 };
00116 
00117 // ######################################################################
00118 /* So things look consistent in everyone's emacs... */
00119 /* Local Variables: */
00120 /* mode: c++ */
00121 /* indent-tabs-mode: nil */
00122 /* End: */
00123 
00124 #endif // NEURO_ENVVISUALCORTEX_H_DEFINED
Generated on Sun May 8 08:41:02 2011 for iLab Neuromorphic Vision Toolkit by  doxygen 1.6.3