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
Raw File
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
back to top