This struct bundles a function and its first derivatives. 
        unsigned nGrid = js["grid"]["generator"]["initial"]["n"].asUInt();
        unsigned NxGrid = js["grid"]["generator"]["initial"]["Nx"].asUInt();
        unsigned NyGrid = js["grid"]["generator"]["initial"]["Ny"].asUInt();
        double epsHector = js["grid"]["generator"]["eps"].asDouble();
        if( mode == 0)
        {
            std::cout << " ... of type conformal ...\n";
                              mag.
R0(), 0., nGrid, NxGrid, NyGrid, epsHector,
                              true);
        }
        else if( mode == 1)
        {
            std::cout << " ... of type adaption ...\n";
                              psi_1, mag.
R0(), 0., nGrid, NxGrid, NyGrid,
                              epsHector, true);
        }
        else
        {
            std::cout << " ... of type monitor metric ...\n";
                              psi_1, mag.
R0(), 0., nGrid, NxGrid, NyGrid,
                              epsHector, true);
        }