Revision cc7055c78202813215e6c607255bdfdf6e088dca authored by Konrad Werys on 01 November 2019, 12:51:09 UTC, committed by Konrad Werys on 01 November 2019, 12:51:09 UTC
1 parent 00b20ae
OxFactoryOfSignCalculators.h
/*!
* \file OxFactoryOfSignCalculators.h
* \author Konrad Werys
* \date 2018/08/18
*/
#ifndef Tomato_OXFACTORYOFSignCalculators_H
#define Tomato_OXFACTORYOFSignCalculators_H
#include "CmakeConfigForTomato.h"
#include "OxSignCalculatorNoSign.h"
#include "OxSignCalculatorRealImag.h"
#ifdef USE_PRIVATE_NR2
#include "OxSignCalculatorShmolli.h"
#endif
namespace Ox {
template<typename TYPE>
struct TomatoOptions;
static const char *signCalculatorsTypeNames[] = {
"NoSign",
"RealImag",
"MagPhase"
};
enum signCalculatorsType_t {
NoSign = 0,
RealImag = 1,
MagPhase = 2,
lastSignCalculatorType = MagPhase
};
static int signCalculatorsAvailability [] = {
1, // NoSign
1, // RealImag
#ifdef USE_PRIVATE_NR2
1, // MagPhase
#else
0, // MagPhase
#endif
};
template<typename TYPE>
class FactoryOfSignCalculators {
public:
static SignCalculator<TYPE>* newByFactory(TomatoOptions<TYPE> *opts){
switch (opts->sign_calc_method){
case NoSign: {
return new SignCalculatorNoSign<TYPE>();
}
case RealImag: {
return new SignCalculatorRealImag<TYPE>();
}
#ifdef USE_PRIVATE_NR2
case MagPhase: {
return new SignCalculatorShmolli<TYPE>();
}
#endif
default:
throw std::runtime_error("sign_calc_method not available");
}
}
static void disp(int sign_calc_method = -1){
if (sign_calc_method >= 0) {
printf("%-28s%-22s", " sign_calc_method: ", signCalculatorsTypeNames[sign_calc_method]);
}
printf("options: [ ");
for (int i = 0; i < lastSignCalculatorType+1; i++){
if(signCalculatorsAvailability[i]){
printf("%s ", signCalculatorsTypeNames[i]);
}
}
printf("] \n");
}
};
} // namespace Ox
#endif //Tomato_OXFACTORYOFSignCalculators_H
Computing file changes ...