AURobotServers  4
Public Member Functions | Protected Member Functions | Private Attributes | Static Private Attributes | List of all members
UFuncPiPi Class Reference
Inheritance diagram for UFuncPiPi:
Inheritance graph

Public Member Functions

virtual bool handleCommand (UServerInMsg *msg, void *extra)
 
 UFuncPiPi ()
 
virtual ~UFuncPiPi ()
 
- Public Member Functions inherited from UFunctionCamBase
virtual void createResources ()
 
UImagegetImage (UServerInMsg *msg, void *extra)
 
virtual bool setResource (UResBase *ressource, bool remove)
 
 UFunctionCamBase ()
 
virtual ~UFunctionCamBase ()
 
- Public Member Functions inherited from UFunctionImgBase
virtual void setCmdHandler (UCmdExe *cmdExe)
 
void showImagesAsDefault (bool show)
 
 UFunctionImgBase ()
 
virtual ~UFunctionImgBase ()
 
- Public Member Functions inherited from UFunctionBase
bool addResource (UResBase *resource, UFunctionBase *owner)
 
void closeLogfile ()
 
virtual const char * commandList ()
 
const char * getAliasName ()
 
const char * getLoadedFileName ()
 
void * getLoadedModuleRef ()
 
virtual bool gotAllResources (char *missingThese, int missingTheseCnt)
 
bool isMine (const char *cmdName)
 
bool isStatic ()
 is the module loaded as static A module is static if the ldFilename has a length of zero. More...
 
virtual const char * name ()
 
bool newCmd (UServerInMsg *newMsg, UDataBase *extra)
 
bool newCommand (UServerInMsg *newMsg, void *extra)
 
bool openLogfile (const char *name)
 
void print (const char *preString)
 
virtual void resourceUpdated ()
 
bool sendEndTag (UServerInMsg *msg)
 
bool sendEndTag ()
 
bool sendFullTag (const char *attributes)
 
bool sendHelpDone (UServerInMsg *msg)
 
bool sendHelpDone ()
 
bool sendHelpStart (UServerInMsg *msg, const char *subject)
 
bool sendHelpStart (const char *subject)
 
bool sendHelpStart ()
 
bool sendMsg (UServerInMsg *msg, const char *message, int size)
 
bool sendMsg (const char *message)
 
bool sendMsg (UServerInMsg *msg, const char *message)
 
bool sendMsg (int clientIdx, const char *message, int size)
 
bool sendMsgInt (int clientIdx, const char *message)
 
bool sendStartTag (const char *attributes)
 
bool sendText (UServerInMsg *msg, const char *text)
 
bool sendText (const char *text)
 
virtual void setAliasName (const char *name)
 
virtual void setCommand (const char *cmdList, const char *name, const char *note)
 
void setLoadedModuleRef (void *module, const char *moduleFileName)
 
virtual void setLoadTime (UTime)
 
void setName (const char *name)
 
void setVerbose (bool value)
 
 UFunctionBase ()
 
virtual ~UFunctionBase ()
 
- Public Member Functions inherited from UCallBack
bool addOnEvent (UOnEvent *dataObject)
 
virtual bool onEvent (const char *interface, const char *dataType, void *data)
 
 UCallBack ()
 
virtual ~UCallBack ()
 
- Public Member Functions inherited from UResVarPool
int addMethod (const char *formalName, const char *paramTypes, const char *comment)
 
int addMethodV (const char *formalName, const char *paramTypes, const char *comment)
 
UVarPooladdStruct (const char *name, const char *comment, bool copy=false)
 
UVariableaddVar (const char *name, const double initialValue, const char *type, const char *comment)
 
UVariableaddVar (const char *name, const char *initialValue, const char *type, const char *comment)
 
UVariableaddVarA (const char *name, const char *initialValue, const char *type, const char *comment)
 
bool callGlobal (const char *name, const char *paramOrder, char **strings, const double *doubles, double *value, UDataBase **returnStruct, int *returnStructCnt)
 
bool callGlobalV (const char *name, const char *paramOrder, UVariable **params, UDataBase **returnStruct, int *returnStructCnt)
 Call a method from the root var pool scope It may be in the structure direct (no '.') or in any sub-structure that the 'name.subname' indicate. More...
 
bool callLocal (const char *name, const char *paramOrder, char **strings, const double *doubles, double *value, UDataBase **returnStruct, int *returnStructCnt)
 
bool callVS (const char *function, const char *stringParam)
 
int callVSCD (const char *function, const char *strPar, UDataBase *data, int cooSys)
 
void createBaseVar ()
 
virtual bool createVarSpace (const int varCnt, const int structCnt, const int methCnt, const char *note, bool copy=false)
 
bool getGlobalString (const char *name, const char **value)
 
bool getGlobalValue (const char *name, double *value)
 
bool getGlobalValue (const char *name, const char **value)
 
bool getGlobalValue (const char *name, bool *value)
 
bool getGlobalValue (const char *name, UTime *value)
 
bool getLocalValue (const char *name, double *value)
 get a value in this variable tree More...
 
bool getLocalValue (const char *name, bool *value)
 
bool getLocalValue (const char *name, UTime *value)
 
double getLocalValue (int idx)
 
UPosition getLocalValue3D (int idx)
 
UPosRot getLocalValue6D (int idx)
 
bool getLocalValueBool (int idx)
 
int getLocalValueInt (int idx)
 
UTime getLocalValueTime (int idx)
 
const char * getLogFileName ()
 
const char * getVarDescription (int idx)
 
UVarCalcgetVarPool ()
 
bool isLogFileOpen ()
 
bool isLogFileOpen (const char *structName)
 
bool isVarPoolUpdated (int lastCnt, int *newCnt)
 
void logFileClose ()
 
bool logFileOpen ()
 
void logFileStart (const char *structName, bool open)
 
virtual bool methodCall (const char *name, const char *paramOrder, char **strings, const double *doubles, double *value, UDataBase **returnStruct=NULL, int *returnStructCnt=NULL)
 
virtual const char * print (const char *preString, char *buff, int buffCnt)
 
bool setGlobalVar (const char *name, const double value, bool mayAdd)
 Assigns a value to a variable. The variable may be a part of a structure. More...
 
bool setLocalVar (int idx, double value, const int element)
 
bool setLocalVar (const char *name, const double value, bool mayAdd)
 Assigns a value to a variable. The variable may be a part of a structure. More...
 
bool setLocalVar3D (int idx, UPosition *value)
 
bool setLocalVar6D (int idx, UPosRot *value)
 
bool setLocalVarAdd (int idx, double value, const int element)
 
bool setLocalVarPose (int idx, UPose *value)
 
void setVarPool (UVarCalc *sharedVarPool)
 
int updateQTvars (int structIdx)
 
 UResVarPool ()
 
virtual ~UResVarPool ()
 
- Public Member Functions inherited from UResBase
void createReplayVar (UVarPool *pool)
 
UCmdExegetCorePointer ()
 
char * getLogFileName (char *fn, const int fnCnt)
 
int getResFuncIdx ()
 
const char * getResID ()
 
int getResVersion ()
 
bool isA (const char *idStr)
 
bool isAlsoA (const char *id)
 
virtual void saveSettings ()
 
void setCorePointer (UCmdExe *serverCore)
 
void setResFuncIdx (int idx)
 
virtual void setResID (const char *id, const int version)
 
virtual void stop (bool)
 
virtual void updateReplayStatus ()
 
 UResBase ()
 
virtual ~UResBase ()
 
- Public Member Functions inherited from UReplay
void addChild (UReplay *child)
 
virtual bool decodeReplayLine (char *)
 
char * getLogFileName (char *fn, const int fnCnt)
 
char * getReplayFileName (char *fn, const int fnCnt)
 
int getReplayLogLine ()
 
bool isReplay ()
 
bool isReplayFileOpen ()
 
void removeChild (UReplay *child)
 
virtual void replayAdvanceTime (UTime untilTime)
 
void replaySetBaseFileName (const char *name, const char *preName="")
 
void replaySetFileName (const char *name)
 
virtual bool replayStep ()
 
int replayStep (int steps)
 
virtual bool replayToTime (UTime untilTime)
 
void setParent (UReplay *parent)
 
bool setReplay (bool value)
 
 UReplay ()
 
virtual ~UReplay ()
 
- Public Member Functions inherited from ULock
bool lock ()
 
void lockInit ()
 
void post ()
 
bool tryLock ()
 
bool tryWait ()
 
 ULock ()
 
void unlock ()
 
bool wait ()
 
 ~ULock ()
 
- Public Member Functions inherited from UVarMethodImplement
virtual bool methodCallV (const char *name, const char *paramOrder, UVariable *params[], UDataBase **returnStruct, int *returnStructCnt)
 
virtual ~UVarMethodImplement ()
 

Protected Member Functions

bool calculateBallPosition (UImage *ellImg, int camCnt)
 
void createBaseVar ()
 
void filterMask (UImage *src, UImage *dst)
 
bool findBall (UImage *img, bool debug, int camCnt)
 
bool findBallCandidates (UImage *img, UImage *ellImg)
 
int getCnt ()
 
void maskColors (UImage *srcImg, UImage *dstImg)
 
- Protected Member Functions inherited from UFunctionCamBase
UCamPushgetCam (int imgDevice, const char *posName)
 
UCamPushgetCam (int camDevNum)
 
bool getCamAndRawImage (UCamPush **cam, UImage **imgRaw, int *imgDevice, void *imgBase, const char *posName, int rectfiedImg)
 
int getDefaultCamDevice ()
 
- Protected Member Functions inherited from UFunctionImgBase
bool sendImage (UServerInMsg *msg, const char *tagName, UImage *imgRgb, int imgLeft=0, int imgTop=0, int imgWidth=640, int imgHeight=480, int imgSource=-1, bool isCodecBin=true, bool imgIsBW=false, bool imgGetNum=true, bool imgGetTod=true, bool imgGetTime=false, const char *posName=NULL, bool imgGetName=true, bool silent=false)
 
- Protected Member Functions inherited from UFunctionBase
int getCmdIndex ()
 
UResBasegetStaticResource (const char *resName, bool mayCreate, bool staticOnly=true)
 get a pointer to a static resource. More...
 
bool isClientAlive (int clientIdx, double holdOffTime)
 
bool sendDebug (UServerInMsg *msg, const char *debugText)
 
bool sendDebug (const char *debugText)
 
bool sendError (UServerInMsg *msg, const char *errorText)
 
bool sendError (const char *errorText)
 
bool sendHelp (UServerInMsg *msg, const char *infoText)
 
bool sendHelp (const char *infoText)
 
bool sendInfo (UServerInMsg *msg, const char *infoText)
 
bool sendInfo (const char *infoText)
 
bool sendWarning (UServerInMsg *msg, const char *warningText)
 
bool sendWarning (const char *warningText)
 
UResBasesetThisResource (const char *ID, UResBase *resource, bool remove, bool *changed, UResBase *currentResPtr, bool *isLocal)
 
- Protected Member Functions inherited from UResVarPool
void setDescription (const char *note, bool copy=false)
 
- Protected Member Functions inherited from UResBase
UResBasegetStaticResource (const char *resName, bool mayCreate, bool staticOnly=true)
 get a pointer to a static resource. More...
 

Private Attributes

float ballPos [MAX_CAM_CNT][2]
 most likely ball position in image coordinates (x,y) More...
 
UTime ballTime [MAX_CAM_CNT]
 timage time for source images More...
 
CvBox2D32f ell [MAX_ELL_CNT]
 resulting ellipses found in image More...
 
int ellCnt
 number of ellipses found More...
 
UTime refTime
 reference time More...
 
UVariablevarMajMinRatio
 minimum ratio metween major and minor axis of ellipse More...
 
UVariablevarMaxSize
 Maximum size for an estimated ball. More...
 
UVariablevarMinSize
 Maximum size for an estimated ball. More...
 
UVariablevarPoolImg
 pointer to temporary images to use More...
 
UVariablevarRedCnt
 pointer to number of balls found in image More...
 
UVariablevarRedLim
 pointer to limiting red values redMin, redMax, greenMin, greenMax More...
 
UVariablevarRedTime
 pointer to time of detection More...
 
UVariablevarSourceImg
 pointer to to source images More...
 
UVariablevarTopLine
 topmost line in image More...
 

Static Private Attributes

static const int MAX_CAM_CNT = 4
 max number of ball positions */ More...
 
static const int MAX_ELL_CNT = 100
 

Additional Inherited Members

- Static Public Member Functions inherited from UResVarPool
static const char * getResClassID ()
 
- Public Attributes inherited from UFunctionBase
bool silent
 is reply to client and console to be limited More...
 
- Public Attributes inherited from UReplay
bool replayTimeAdvancePending
 
UTime replayTimeNow
 
- Static Public Attributes inherited from UFunctionBase
static const int MAX_ID_LENGTH = 30
 
static const int MAX_RESOURCE_LIST_SIZE = 250
 
- Protected Attributes inherited from UFunctionCamBase
UCamPoolcamPool
 
- Protected Attributes inherited from UFunctionImgBase
UImagePoolimgPool
 
- Protected Attributes inherited from UFunctionBase
char aliasName [MAX_ID_LENGTH]
 
UCmdExecmdHandler
 
char * cmdToks [20]
 
int cmdToksCnt
 
char commandsHandled [MAX_RESOURCE_LIST_SIZE]
 
UServerInMsgmsg
 
char pluginName [MAX_RESOURCE_LIST_SIZE]
 
bool verboseMessages
 
- Protected Attributes inherited from UResBase
int resFuncIdx
 
char resID [MAX_RESOURCE_ID_LENGTH]
 
char resIsAlso [MAX_RESOURCE_ISALSO_LENGTH]
 
int resVersion
 
- Protected Attributes inherited from UReplay
bool replay
 
FILE * replayFile
 
char replayFileName [REPLAY_FILE_NAME_LENGTH]
 replay filename More...
 
char replayLine [MAX_LOG_LINE_LENGTH]
 
int replayLogLine
 
UReplayreplayParent
 
UTime replayTimeNext
 
- Static Protected Attributes inherited from UReplay
static const int MAX_LOG_LINE_LENGTH = 10000
 
static const int REPLAY_FILE_NAME_LENGTH = 264
 max length of replay filename More...
 

Detailed Description

Example plugin to find balls in camera image

Author
Christian Andersen

Constructor & Destructor Documentation

UFuncPiPi::UFuncPiPi ( )
inline
virtual UFuncPiPi::~UFuncPiPi ( )
inlinevirtual

Destructor - to delete the resource (etc) when finished

Member Function Documentation

bool UFuncPiPi::calculateBallPosition ( UImage ellImg,
int  camCnt 
)
inlineprotected

Find the best of the estimated ball candidate and calculate the ball position relalive to the robot. Expect estimate ellipses that may be balls in the array 'ell' with ellCnt ellipses found. The result is converted to first camera coordinates using the camera focal length and a known ball size. There is no radial error correction applied, so some error must be expected. The camera coordinates are transformed to robot coordinates using a known camera pose (from the camera structure). The result is saved in the 'ballPos' variable in meters relative to the robot. If the ball is close to the edge of the image and partially out of the image, then one of the flags isOutL or isOutR is set to true.

Parameters
ellImgoptional image for debug paint, emmits also more printout to console
camCntis the current camera number
Returns
true if possible - and if true, then the ballPos, isOutL and isOutR is set.

References ballPos, UImage::cvArr(), ell, and ellCnt.

Referenced by findBall().

void UFuncPiPi::createBaseVar ( )
inlineprotected

Make the variables that will be available to other plugins

References UResVarPool::addVar(), varMajMinRatio, varMaxSize, varMinSize, varPoolImg, varRedCnt, varRedLim, varRedTime, varSourceImg, and varTopLine.

Referenced by UFuncPiPi().

void UFuncPiPi::filterMask ( UImage src,
UImage dst 
)
inlineprotected

filter the image. Source and destination image may be the same.

Parameters
srcis the source image
dstis the destination image

References UImage::copyMeta(), UImage::cvArr(), UImagePool::getImage(), UVariable::getInt(), UFunctionBase::getStaticResource(), UFunctionImgBase::imgPool, and varPoolImg.

Referenced by findBall().

bool UFuncPiPi::findBall ( UImage img,
bool  debug,
int  camCnt 
)
inlineprotected

Find red ball in image, using parameters from global var pool

Parameters
imgis a pointer to the image to be analized
debugif true, then more images are producen in the image pool
blueif true, then the blue color values are used (else the red values)
Returns
true if at least one red ball is found

References ballTime, calculateBallPosition(), UImage::copy(), ellCnt, filterMask(), findBallCandidates(), UTime::getDecSec(), UImagePool::getImage(), UVariable::getInt(), UFunctionBase::getStaticResource(), UFunctionImgBase::imgPool, UImage::imgTime, maskColors(), UImage::setName(), UVariable::setValued(), UImage::tone(), UImage::updated(), varPoolImg, varRedCnt, and varRedTime.

Referenced by handleCommand().

bool UFuncPiPi::findBallCandidates ( UImage img,
UImage ellImg 
)
inlineprotected

Find balls in this image. This function is almost a direct copy of the 'fitellipse.c' example from the opencv package.

Parameters
imgis a pointer to a BW mask image with interesting pixels beeing > 0
ellImgoptional image where found ellipses are drawn (for debug)
Returns
true if at least one ball candidate is found.

References UImage::cvArr(), ell, ellCnt, UVariable::getDouble(), UVariable::getInt(), MAX_ELL_CNT, varMajMinRatio, varMaxSize, and varMinSize.

Referenced by findBall().

int UFuncPiPi::getCnt ( )
inlineprotected

Get number of balls found in image

References ellCnt.

virtual bool UFuncPiPi::handleCommand ( UServerInMsg msg,
void *  extra 
)
inlinevirtual
void UFuncPiPi::maskColors ( UImage srcImg,
UImage dstImg 
)
inlineprotected

Find balls in this image. This function is almost a direct copy of the 'fitellipse.c' example from the opencv package.

Parameters
srcImgis a pointer to the image to be analized
dstImgis where the pixels with the ball color is saved.
debugif true, then more images are producen in the image pool

References UImage::copyMeta(), UImage::getHeight(), UVariable::getInt(), UImage::getLine(), UImage::getWidth(), UImage::isYUV(), UPixel::p2, UPixel::p3, UImage::setName(), UImage::setSize(), UImage::toYUV(), UImage::updated(), UResBase::var, varRedLim, and varTopLine.

Referenced by findBall().

Member Data Documentation

float UFuncPiPi::ballPos[MAX_CAM_CNT][2]
private

most likely ball position in image coordinates (x,y)

Referenced by calculateBallPosition(), and handleCommand().

UTime UFuncPiPi::ballTime[MAX_CAM_CNT]
private

timage time for source images

Referenced by findBall(), and handleCommand().

CvBox2D32f UFuncPiPi::ell[MAX_ELL_CNT]
private

resulting ellipses found in image

Referenced by calculateBallPosition(), and findBallCandidates().

int UFuncPiPi::ellCnt
private

number of ellipses found

Referenced by calculateBallPosition(), findBall(), findBallCandidates(), getCnt(), and UFuncPiPi().

const int UFuncPiPi::MAX_CAM_CNT = 4
staticprivate

max number of ball positions */

const int UFuncPiPi::MAX_ELL_CNT = 100
staticprivate

Referenced by findBallCandidates().

UTime UFuncPiPi::refTime
private

reference time

Referenced by handleCommand(), and UFuncPiPi().

UVariable* UFuncPiPi::varMajMinRatio
private

minimum ratio metween major and minor axis of ellipse

Referenced by createBaseVar(), and findBallCandidates().

UVariable* UFuncPiPi::varMaxSize
private

Maximum size for an estimated ball.

Referenced by createBaseVar(), and findBallCandidates().

UVariable* UFuncPiPi::varMinSize
private

Maximum size for an estimated ball.

Referenced by createBaseVar(), and findBallCandidates().

UVariable* UFuncPiPi::varPoolImg
private

pointer to temporary images to use

Referenced by createBaseVar(), filterMask(), and findBall().

UVariable* UFuncPiPi::varRedCnt
private

pointer to number of balls found in image

Referenced by createBaseVar(), and findBall().

UVariable* UFuncPiPi::varRedLim
private

pointer to limiting red values redMin, redMax, greenMin, greenMax

Referenced by createBaseVar(), and maskColors().

UVariable* UFuncPiPi::varRedTime
private

pointer to time of detection

Referenced by createBaseVar(), and findBall().

UVariable* UFuncPiPi::varSourceImg
private

pointer to to source images

Referenced by createBaseVar(), and handleCommand().

UVariable* UFuncPiPi::varTopLine
private

topmost line in image

Referenced by createBaseVar(), and maskColors().


The documentation for this class was generated from the following file: