VisionCpp  0.0.1
OP_SepGauss3x3.hpp
Go to the documentation of this file.
1 // This file is part of VisionCpp, a lightweight C++ template library
2 // for computer vision and image processing.
3 //
4 // Copyright (C) 2016 Codeplay Software Limited. All Rights Reserved.
5 //
6 // Contact: visioncpp@codeplay.com
7 //
8 // Licensed under the Apache License, Version 2.0 (the "License");
9 // you may not use this file except in compliance with the License.
10 // You may obtain a copy of the License at
11 //
12 // http://www.apache.org/licenses/LICENSE-2.0
13 //
14 // Unless required by applicable law or agreed to in writing, software
15 // distributed under the License is distributed on an "AS IS" BASIS,
16 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 // See the License for the specific language governing permissions and
18 // limitations under the License.
19 
20 /// \file OP_SepGauss3x3.hpp
21 /// \brief Separable Gaussian filter for 3x3 filter size
22 
23 namespace visioncpp {
24 /// \struct OP_SepGaussRow3
25 /// \brief Separable filter for rows.
26 /// If the number of channel is different in your case feel free to write your
27 /// own.
29  /// \param nbr - Where PIXEL is pixel type
30  /// \return PIXEL
31  template <typename NeighbourT>
32  typename NeighbourT::PixelType operator()(NeighbourT &nbr) {
33  auto out = nbr.at(nbr.I_c, nbr.I_r - 1) * 1.0f / 4.0f;
34  out += nbr.at(nbr.I_c, nbr.I_r) * 2.0f / 4.0f;
35  out += nbr.at(nbr.I_c, nbr.I_r + 1) * 1.0f / 4.0f;
36  return out;
37  }
38 };
39 
40 /// \struct OP_SepGaussCol3
41 /// \brief Separable filter for cols.
43  /// \param nbr - Where PIXEL is pixel type
44  /// \return PIXEL
45  template <typename NeighbourT>
46  typename NeighbourT::PixelType operator()(NeighbourT &nbr) {
47  auto out = nbr.at(nbr.I_c - 1, nbr.I_r) * 1.0f / 3.0f;
48  out += nbr.at(nbr.I_c, nbr.I_r) * 1.0f / 3.0f;
49  out += nbr.at(nbr.I_c + 1, nbr.I_r) * 1.0f / 3.0f;
50  return out;
51  }
52 };
53 }
VisionCpp namespace.
Definition: sycl/device.hpp:24
Separable filter for cols.
NeighbourT::PixelType operator()(NeighbourT &nbr)
Separable filter for rows.
NeighbourT::PixelType operator()(NeighbourT &nbr)