1
0
Fork 0
mirror of https://github.com/cosmo-sims/MUSIC.git synced 2024-09-11 07:53:43 +02:00
MUSIC/src/transfer_function.cc
2024-02-24 10:52:43 +01:00

64 lines
2.3 KiB
C++

// This file is part of MUSIC
// A software package to generate ICs for cosmological simulations
// Copyright (C) 2010-2024 by Oliver Hahn
//
// monofonIC is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// monofonIC is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <http://www.gnu.org/licenses/>.
#include "transfer_function.hh"
std::map< std::string, transfer_function_plugin_creator *>&
get_transfer_function_plugin_map()
{
static std::map< std::string, transfer_function_plugin_creator* > transfer_function_plugin_map;
return transfer_function_plugin_map;
}
void print_transfer_function_plugins()
{
std::map< std::string, transfer_function_plugin_creator *>& m = get_transfer_function_plugin_map();
std::map< std::string, transfer_function_plugin_creator *>::iterator it;
it = m.begin();
std::cout << " - Available transfer function plug-ins:\n";
while( it!=m.end() )
{
if( (*it).second )
std::cout << "\t\'" << (*it).first << "\'\n";
++it;
}
}
std::unique_ptr<transfer_function_plugin> select_transfer_function_plugin( config_file& cf, const cosmology::parameters& cp )
{
std::string tfname = cf.get_value<std::string>( "cosmology", "transfer" );
transfer_function_plugin_creator *the_transfer_function_plugin_creator = get_transfer_function_plugin_map()[ tfname ];
if( !the_transfer_function_plugin_creator )
{
std::cerr << " - Error: transfer function plug-in \'" << tfname << "\' not found." << std::endl;
music::elog.Print("Invalid/Unregistered transfer function plug-in encountered : %s",tfname.c_str() );
print_transfer_function_plugins();
throw std::runtime_error("Unknown transfer function plug-in");
}else
{
std::cout << " - Selecting transfer function plug-in \'" << tfname << "\'..." << std::endl;
music::ulog.Print("Selecting transfer function plug-in : %s",tfname.c_str() );
}
return the_transfer_function_plugin_creator->create( cf, cp );
}