Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032 #include <Segmentation/cmtkLabelCombinationVoting.h>
00033
00034 namespace
00035 cmtk
00036 {
00037
00040
00041 LabelCombinationVoting::LabelCombinationVoting( const std::vector<TypedArray::SmartPtr>& data )
00042 {
00043 const size_t nValues = data[ 0 ]->GetDataSize();
00044 m_Result = TypedArray::SmartPtr( TypedArray::Create( TYPE_SHORT, nValues ) );
00045
00046 #pragma omp parallel for
00047 for ( size_t i = 0; i < nValues; ++i )
00048 {
00049 short label[256];
00050 memset( label, 0, sizeof( label ) );
00051
00052 for ( size_t curr = 0; curr < data.size(); ++curr )
00053 {
00054 Types::DataItem v;
00055 if ( data[ curr ]->Get( v, i ) )
00056 {
00057 ++label[ static_cast<byte>( v ) ];
00058 }
00059 }
00060
00061
00062
00063 int maxLab = 0;
00064 int maxCnt = 0;
00065
00066 for ( int lab=0; lab < 256; ++lab )
00067 {
00068
00069 if ( label[ lab ] > maxCnt )
00070 {
00071 maxCnt = label[ lab ];
00072 maxLab = lab;
00073 }
00074 else
00075 {
00076 if ( label[lab] == maxCnt )
00077 {
00078 maxLab = -1;
00079 }
00080 }
00081 }
00082
00083 this->m_Result->Set( maxLab, i );
00084 }
00085 }
00086
00087 }