diff --git a/include/config_file.hh b/include/config_file.hh index f0b4491..4f741a1 100644 --- a/include/config_file.hh +++ b/include/config_file.hh @@ -162,6 +162,9 @@ public: items_[in_section + '/' + name] = value; } + size_t lastindex = filename.find_last_of('.'); + std::string config_basename = filename.substr(0, lastindex); + items_["meta/config_basename"] = config_basename; } //! inserts a key/value pair in the hash map @@ -288,6 +291,12 @@ public: return get_value_safe("", key, default_value); } + std::string get_path_relative_to_config(std::string const &filename) const { + std::string empty_string; + const std::string basename = get_value_safe("meta", "config_basename", empty_string); + return basename + "_" + filename; + } + //! dumps all key-value pairs to a std::ostream void dump(std::ostream &out) { std::map::const_iterator i = items_.begin(); diff --git a/src/ic_generator.cc b/src/ic_generator.cc index c0c4f2a..3064355 100644 --- a/src/ic_generator.cc +++ b/src/ic_generator.cc @@ -209,8 +209,8 @@ int run( config_file& the_config ) const real_t astart = 1.0/(1.0+zstart); const real_t volfac(std::pow(boxlen / ngrid / 2.0 / M_PI, 1.5)); - the_cosmo_calc->write_powerspectrum(astart, "input_powerspec.txt" ); - the_cosmo_calc->write_transfer("input_transfer.txt" ); + the_cosmo_calc->write_powerspectrum(astart, the_config.get_path_relative_to_config("input_powerspec.txt")); + the_cosmo_calc->write_transfer(the_config.get_path_relative_to_config("input_transfer.txt")); // the_cosmo_calc->compute_sigma_bc(); // abort(); @@ -763,7 +763,7 @@ int run( config_file& the_config ) }, psi); the_output_plugin->write_grid_data( rho, this_species, fluid_component::density ); - rho.Write_PowerSpectrum("input_powerspec_sampled_evolved_semiclassical.txt"); + rho.Write_PowerSpectrum(the_config.get_path_relative_to_config("input_powerspec_sampled_evolved_semiclassical.txt")); rho.FourierTransformBackward(); //====================================================================== diff --git a/src/main.cc b/src/main.cc index 4668964..db319dc 100644 --- a/src/main.cc +++ b/src/main.cc @@ -148,6 +148,12 @@ int main( int argc, char** argv ) // open the configuration file config_file the_config(argv[1]); + std::string log_filename = the_config.get_path_relative_to_config("log.txt"); + music::logger::set_output(log_filename); + music::ilog << " argv[1] : " << argv[1] << std::endl; + music::ilog << " config_basename : " << the_config.get_path_relative_to_config("") << std::endl; + music::ilog << " log file : " << log_filename << std::endl; + music::ilog << "-------------------------------------------------------------------------------" << std::endl; //------------------------------------------------------------------------------ // Set up FFTW diff --git a/src/plugins/transfer_CLASS.cc b/src/plugins/transfer_CLASS.cc index f748e22..a81ef81 100644 --- a/src/plugins/transfer_CLASS.cc +++ b/src/plugins/transfer_CLASS.cc @@ -203,7 +203,7 @@ class transfer_CLASS_plugin : public TransferFunction_plugin { this->tf_isnormalised_ = true; - ofs_class_input_.open("input_class_parameters.ini", std::ios::trunc); + ofs_class_input_.open(cf.get_path_relative_to_config("input_class_parameters.ini"), std::ios::trunc); // all cosmological parameters need to be passed through the_cosmo_calc