SlidingAverageCreator.hh 5.89 KB
/*
 * SlidingAverageCreator.hh
 *
 *  Created on: Dec 12, 2012
 *      Author: f.casimir
 */

#ifndef SlidingAverageCREATOR_HH_
#define SlidingAverageCREATOR_HH_

#include "ParamData.hh"
#include "VisitorOfParamData.hh"
#include "SlidingAverage.hh"

namespace AMDA {
namespace Parameters {

/**
 * @class SlidingAverageCreator
 * @brief Creator of the Operation SlidingAverage parameterized with ParamData input type.
 * @details Implement the interface VisitorOfParamData.
 */
class SlidingAverageCreator : public VisitorOfParamData {
public:
	/**
	 * @brief Constructor.
	 */
	SlidingAverageCreator(Process& pProcess, ParamData& paramInput, TimeIntervalListSPtr pTimeIntervalList, double window)
		: _process(pProcess), _paramData(paramInput), _operation(NULL), _timeIntervalList(pTimeIntervalList), _window(window) {

		_paramData.accept(*this);
	}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataScalaireShort *)
	 */
	void visit(ParamDataScalaireShort *) {_operation = new SlidingAverage<ParamDataScalaireShort>( _process, dynamic_cast<ParamDataScalaireShort &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataScalaireFloat *)
	 */
	void visit(ParamDataScalaireFloat *) {_operation = new SlidingAverage<ParamDataScalaireFloat>( _process, dynamic_cast<ParamDataScalaireFloat &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataScalaireDouble *)
	 */
	void visit(ParamDataScalaireDouble *) {_operation = new SlidingAverage<ParamDataScalaireDouble>(  _process,dynamic_cast<ParamDataScalaireDouble &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataScalaireLongDouble *)
	 */
	void visit(ParamDataScalaireLongDouble *) {_operation = new SlidingAverage<ParamDataScalaireLongDouble>( _process, dynamic_cast<ParamDataScalaireLongDouble &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataScalaireInt *)
	 */
	void visit(ParamDataScalaireInt *) {_operation = new SlidingAverage<ParamDataScalaireInt>( _process, dynamic_cast<ParamDataScalaireInt &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataLogicalData *)
	 */
	void visit(ParamDataLogicalData *) { BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("SlidingAverageCreator operation not supported")); }

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab1DShort *)
	 */
	void visit(ParamDataTab1DShort *) {_operation = new SlidingAverage<ParamDataTab1DShort>( _process, dynamic_cast<ParamDataTab1DShort &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab1DFloat *)
	 */
	void visit(ParamDataTab1DFloat *) {_operation = new SlidingAverage<ParamDataTab1DFloat>( _process, dynamic_cast<ParamDataTab1DFloat &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab1DDouble *)
	 */
	void visit(ParamDataTab1DDouble *) {_operation = new SlidingAverage<ParamDataTab1DDouble>( _process, dynamic_cast<ParamDataTab1DDouble &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab1DLongDouble *)
	 */
	void visit(ParamDataTab1DLongDouble *) {_operation = new SlidingAverage<ParamDataTab1DLongDouble>( _process, dynamic_cast<ParamDataTab1DLongDouble &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab1DInt *)
	 */
	void visit(ParamDataTab1DInt *) {_operation = new SlidingAverage<ParamDataTab1DInt>( _process, dynamic_cast<ParamDataTab1DInt &>(_paramData), _timeIntervalList, _window);}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab1DLogicalData *)
	 */
	void visit(ParamDataTab1DLogicalData *) { BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("SlidingAverageCreator operation not supported") );}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab2DShort *)
	 */
	void visit(ParamDataTab2DShort *) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("ParamDataTab2DShort data not supported"));
	}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab2DFloat *)
	 */
	void visit(ParamDataTab2DFloat *) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("ParamDataTab2DFloat data not supported"));
	}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab2DDouble *)
	 */
	void visit(ParamDataTab2DDouble *) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("ParamDataTab2DDouble data not supported"));
	}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab2DLongDouble *)
	 */
	void visit(ParamDataTab2DLongDouble *) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("ParamDataTab2DLongDouble data not supported"));
	}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab2DInt *)
	 */
	void visit(ParamDataTab2DInt *) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("ParamDataTab2DInt data not supported"));
	}

	/**
	 * @overload VisitorOfParamData::visit(ParamDataTab2DLogicalData *)
	 */
	void visit(ParamDataTab2DLogicalData *) {
		BOOST_THROW_EXCEPTION(AMDA::AMDA_exception() << AMDA::errno_code(AMDA_ERROR_UNKNOWN) << AMDA::ex_msg("ParamDataTab2DLogicalData data not supported"));
	}

	/**
	 * @brief get the SlidingAverage parameterized operation.
	 */
	Operation * getOperation() const {	return _operation;	}

private:
	Process   &_process;
	ParamData &_paramData;
	Operation *_operation;
	TimeIntervalListSPtr _timeIntervalList;
	  /**
	   * @brief window size for sliding average.
	   */
	double _window;
};

} /* namespace Parameters */
} /* namespace AMDA */
#endif /* SlidingAverageCREATOR_HH_ */