Raw File
OxFactoryOfFitters.hxx
/*!
 * \file OxFactoryOfFitters.hxx
 * \author Konrad Werys
 * \date 2019/11/26
 */

#ifndef Tomato_OXFACTORYOFFitters_HXX
#define Tomato_OXFACTORYOFFitters_HXX

#include "OxFitterAmoebaVnl.h"
#include "OxFitterLevenbergMarquardtVnl.h"
#ifdef USE_PRIVATE_NR2
#include "OxFitterAmoebaPrivateNr2.h"
#endif
#ifdef USE_LMFIT
#include "OxFitterLevenbergMarquardtLmfit.h"
#endif


namespace Ox {

    template < typename TYPE >
    Fitter<TYPE>*
    FactoryOfFitters<TYPE>
    ::newByFactory(TomatoOptions<TYPE> *opts){
        Fitter<TYPE> *fitter = 0; //nullpointer

        switch (opts->fitting_method){
            case AmoebaVnl: {
                fitter = new FitterAmoebaVnl<TYPE>();
                break;
            }
            case LevMarVnl: {
                fitter = new FitterLevenbergMarquardtVnl<TYPE>();
                break;
            }
#ifdef USE_PRIVATE_NR2
            case AmoebaPrivateNr2: {
                fitter = new FitterAmoebaPrivateNr2<TYPE>();
                break;
            }
#endif

#ifdef USE_LMFIT
            case LevMarLmfit: {
                fitter = new FitterLevenbergMarquardtLmfit<TYPE>();
                break;
            }
#endif
            default:
                throw std::runtime_error("fitting_method not available");
        }

        fitter->setMaxFunctionEvals(opts->max_function_evals);
        fitter->setFTolerance(opts->fTolerance);
        fitter->setUseGradient(opts->use_gradient);

        return fitter;
    }

    template < typename TYPE >
    void
    FactoryOfFitters<TYPE>
    ::disp(int fitting_method){

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

        printf("options: [ ");

        for (int i = 0; i < lastFitterType+1; i++){

            if(fittersAvailability[i]){
                printf("%s ", fittersTypeNames[i]);
            }
        }

        printf("] \n");
    }

} // namespace Ox

#endif //Tomato_OXFACTORYOFFitters_HXX
back to top