SMIL  1.0.4
DMorphoBase.hpp
1 /*
2  * Copyright (c) 2011-2016, Matthieu FAESSEL and ARMINES
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * * Neither the name of Matthieu FAESSEL, or ARMINES nor the
14  * names of its contributors may be used to endorse or promote products
15  * derived from this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS ``AS IS''
18  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDERS AND CONTRIBUTORS BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  * POSSIBILITY OF SUCH DAMAGE.
28  */
29 
30 #ifndef _D_MORPHO_BASE_HPP
31 #define _D_MORPHO_BASE_HPP
32 
33 #include "Core/include/DImage.h"
34 #include "Base/include/private/DImageArith.hpp"
35 #include "Morpho/include/DMorphoInstance.h"
36 #include "DMorphImageOperations.hxx"
37 #include "DHitOrMiss.hpp"
38 
39 namespace smil
40 {
64  template <class T>
65  RES_T dilate(const Image<T> &imIn, Image<T> &imOut,
66  const StrElt &se = DEFAULT_SE, const T borderVal = ImDtTypes<T>::min())
67  {
68  ASSERT_ALLOCATED(&imIn, &imOut);
69  ASSERT_SAME_SIZE(&imIn, &imOut);
70 
71  MorphImageFunction<T, supLine<T>> iFunc(borderVal);
72  return iFunc(imIn, imOut, se);
73  }
74 
89  template <class T>
90  RES_T dilate(const Image<T> &imIn, Image<T> &imOut, UINT seSize,
91  const T borderVal = ImDtTypes<T>::min())
92  {
93  return dilate(imIn, imOut, DEFAULT_SE(seSize), borderVal);
94  }
95 
111  template <class T>
112  RES_T erode(const Image<T> &imIn, Image<T> &imOut,
113  const StrElt &se = DEFAULT_SE, const T borderVal = ImDtTypes<T>::max())
114  {
115  ASSERT_ALLOCATED(&imIn, &imOut);
116  ASSERT_SAME_SIZE(&imIn, &imOut);
117 
118  MorphImageFunction<T, infLine<T>> iFunc(borderVal);
119  return iFunc(imIn, imOut, se.transpose());
120  }
121 
135  template <class T>
136  RES_T erode(const Image<T> &imIn, Image<T> &imOut, UINT seSize,
137  const T borderVal = ImDtTypes<T>::max())
138  {
139  return erode(imIn, imOut, DEFAULT_SE(seSize), borderVal);
140  }
141 
142 
145 } // namespace smil
146 
147 #endif // _D_MORPHO_BASE_HPP
Main Image class.
Definition: DImage.hpp:57
Definition: DMorphImageOperations.hpp:145
Base structuring element.
Definition: DStructuringElement.h:68
RES_T erode(const Image< T > &imIn, Image< T > &imOut, UINT seSize, const T borderVal=ImDtTypes< T >::max())
erode() - Morphological grayscale erosion using the default structuring element but being able to set...
Definition: DMorphoBase.hpp:136
RES_T dilate(const Image< T > &imIn, Image< T > &imOut, UINT seSize, const T borderVal=ImDtTypes< T >::min())
dilate() - Morphological grayscale dilation using the default structuring element but being able to s...
Definition: DMorphoBase.hpp:90
Definition: DTypes.hpp:88