Revision 41e684800fbdd0bf24b91ff51f61f60818cc9bc0 authored by Konrad Werys on 14 November 2019, 09:31:46 UTC, committed by Konrad Werys on 14 November 2019, 09:31:46 UTC
1 parent 8e25865
Raw File
OxFactoryOfCalculators.h
/*!
 * \file OxFactoryOfCalculators.h
 * \author Konrad Werys
 * \date 2018/08/18
 */

#ifndef Tomato_OXFACTORYOFCalculators_H
#define Tomato_OXFACTORYOFCalculators_H

#include "CmakeConfigForTomato.h"
#include "OxCalculatorT1Molli.h"
#include "OxCalculatorT1Shmolli.h"
#ifdef USE_PRIVATE_NR2
#include "OxCalculatorT1ShmolliOriginal.h"
#endif
#include "OxCalculatorT2.h"


namespace Ox {

    template<typename TYPE>
    struct TomatoOptions;

    enum paramType_t {
        T1 = 0,
        T2 = 1,
        T2star = 2,
        Perf = 3
    };

    static const char *calculatorsTypeNames[] = {
            "T1_MOLLI",
            "T1_SHMOLLI",
            "T1_SHMOLLI_original",
            "T2"
    };

    enum calculatorsType_t {
        T1_MOLLI = 0,
        T1_SHMOLLI = 1,
        T1_SHMOLLI_original = 2,
        T2_ThreeParam = 3,
        lastCalculatorType = T2_ThreeParam
    };

    static int calculatorsAvailability[] = {
            1, // T1_MOLLI
            1, // T1_SHMOLLI
#ifdef USE_PRIVATE_NR2
            1, // T1_SHMOLLI_original
#else
            0, // T1_SHMOLLI_original
#endif
            1 // T2
    };

    static int calculatorsParamsToCalculate[] = {
            T1, // T1_MOLLI
            T1, // T1_SHMOLLI
            T1, // T1_SHMOLLI_original
            T2  // T2_ThreeParam
    };

    template<typename TYPE>
    class FactoryOfCalculators {
    public:

        static Calculator<TYPE>* newByFactory(TomatoOptions<TYPE> *opts){
            Calculator<TYPE> *calculatorT1 = 0; //nullpointer
            switch (opts->parameter_to_map){
                case T1_MOLLI: {
                    calculatorT1 = new CalculatorT1Molli<TYPE>();
                    break;
                }
                case T1_SHMOLLI: {
                    calculatorT1 = new CalculatorT1Shmolli<TYPE>();
                    break;
                }
#ifdef USE_PRIVATE_NR2
                case T1_SHMOLLI_original: {
                    calculatorT1 = new CalculatorT1ShmolliOriginal<TYPE>();
                    break;
                }
#endif
                case T2_ThreeParam: {
                    calculatorT1 = new CalculatorT2<TYPE>();
                    break;
                }
                default:
                    throw std::runtime_error("parameter_to_map not available");

            }

            calculatorT1->setMeanCutOff(opts->mean_cut_off);

            return calculatorT1;
        }

        static void disp(int parameter_to_map = -1){

            if (parameter_to_map >= 0) {
                printf("%-28s%-22s", " parameter_to_map: ", calculatorsTypeNames[parameter_to_map]);
            }

            printf("options: [ ");

            for (int i = 0; i < lastCalculatorType+1; i++){
                if(calculatorsAvailability[i]){
                    printf("%s ", calculatorsTypeNames[i]);
                }
            }

            printf("] \n");
        }
    };

} // namespace Ox

#endif //Tomato_OXFACTORYOFCalculators_H
back to top