JeVois  1.22
JeVois Smart Embedded Machine Vision Toolkit
Share this page:
Loading...
Searching...
No Matches
jevois::dnn::PostProcessorClassify Class Reference

#include <jevois/DNN/PostProcessorClassify.H>

Post-Processor for neural network pipeline.

This is the last step in a deep neural network processing Pipeline.

Definition at line 29 of file PostProcessorClassify.H.

Inheritance diagram for jevois::dnn::PostProcessorClassify:
Collaboration diagram for jevois::dnn::PostProcessorClassify:

Public Member Functions

virtual ~PostProcessorClassify ()
 Destructor.
 
void freeze (bool doit) override
 Freeze/unfreeze parameters that users should not change while running.
 
void process (std::vector< cv::Mat > const &outs, PreProcessor *preproc) override
 Process outputs and draw/send some results.
 
void report (jevois::StdModule *mod, jevois::RawImage *outimg=nullptr, jevois::OptGUIhelper *helper=nullptr, bool overlay=true, bool idle=false) override
 Report what happened in last process() to console/output video/GUI.
 
std::vector< ObjReco > const & latestRecognitions () const
 Get the latest recognition results, use with caution, not thread-safe.
 
- Public Member Functions inherited from jevois::dnn::PostProcessor
virtual ~PostProcessor ()
 Destructor.
 
- Public Member Functions inherited from jevois::Component
 Component (std::string const &instance)
 Constructor.
 
virtual ~Component ()
 Virtual destructor for safe inheritance.
 
template<class Comp , typename... Args>
std::shared_ptr< Comp > addSubComponent (std::string const &instance, Args &&...args)
 Pseudo-constructor: construct and add another component as a subcomponent of this one.
 
template<class Comp >
void removeSubComponent (std::shared_ptr< Comp > &component)
 Remove a sub-Component from this Component, by shared_ptr.
 
void removeSubComponent (std::string const &instance, bool warnIfNotFound=true)
 Remove a sub-Component from this Component, by instance name.
 
template<class Comp = jevois::Component>
std::shared_ptr< Comp > getSubComponent (std::string const &instance) const
 Get a sub-component by instance name.
 
bool isTopLevel () const
 Returns true if this component is top-level, i.e., its parent is jevois::Manager.
 
bool initialized () const
 Has this component been initialized yet?
 
std::string const & className () const
 The class name of this component.
 
std::string const & instanceName () const
 The instance name of this component.
 
template<typename T >
std::vector< std::string > setParamVal (std::string const &paramdescriptor, T const &val)
 Set a parameter value.
 
template<typename T >
void setParamValUnique (std::string const &paramdescriptor, T const &val)
 Set a parameter value, simple version assuming only one parameter match.
 
template<typename T >
std::vector< std::pair< std::string, T > > getParamVal (std::string const &paramdescriptor) const
 Get parameter(s) value(s) by descriptor.
 
template<typename T >
getParamValUnique (std::string const &paramdescriptor) const
 Get a parameter value, simple version assuming only one parameter match.
 
std::vector< std::string > setParamString (std::string const &paramdescriptor, std::string const &val)
 Set a parameter value, by string.
 
void setParamStringUnique (std::string const &paramdescriptor, std::string const &val)
 Set a parameter value by string, simple version assuming only one parameter match.
 
std::vector< std::pair< std::string, std::string > > getParamString (std::string const &paramdescriptor) const
 Get a parameter value, by string.
 
std::string getParamStringUnique (std::string const &paramdescriptor) const
 Get a parameter value by string, simple version assuming only one parameter match.
 
void freezeParam (std::string const &paramdescriptor, bool doit)
 Freeze/unfreeze a parameter, by name, see ParameterBase::freeze()
 
void freezeAllParams (bool doit)
 Freeze all parameters.
 
std::string descriptor () const
 Get our full descriptor (including all parents) as [Instancename]:[...]:[...].
 
void setParamsFromFile (std::string const &filename)
 Set some parameters from a file.
 
std::istream & setParamsFromStream (std::istream &is, std::string const &absfile)
 Set some parameters from an open stream.
 
virtual void paramInfo (std::shared_ptr< UserInterface > s, std::map< std::string, std::string > &categs, bool skipFrozen, std::string const &cname="", std::string const &pfx="")
 Get machine-oriented descriptions of all parameters.
 
void foreachParam (std::function< void(std::string const &compname, ParameterBase *p)> func, std::string const &cname="")
 Run a function on every param we hold.
 
template<typename T >
std::shared_ptr< DynamicParameter< T > > addDynamicParameter (std::string const &name, std::string const &description, T const &defaultValue, ParameterCategory const &category)
 Add a new parameter after the Component has already been constructed.
 
template<typename T , template< typename > class ValidValuesSpec>
std::shared_ptr< DynamicParameter< T > > addDynamicParameter (std::string const &name, std::string const &description, T const &defaultValue, ValidValuesSpec< T > const &validValuesSpec, ParameterCategory const &category)
 Add a new parameter after the Component has already been constructed.
 
template<typename T >
void setDynamicParameterCallback (std::string const &name, std::function< void(T const &)> cb, bool callnow=true)
 Register a callback with a previously created dynamic parameter.
 
void removeDynamicParameter (std::string const &name, bool throw_if_not_found=true)
 Remove a previously added dynamic parameter.
 
void setPath (std::string const &path)
 Assign a filesystem path to this component.
 
std::filesystem::path absolutePath (std::filesystem::path const &path="")
 If given path is relative (not starting with /), prepend the Component path to it.
 
- Public Member Functions inherited from jevois::ParameterRegistry
virtual ~ParameterRegistry ()
 Virtual destructor for safe inheritance.
 

Protected Member Functions

void onParamChange (postprocessor::classes const &param, std::string const &val) override
 
- Protected Member Functions inherited from jevois::Component
virtual void preInit ()
 Called before all sub-Components are init()ed.
 
virtual void postInit ()
 Called after all sub-Components are init()ed.
 
virtual void preUninit ()
 Called before all sub-Components are uninit()ed.
 
virtual void postUninit ()
 Called after all sub-Components are uninit()ed.
 
- Protected Member Functions inherited from jevois::ParameterRegistry
void addParameter (ParameterBase *const param)
 The Parameter class uses this method to register itself on construction with its owning Component.
 
void removeParameter (ParameterBase *const param)
 The Parameter class uses this method to un-register itself on destruction with its owning Component.
 
void callbackInitCall ()
 For all parameters that have a callback which has never been called, call it with the default param value.
 

Protected Attributes

std::map< int, std::string > itsLabels
 Mapping from object ID to class name.
 

Related Symbols

(Note that these are not member symbols.)

 JEVOIS_DECLARE_PARAMETER (classoffset, int, "Offset added to model output when looking up class name. Useful if " "your model uses a background class but your class file does not (use -1), or if your " "model does not use a background class but your class file has one (use 1). If unsure, " "use 0 and check whether reported class names are off.", 0, ParamCateg)
 Parameter.
 
 JEVOIS_DECLARE_PARAMETER_WITH_CALLBACK (classes, std::string, "Path to text file with names of object classes", "", ParamCateg)
 Parameter.
 
 JEVOIS_DECLARE_PARAMETER (top, unsigned int, "Max number of top-scoring predictions that score above " "threshold to report", 5, ParamCateg)
 Parameter.
 
 JEVOIS_DECLARE_PARAMETER (cthresh, float, "Classification threshold (in percent confidence) above which " "predictions will be reported", 20.0F, jevois::Range< float >(0.0F, 100.0F), ParamCateg)
 Parameter.
 
 JEVOIS_DECLARE_PARAMETER (softmax, bool, "Apply a softmax to classification outputs", false, ParamCateg)
 Parameter.
 
 JEVOIS_DECLARE_PARAMETER (scorescale, float, "Scaling factors applied to recognition scores. Mainly " "for debugging if your scores seem too high or too low. If too high, usually " "that means that you should turn on parameter softmax instead.", 1.0F, ParamCateg)
 Parameter.
 
 JEVOIS_DECLARE_PARAMETER (boxclamp, bool, "Clamp detection boxes to fit within the input image. Good to avoid " "having boxes that extend beyond the display and to be able to see object labels " "even on boxes that start at negative coordinates but will artificially reduce " "the size of detections that extend beyond the display", true, ParamCateg)
 Parameter.
 
 JEVOIS_DECLARE_PARAMETER (serialreport, bool, "Send classification or detection results to serial port", true, ParamCateg)
 Parameter.
 

Constructor & Destructor Documentation

◆ ~PostProcessorClassify()

jevois::dnn::PostProcessorClassify::~PostProcessorClassify ( )
virtual

Destructor.

Definition at line 27 of file PostProcessorClassify.C.

Member Function Documentation

◆ freeze()

void jevois::dnn::PostProcessorClassify::freeze ( bool  doit)
overridevirtual

Freeze/unfreeze parameters that users should not change while running.

Implements jevois::dnn::PostProcessor.

Definition at line 31 of file PostProcessorClassify.C.

◆ latestRecognitions()

std::vector< jevois::ObjReco > const & jevois::dnn::PostProcessorClassify::latestRecognitions ( ) const

Get the latest recognition results, use with caution, not thread-safe.

This returns a reference to our internal vector of recognitions. That vector will get overwritten every time process() is called. It is ok to use this after you have called process() on a given frame, or, if using a Pipeline, after you have called Pipeline::process(). Do not hold this ref past the end of the current video frame. If you need to keep a persistent copy of the data, make a deep copy of the vector.

Definition at line 134 of file PostProcessorClassify.C.

◆ onParamChange()

void jevois::dnn::PostProcessorClassify::onParamChange ( postprocessor::classes const &  param,
std::string const &  val 
)
overrideprotected

◆ process()

void jevois::dnn::PostProcessorClassify::process ( std::vector< cv::Mat > const &  outs,
PreProcessor preproc 
)
overridevirtual

Process outputs and draw/send some results.

Implements jevois::dnn::PostProcessor.

Definition at line 44 of file PostProcessorClassify.C.

References jevois::dnn::getLabel(), LERROR, LFATAL, o, jevois::dnn::softmax(), and jevois::dnn::topK().

◆ report()

void jevois::dnn::PostProcessorClassify::report ( jevois::StdModule mod,
jevois::RawImage outimg = nullptr,
jevois::OptGUIhelper helper = nullptr,
bool  overlay = true,
bool  idle = false 
)
overridevirtual

Report what happened in last process() to console/output video/GUI.

Implements jevois::dnn::PostProcessor.

Definition at line 83 of file PostProcessorClassify.C.

References jevois::GUIhelper::itext(), o, jevois::StdModule::sendSerialObjReco(), jevois::sformat(), jevois::yuyv::White, and jevois::rawimage::writeText().

Friends And Related Symbol Documentation

◆ JEVOIS_DECLARE_PARAMETER() [1/7]

JEVOIS_DECLARE_PARAMETER ( boxclamp  ,
bool  ,
"Clamp detection boxes to fit within the input image. Good to avoid " "having boxes that extend beyond the display and to be able to see object labels " "even on boxes that start at negative coordinates but will artificially reduce " "the size of detections that extend beyond the display"  ,
true  ,
ParamCateg   
)
related

Parameter.

◆ JEVOIS_DECLARE_PARAMETER() [2/7]

JEVOIS_DECLARE_PARAMETER ( classoffset  ,
int  ,
"Offset added to model output when looking up class name. Useful if " "your model uses a background class but your class file does not   use -1,
or if your " "model does not use a background class but your class file has one(use 1). If  unsure,
" "use 0 and check whether reported class names are off."  ,
,
ParamCateg   
)
related

Parameter.

◆ JEVOIS_DECLARE_PARAMETER() [3/7]

JEVOIS_DECLARE_PARAMETER ( cthresh  ,
float  ,
"Classification threshold (in percent confidence) above which " "predictions will be reported"  ,
20.  0F,
jevois::Range< float >  0.0F, 100.0F,
ParamCateg   
)
related

Parameter.

◆ JEVOIS_DECLARE_PARAMETER() [4/7]

JEVOIS_DECLARE_PARAMETER ( scorescale  ,
float  ,
"Scaling factors applied to recognition scores. Mainly " "for debugging if your scores seem too high or too low. If too  high,
usually " "that means that you should turn on parameter softmax instead."  ,
1.  0F,
ParamCateg   
)
related

Parameter.

◆ JEVOIS_DECLARE_PARAMETER() [5/7]

JEVOIS_DECLARE_PARAMETER ( serialreport  ,
bool  ,
"Send classification or detection results to serial port"  ,
true  ,
ParamCateg   
)
related

Parameter.

◆ JEVOIS_DECLARE_PARAMETER() [6/7]

JEVOIS_DECLARE_PARAMETER ( softmax  ,
bool  ,
"Apply a softmax to classification outputs"  ,
false  ,
ParamCateg   
)
related

Parameter.

◆ JEVOIS_DECLARE_PARAMETER() [7/7]

JEVOIS_DECLARE_PARAMETER ( top  ,
unsigned int  ,
"Max number of top-scoring predictions that score above " "threshold to report"  ,
,
ParamCateg   
)
related

Parameter.

◆ JEVOIS_DECLARE_PARAMETER_WITH_CALLBACK()

JEVOIS_DECLARE_PARAMETER_WITH_CALLBACK ( classes  ,
std::string  ,
"Path to text file with names of object classes"  ,
""  ,
ParamCateg   
)
related

Parameter.

Member Data Documentation

◆ itsLabels

std::map<int, std::string> jevois::dnn::PostProcessorClassify::itsLabels
protected

Mapping from object ID to class name.

Definition at line 62 of file PostProcessorClassify.H.


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