JeVois  1.22
JeVois Smart Embedded Machine Vision Toolkit
Share this page:
Loading...
Searching...
No Matches
PostProcessorClassify.H
Go to the documentation of this file.
1// ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////
2//
3// JeVois Smart Embedded Machine Vision Toolkit - Copyright (C) 2021 by Laurent Itti, the University of Southern
4// California (USC), and iLab at USC. See http://iLab.usc.edu and http://jevois.org for information about this project.
5//
6// This file is part of the JeVois Smart Embedded Machine Vision Toolkit. This program is free software; you can
7// redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software
8// Foundation, version 2. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
9// without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public
10// License for more details. You should have received a copy of the GNU General Public License along with this program;
11// if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
12//
13// Contact information: Laurent Itti - 3641 Watt Way, HNB-07A - Los Angeles, CA 90089-2520 - USA.
14// Tel: +1 213 740 3527 - itti@pollux.usc.edu - http://iLab.usc.edu - http://jevois.org
15// ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////
16/*! \file */
17
18#pragma once
19
22
23namespace jevois
24{
25 namespace dnn
26 {
27 //! Post-Processor for neural network pipeline
28 /*! This is the last step in a deep neural network processing Pipeline. \ingroup dnn */
30 public Parameter<postprocessor::classoffset, postprocessor::classes,
31 postprocessor::top, postprocessor::cthresh, postprocessor::softmax,
32 postprocessor::scorescale, postprocessor::namedonly,
33 postprocessor::serialreport>
34 {
35 public:
36
37 //! Inherited constructor ok
38 using PostProcessor::PostProcessor;
39
40 //! Destructor
41 virtual ~PostProcessorClassify();
42
43 //! Freeze/unfreeze parameters that users should not change while running
44 void freeze(bool doit) override;
45
46 //! Process outputs and draw/send some results
47 void process(std::vector<cv::Mat> const & outs, PreProcessor * preproc) override;
48
49 //! Report what happened in last process() to console/output video/GUI
50 void report(jevois::StdModule * mod, jevois::RawImage * outimg = nullptr,
51 jevois::OptGUIhelper * helper = nullptr, bool overlay = true, bool idle = false) override;
52
53 //! Get the latest recognition results, use with caution, not thread-safe
54 /*! This returns a reference to our internal vector of recognitions. That vector will get overwritten every time
55 process() is called. It is ok to use this after you have called process() on a given frame, or, if using a
56 Pipeline, after you have called Pipeline::process(). Do not hold this ref past the end of the current video
57 frame. If you need to keep a persistent copy of the data, make a deep copy of the vector. */
58 std::vector<ObjReco> const & latestRecognitions() const;
59
60 protected:
61 void onParamChange(postprocessor::classes const & param, std::string const & val) override;
62 std::map<int, std::string> itsLabels; //!< Mapping from object ID to class name
63
64 private:
65 std::vector<jevois::ObjReco> itsObjRec;
66 bool itsFirstTime = true;
67 };
68
69 } // namespace dnn
70} // namespace jevois
Helper class to assist modules in creating graphical and GUI elements.
Definition GUIhelper.H:133
A raw image as coming from a V4L2 Camera and/or being sent out to a USB Gadget.
Definition RawImage.H:111
Base class for a module that supports standardized serial messages.
Definition Module.H:234
Post-Processor for neural network pipeline.
void onParamChange(postprocessor::classes const &param, std::string const &val) override
std::vector< ObjReco > const & latestRecognitions() const
Get the latest recognition results, use with caution, not thread-safe.
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::map< int, std::string > itsLabels
Mapping from object ID to class name.
Post-Processor for neural network pipeline.
Pre-Processor for neural network pipeline.
Main namespace for all JeVois classes and functions.
Definition Concepts.dox:2