JeVoisBase  1.20
JeVois Smart Embedded Machine Vision Toolkit Base Modules
Share this page:
LaplacianFilter.H
Go to the documentation of this file.
1 // ///////////////////////////////////////////////////////////////////////////////////////////////////////////////////
2 //
3 // JeVois Smart Embedded Machine Vision Toolkit - Copyright (C) 2017 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 
21 #include <jevois/Types/Enum.H>
22 #include <opencv2/imgproc/imgproc.hpp>
23 
24 namespace laplacianfilter
25 {
26  static jevois::ParameterCategory const ParamCateg("Laplacian Filter Parameters");
27 
28  //! Parameter \relates LaplacianFilter
29  JEVOIS_DECLARE_PARAMETER(ksize, unsigned int, "Laplacian kernel size",
30  1, ParamCateg);
31 
32  //! Parameter \relates LaplacianFilter
33  JEVOIS_DECLARE_PARAMETER(scale, double, "Laplacian scale factor applied to the computed values",
34  1.0, ParamCateg);
35 
36  //! Parameter \relates LaplacianFilter
37  JEVOIS_DECLARE_PARAMETER(delta, double, "Laplacian delta offset applied to the computed values",
38  0.0, ParamCateg);
39 }
40 
41 //! A laplacian filter
42 /*! See http://docs.opencv.org/3.2.0/d4/d86/group__imgproc__filter.html for details. */
43 class LaplacianFilter : public Filter,
44  public jevois::Parameter<laplacianfilter::ksize, laplacianfilter::scale, laplacianfilter::delta>
45 {
46  public:
47  //! Inherited constructor ok
48  using Filter::Filter;
49 
50  //! Virtual destructor for safe inheritance
51  virtual ~LaplacianFilter();
52 
53  //! Processing function: filters the image src and puts the results into dst
54  virtual std::string process(cv::Mat const & src, cv::Mat & dst) override;
55 };
JEVOIS_DECLARE_PARAMETER
JEVOIS_DECLARE_PARAMETER(thresh1, double, "First threshold for hysteresis", 50.0, ParamCateg)
LaplacianFilter::process
virtual std::string process(cv::Mat const &src, cv::Mat &dst) override
Processing function: filters the image src and puts the results into dst.
Definition: LaplacianFilter.C:27
jevois::ParameterCategory
LaplacianFilter::~LaplacianFilter
virtual ~LaplacianFilter()
Virtual destructor for safe inheritance.
Definition: LaplacianFilter.C:23
Filter
Base class for an image filter.
Definition: Filter.H:32
Enum.H
laplacianfilter
Definition: LaplacianFilter.H:24
Filter.H
LaplacianFilter
A laplacian filter.
Definition: LaplacianFilter.H:43