/*******************************************************************************
* TmsCycleParam.h TMS Client library functions
* T.Barnaby, BEAM Ltd, 2007-06-19
*******************************************************************************
*/
#ifndef TmsCycleParam_H
#define TmsCycleParam_H 1
#include <TmsLib.h>
namespace Tms {
class CycleParamState {
public:
CycleParamState();
BString getString(); ///< Returns the CycleParamState in string form
BError setString(BString str); ///< Sets the CycleParamState from a string
UInt32 period; ///< The cycle period
UInt32 bunchMask; ///< The set of bunches to capture bit mask
UInt32 mean1Mask; ///< The set of bunches to pass through meanFilter1
UInt32 mean2Mask; ///< The set of bunches to pass through meanFilter2
UInt32 loHarmonic; ///< The LO harmonic number used in this state
double loPhase; ///< The phase offset of the LO as a fraction of FREF (+-1.0)
int useLoFref; ///< Flag setting system to use LO as FREF rather than phase table address MSB
int acquireData; ///< Flag to aquire data during this state
double gateWidth; ///< The gate pulse width as a fraction of LO (0 - 1.0)
double gatePhase; ///< The gate phase offset as a fraction of LO (0 - 1.0)
double blrWidth; ///< The gate pulse width as a fraction of LO (0 - 1.0)
double blrPhase; ///< The gate phase offset as a fraction of LO (0 - 1.0)
};
/// Cycle Parameter management class
class CycleParamEdit : public CycleParam {
public:
CycleParamEdit();
CycleParamEdit(const CycleParam& param);
BString getString(); ///< Gets the Cycle Parameters in a string format for writing to a file or display
BError setString(BString str); ///< Sets the Cycle Parameters from a string. For reading from a file
BError readFromFile(BString fileName); ///< Reads the Cycle Parameters from a file
BError writeToFile(BString fileName); ///< Writes the Cycle Parameters to a file
BError setStates(BList<CycleParamState> cycleStates); ///< Sets the Cycle Parameter states given the state information list.
BError getStates(BList<CycleParamState>& cycleStates); ///< Returns the state information list describing the Cycle Parameter states. These may not be present.
static void getDefaultState(CycleParamState& state); ///< Get the default settings for a state.
static void getdefaultPickupPositions(BArray<Int32>& pos); ///< Get the default pickup positions.
private:
double value(int numSamples, int harmonic, double phase, int sample);
int bunch(int numSamples, int harmonic, double phase, int sample);
BError generateState(int num, Tms::TmsState state, CycleParamState stateParam, int lo1Harmonic, double lo1Phase, int lo2Harmonic, double lo2Phase);
};
}
#endif