]> Creatis software - bbtk.git/blob - packages/std/src/bbstdCastVector.h
#3202 BBTK Feature New Normal - fast algorithm for ImageBoundaries box
[bbtk.git] / packages / std / src / bbstdCastVector.h
1 /*
2  # ---------------------------------------------------------------------
3  #
4  # Copyright (c) CREATIS (Centre de Recherche en Acquisition et Traitement de l'Image
5  #                        pour la SantÈ)
6  # Authors : Eduardo Davila, Frederic Cervenansky, Claire Mouton
7  # Previous Authors : Laurent Guigues, Jean-Pierre Roux
8  # CreaTools website : www.creatis.insa-lyon.fr/site/fr/creatools_accueil
9  #
10  #  This software is governed by the CeCILL-B license under French law and
11  #  abiding by the rules of distribution of free software. You can  use,
12  #  modify and/ or redistribute the software under the terms of the CeCILL-B
13  #  license as circulated by CEA, CNRS and INRIA at the following URL
14  #  http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
15  #  or in the file LICENSE.txt.
16  #
17  #  As a counterpart to the access to the source code and  rights to copy,
18  #  modify and redistribute granted by the license, users are provided only
19  #  with a limited warranty  and the software's author,  the holder of the
20  #  economic rights,  and the successive licensors  have only  limited
21  #  liability.
22  #
23  #  The fact that you are presently reading this means that you have had
24  #  knowledge of the CeCILL-B license and that you accept its terms.
25  # ------------------------------------------------------------------------ */
26
27
28 /*=========================================================================
29   Program:   bbtk
30   Module:    $RCSfile: bbstdCastVector.h,v $
31   Language:  C++
32   Date:      $Date: 2012/11/16 08:51:32 $
33   Version:   $Revision: 1.8 $
34 =========================================================================*/
35
36
37
38 #ifndef __bbstdCastVector_h_INCLUDED__
39 #define __bbstdCastVector_h_INCLUDED__
40
41 #include "bbtkAtomicBlackBox.h"
42 #include "bbstd_EXPORT.h"
43 #include <vector>
44
45 namespace bbstd 
46 {
47   
48   //=================================================================
49   // BlackBox declaration
50   template < class T, class U >
51   class bbstd_EXPORT CastVector : public bbtk::AtomicBlackBox
52   {  
53     BBTK_TEMPLATE2_BLACK_BOX_INTERFACE(CastVector,bbtk::AtomicBlackBox , T , U );
54     BBTK_DECLARE_INPUT(In , std::vector<T> );
55     BBTK_DECLARE_OUTPUT(Out , std::vector<U> );
56     BBTK_PROCESS(DoIt);
57     void DoIt() {  
58 //      bbtkDebugMessage("Data",5,"bbstd::CastVector In  = "
59 //                     << bbGetInputIn() <<" <"<<bbtk::HumanTypeName< T >()
60 //                     <<">"<<std::endl);
61 //      bbSetOutputOut( static_cast< U >(bbGetInputIn()) );
62
63   bbmOutputOut.clear();
64
65     typename std::vector<T>::const_iterator i;
66     for (i=bbmInputIn.begin();i!=bbmInputIn.end();++i)
67     {
68       bbmOutputOut.push_back( *i );
69     }
70
71
72 //      bbtkDebugMessage("Data",5,"bbstd::CastVector Out = "
73 //                     <<( U )bbGetInputIn()<<" <"<<bbtk::HumanTypeName< U >()
74 //                     <<">"<<std::endl);
75     }
76   };
77   //=================================================================
78   
79   
80   
81   
82   //=================================================================
83   // BlackBox description
84   BBTK_BEGIN_DESCRIBE_TEMPLATE2_BLACK_BOX(CastVector,bbtk::AtomicBlackBox);
85   BBTK_NAME("CastVector"+bbtk::HumanTypeName< T1 >()+"To"+bbtk::HumanTypeName< T2 >());
86   BBTK_AUTHOR("laurent.guigues@creatis.insa-lyon.fr");
87   BBTK_DESCRIPTION("Static CastVector from "+bbtk::HumanTypeName< T1 >()+" ("
88                    +bbtk::TypeName< T1 >()+") to "+bbtk::HumanTypeName< T2 >()
89                    +" ("+bbtk::TypeName< T2 >()+")");
90   BBTK_DEFAULT_ADAPTOR();
91   typedef std::vector<T1> T1vector;
92   BBTK_TEMPLATE2_INPUT(CastVector,In,"Input", T1vector );
93   typedef std::vector<T2> T2vector;
94   BBTK_TEMPLATE2_OUTPUT(CastVector,Out,"Output", T2vector );
95   BBTK_END_DESCRIBE_TEMPLATE2_BLACK_BOX(CastVector);
96   //=================================================================
97
98   template <class T, class U> void CastVector< T , U >::bbUserSetDefaultValues() {}
99   template <class T, class U> void CastVector< T , U >::bbUserInitializeProcessing() {}
100   template <class T, class U> void CastVector< T , U >::bbUserFinalizeProcessing() {}
101
102
103 } // namespace bbstd
104
105 #endif // __bbstdCastVector_h_INCLUDED__
106