11 #ifndef PRIMATOLOGIST_UTILITY_IO_H    12 #define PRIMATOLOGIST_UTILITY_IO_H    14 #include <aims/utility/converter_g.h>                    15 #include <aims/io/io_g.h>                    16 #include <aims/io/channelR.h>                               17 #include <cartodata/volume/volume.h>    24   void write( 
const T & 
object, 
const std::string & fname, 
bool doit = 
true )
    36   void read( 
const std::string & fname, T & 
object, 
bool doit = 
true )
    49   void readChannel( 
const std::string & fname, T & 
object, int8_t channel, 
bool doit = 
true )
    53       ChannelReader<T> r( fname );
    54       r.read( 
object, channel );
    58 #ifndef DOXYGEN_HIDE_INTERNAL_CLASSES    61   void readChannel( 
const std::string & fname, carto::VolumeRef<T> & 
object, int8_t channel, 
bool doit = 
true )
    65       AimsData<T> data( 
object );
    66       ChannelReader<AimsData<T> > r( fname );
    67       r.read( data, channel );
    68       if( 
object.
get() != data.volume().get() )
    69         object = data.volume();
    72 #endif // DOXYGEN_HIDE_INTERNAL_CLASSES    74 #ifndef DOXYGEN_HIDE_INTERNAL_CLASSES    78     template<
typename IN, 
typename OUT>
    79     bool convert( Process & p, 
const std::string & fname, Finder & f );
    90           registerProcessType( 
"Volume", 
"S8",      &convert<int8_t,T> );
    91           registerProcessType( 
"Volume", 
"U8",      &convert<uint8_t,T> );
    92           registerProcessType( 
"Volume", 
"S16",     &convert<int16_t,T> );
    93           registerProcessType( 
"Volume", 
"U16",     &convert<uint16_t,T> );
    94           registerProcessType( 
"Volume", 
"S32",     &convert<int32_t,T> );
    95           registerProcessType( 
"Volume", 
"U32",     &convert<uint32_t,T> );
    96           registerProcessType( 
"Volume", 
"S64",     &convert<int64_t,T> );
    97           registerProcessType( 
"Volume", 
"U64",     &convert<uint64_t,T> );
    98           registerProcessType( 
"Volume", 
"FLOAT",   &convert<float,T> );
    99           registerProcessType( 
"Volume", 
"DOUBLE",  &convert<double,T> );
   107     template<
typename IN, 
typename OUT>
   108     bool convert( Process & p, 
const std::string & fname, Finder & f )
   111       std::string fmt = f.format();
   112       Reader<carto::VolumeRef<IN> > r( fname );
   113       carto::VolumeRef<IN> 
data;
   114       r.read( data, 0, &fmt );
   117         cc.
data.reallocate( data.getSizeX(), data.getSizeY(),
   118                             data.getSizeZ(), data.getSizeT() );
   120         cc.
data = carto::VolumeRef<OUT>( data.getSizeX(), data.getSizeY(),
   121                                          data.getSizeZ(), data.getSizeT() );
   122       carto::ShallowConverter<carto::VolumeRef<IN>, carto::VolumeRef<OUT> > conv;
   123       conv.convert( data, cc.
data );
   124       cc.
data.copyHeaderFrom( data.header() );
   129 #endif // DOXYGEN_HIDE_INTERNAL_CLASSES   134   template <
typename T>
   135   void readConvert( 
const std::string & fname, carto::VolumeRef<T> & 
object, 
bool doit = 
true )
   147 #endif // PRIMATOLOGIST_UTILITY_IO_H 
void readConvert(const std::string &fname, carto::VolumeRef< T > &object, bool doit=true)
bool convert(Process &p, const std::string &fname, Finder &f)
void readChannel(const std::string &fname, T &object, int8_t channel, bool doit=true)
Read a given channel A conversion is done between the channel type and the object type if necessaey...
VolumeConvertReader(carto::VolumeRef< T > &vol)
void read(const std::string &fname, T &object, bool doit=true)
Basic read Provided object type must be the same as disk data type. 
void write(const T &object, const std::string &fname, bool doit=true)
Basic write. 
carto::VolumeRef< T > & data
virtual ~VolumeConvertReader()