Logo Search packages:      
Sourcecode: libgdf version File versions  Download package

Channel.cpp

//
// This file is part of libGDF.
//
// libGDF is free software: you can redistribute it and/or modify
// it under the terms of the GNU Lesser General Public License as
// published by the Free Software Foundation, either version 3 of
// the License, or (at your option) any later version.
//
// libGDF is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
// along with libGDF.  If not, see <http://www.gnu.org/licenses/>.
//
// Copyright 2010 Martin Billinger

#include "GDF/Channel.h"
#include "GDF/ChannelData.h"
#include <boost/numeric/conversion/cast.hpp>
#include <boost/lexical_cast.hpp>
//#include <iostream>

namespace gdf {

00027     Channel::Channel( const SignalHeader *sig_hdr, const size_t length )
    {
        m_signalheader = sig_hdr;

        switch( m_signalheader->get_datatype( ) )
        {
        case INT8:
            {
                m_data = new ChannelData<int8>( length );
            } break;
        case UINT8:
            {
                m_data = new ChannelData<uint8>( length );
            } break;
        case INT16:
            {
                m_data = new ChannelData<int16>( length );
            } break;
        case UINT16:
            {
                m_data = new ChannelData<uint16>( length );
            } break;
        case INT32:
            {
                m_data = new ChannelData<int32>( length );
            } break;
        case UINT32:
            {
                m_data = new ChannelData<uint32>( length );
            } break;
        case INT64:
            {
                m_data = new ChannelData<int64>( length );
            } break;
        case UINT64:
            {
                m_data = new ChannelData<uint64>( length );
            } break;
        case FLOAT32:
            {
                m_data = new ChannelData<float32>( length );
            } break;
        case FLOAT64:
            {
                m_data = new ChannelData<float64>( length );
            } break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        }
    }

    //===================================================================================================
    //===================================================================================================

00080     Channel::Channel( const SignalHeader *sig_hdr )
    {
        m_signalheader = sig_hdr;

        size_t length = sig_hdr->get_samples_per_record( );

        switch( m_signalheader->get_datatype( ) )
        {
        case INT8:
            {
                m_data = new ChannelData<int8>( length );
            } break;
        case UINT8:
            {
                m_data = new ChannelData<uint8>( length );
            } break;
        case INT16:
            {
                m_data = new ChannelData<int16>( length );
            } break;
        case UINT16:
            {
                m_data = new ChannelData<uint16>( length );
            } break;
        case INT32:
            {
                m_data = new ChannelData<int32>( length );
            } break;
        case UINT32:
            {
                m_data = new ChannelData<uint32>( length );
            } break;
        case INT64:
            {
                m_data = new ChannelData<int64>( length );
            } break;
        case UINT64:
            {
                m_data = new ChannelData<uint64>( length );
            } break;
        case FLOAT32:
            {
                m_data = new ChannelData<float32>( length );
            } break;
        case FLOAT64:
            {
                m_data = new ChannelData<float64>( length );
            } break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        }
    }

    //===================================================================================================
    //===================================================================================================

00135     Channel::Channel( const Channel &other )
    {
        m_signalheader = other.m_signalheader;
        //size_t length = m_signalheader->get_samples_per_record( );

        switch( m_signalheader->get_datatype( ) )
        {
        case INT8:
            {
                m_data = new ChannelData<int8>( other.m_data );
            } break;
        case UINT8:
            {
                m_data = new ChannelData<uint8>( other.m_data );
            } break;
        case INT16:
            {
                m_data = new ChannelData<int16>( other.m_data );
            } break;
        case UINT16:
            {
                m_data = new ChannelData<uint16>( other.m_data );
            } break;
        case INT32:
            {
                m_data = new ChannelData<int32>( other.m_data );
            } break;
        case UINT32:
            {
                m_data = new ChannelData<uint32>( other.m_data );
            } break;
        case INT64:
            {
                m_data = new ChannelData<int64>( other.m_data );
            } break;
        case UINT64:
            {
                m_data = new ChannelData<uint64>( other.m_data );
            } break;
        case FLOAT32:
            {
                m_data = new ChannelData<float32>( other.m_data );
            } break;
        case FLOAT64:
            {
                m_data = new ChannelData<float64>( other.m_data );
            } break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        }
    }

    //===================================================================================================
    //===================================================================================================

00189     Channel::~Channel( )
    {
        delete m_data;
    }

    //===================================================================================================
    //===================================================================================================

00197     void Channel::clear( )
    {
        m_data->clear( );
    }

    //===================================================================================================
    //===================================================================================================

00205     void Channel::addSamplePhys( const double value )
    {
        using boost::numeric_cast;

        double rawval = m_signalheader->phys_to_raw( value );

        switch( m_signalheader->get_datatype( ) )
        {
        case INT8: m_data->addSample( numeric_cast<int8>(rawval) ); break;
        case UINT8: m_data->addSample( numeric_cast<uint8>(rawval) ); break;
        case INT16: m_data->addSample( numeric_cast<int16>(rawval) ); break;
        case UINT16: m_data->addSample( numeric_cast<uint16>(rawval) ); break;
        case INT32: m_data->addSample( numeric_cast<int32>(rawval) ); break;
        case UINT32: m_data->addSample( numeric_cast<uint32>(rawval) ); break;
        case INT64: m_data->addSample( numeric_cast<int64>(rawval) ); break;
        case UINT64: m_data->addSample( numeric_cast<uint64>(rawval) ); break;
        case FLOAT32: m_data->addSample( numeric_cast<float32>(rawval) ); break;
        case FLOAT64: m_data->addSample( numeric_cast<float64>(rawval) ); break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        };
    }

    //===================================================================================================
    //===================================================================================================

00230     void Channel::blitSamplesPhys( const double *values, size_t num )
    {
        for( size_t i=0; i<num; i++ )
            addSamplePhys( values[i] );
    }

    //===================================================================================================
    //===================================================================================================

00239     void Channel::fillPhys( const double value, size_t num )
    {
        using boost::numeric_cast;
        double rawval = value * m_signalheader->phys_to_raw( value );

        switch( m_signalheader->get_datatype( ) )
        {
        case INT8: m_data->fill( numeric_cast<int8>(rawval), num ); break;
        case UINT8: m_data->fill( numeric_cast<uint8>(rawval), num ); break;
        case INT16: m_data->fill( numeric_cast<int16>(rawval), num ); break;
        case UINT16: m_data->fill( numeric_cast<uint16>(rawval), num ); break;
        case INT32: m_data->fill( numeric_cast<int32>(rawval), num ); break;
        case UINT32: m_data->fill( numeric_cast<uint32>(rawval), num ); break;
        case INT64: m_data->fill( numeric_cast<int64>(rawval), num ); break;
        case UINT64: m_data->fill( numeric_cast<uint64>(rawval), num ); break;
        case FLOAT32: m_data->fill( numeric_cast<float32>(rawval), num ); break;
        case FLOAT64: m_data->fill( numeric_cast<float64>(rawval), num ); break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        };
    }

    //===================================================================================================
    //===================================================================================================

00263     template<typename T> void Channel::fillRaw( const T rawval, size_t num )
    {
        using boost::numeric_cast;

        switch( m_signalheader->get_datatype( ) )
        {
        case INT8: m_data->fill( numeric_cast<int8>(rawval), num ); break;
        case UINT8: m_data->fill( numeric_cast<uint8>(rawval), num ); break;
        case INT16: m_data->fill( numeric_cast<int16>(rawval), num ); break;
        case UINT16: m_data->fill( numeric_cast<uint16>(rawval), num ); break;
        case INT32: m_data->fill( numeric_cast<int32>(rawval), num ); break;
        case UINT32: m_data->fill( numeric_cast<uint32>(rawval), num ); break;
        case INT64: m_data->fill( numeric_cast<int64>(rawval), num ); break;
        case UINT64: m_data->fill( numeric_cast<uint64>(rawval), num ); break;
        case FLOAT32: m_data->fill( numeric_cast<float32>(rawval), num ); break;
        case FLOAT64: m_data->fill( numeric_cast<float64>(rawval), num ); break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        };
    }

    //===================================================================================================
    //===================================================================================================

00286     void Channel::setSamplePhys( size_t pos, double value )
    {
        using boost::numeric_cast;

        double rawval = m_signalheader->phys_to_raw( value );

        switch( m_signalheader->get_datatype() )
        {
        case INT8: m_data->setSample( pos, numeric_cast<int8>( rawval ) ); break;
        case UINT8: m_data->setSample( pos, numeric_cast<uint8>( rawval ) ); break;
        case INT16: m_data->setSample( pos, numeric_cast<int16>( rawval ) ); break;
        case UINT16: m_data->setSample( pos, numeric_cast<uint16>( rawval ) ); break;
        case INT32: m_data->setSample( pos, numeric_cast<int32>( rawval ) ); break;
        case UINT32: m_data->setSample( pos, numeric_cast<uint32>( rawval ) ); break;
        case INT64: m_data->setSample( pos, numeric_cast<int64>( rawval ) ); break;
        case UINT64: m_data->setSample( pos, numeric_cast<uint64>( rawval ) ); break;
        case FLOAT32: m_data->setSample( pos, numeric_cast<float32>( rawval ) ); break;
        case FLOAT64: m_data->setSample( pos, numeric_cast<float64>( rawval ) ); break;
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        }
    }

    //===================================================================================================
    //===================================================================================================

00311     double Channel::getSamplePhys( size_t pos )
    {
        using boost::numeric_cast;

        switch( m_signalheader->get_datatype() )
        {
        case INT8: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, int8() ) ) );
        case UINT8: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, uint8() ) ) );
        case INT16: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, int16() ) ) );
        case UINT16: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, uint16() ) ) );
        case INT32: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, int32() ) ) );
        case UINT32: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, uint32() ) ) );
        case INT64: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, int64() ) ) );
        case UINT64: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, uint64() ) ) );
        case FLOAT32: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, float32() ) ) );
        case FLOAT64: return m_signalheader->raw_to_phys( numeric_cast<double>( m_data->getSample( pos, float64() ) ) );
        default: throw exception::invalid_type_id( boost::lexical_cast<std::string>(m_signalheader->get_datatype( )) ); break;
        }
    }

    //===================================================================================================
    //===================================================================================================

00334     void Channel::deblitSamplesPhys( double *values, size_t start, size_t num )
    {
        for( size_t i=0; i<num; i++ )
        {
            values[i] = getSamplePhys( start + i );
        }
    }

    //===================================================================================================
    //===================================================================================================

00345     size_t Channel::getFree( )
    {
        return m_data->getFree( );
    }

    //===================================================================================================
    //===================================================================================================

00353     size_t Channel::getWritten( )
    {
        return m_data->getWritten( );
    }

    //===================================================================================================
    //===================================================================================================

00361     uint32 Channel::getTypeID( )
    {
        return m_signalheader->get_datatype( );
    }

    //===================================================================================================
    //===================================================================================================

    std::ostream &operator<<( std::ostream &out, const Channel &c )
    {
        c.m_data->tostream( out );
        return out;
    }

    //===================================================================================================
    //===================================================================================================

    std::istream &operator>>( std::istream &in, Channel &c )
    {
        c.m_data->fromstream( in );
        return in;
    }

}

Generated by  Doxygen 1.6.0   Back to index