tomwalters@23: // Copyright 2008-2010, Thomas Walters tomwalters@23: // tomwalters@23: // AIM-C: A C++ implementation of the Auditory Image Model tomwalters@23: // http://www.acousticscale.org/AIMC tomwalters@23: // tomwalters@23: // This program is free software: you can redistribute it and/or modify tomwalters@23: // it under the terms of the GNU General Public License as published by tomwalters@23: // the Free Software Foundation, either version 3 of the License, or tomwalters@23: // (at your option) any later version. tomwalters@23: // tomwalters@23: // This program is distributed in the hope that it will be useful, tomwalters@23: // but WITHOUT ANY WARRANTY; without even the implied warranty of tomwalters@23: // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the tomwalters@23: // GNU General Public License for more details. tomwalters@23: // tomwalters@23: // You should have received a copy of the GNU General Public License tomwalters@23: // along with this program. If not, see . tomwalters@23: tomwalters@23: #include "Modules/Input/ModuleFileInput.h" tomwalters@23: #include "Modules/BMM/ModuleGammatone.h" tomwalters@23: #include "Modules/BMM/ModulePZFC.h" tomwalters@23: #include "Modules/NAP/ModuleHCL.h" tomwalters@23: #include "Modules/Strobes/ModuleParabola.h" tomwalters@23: #include "Modules/SAI/ModuleSAI.h" tomwalters@23: #include "Modules/SSI/ModuleSSI.h" tomwalters@23: #include "Modules/Profile/ModuleSlice.h" tomwalters@23: #include "Modules/Profile/ModuleScaler.h" tomwalters@23: #include "Modules/Features/ModuleGaussians.h" tomwalters@23: #include "Modules/Output/FileOutputHTK.h" tomwalters@23: tomwalters@23: #include "Support/ModuleFactory.h" tomwalters@23: tomwalters@23: namespace aimc { tomwalters@23: Module* ModuleFactory::Create(string module_name_, Parameters* params) { tomwalters@23: if (module_name_.compare("gt") == 0) tomwalters@23: return new ModuleGammatone(params); tomwalters@23: tomwalters@23: if (module_name_.compare("pzfc") == 0) tomwalters@23: return new ModulePZFC(params); tomwalters@23: tomwalters@23: if (module_name_.compare("gaussians") == 0) tomwalters@23: return new ModuleGaussians(params); tomwalters@23: tomwalters@23: if (module_name_.compare("file_input") == 0) tomwalters@23: return new ModuleFileInput(params); tomwalters@23: tomwalters@23: if (module_name_.compare("hcl") == 0) tomwalters@23: return new ModuleHCL(params); tomwalters@23: tomwalters@23: if (module_name_.compare("htk_out") == 0) tomwalters@23: return new FileOutputHTK(params); tomwalters@23: tomwalters@23: if (module_name_.compare("scaler") == 0) tomwalters@23: return new ModuleScaler(params); tomwalters@23: tomwalters@23: if (module_name_.compare("slice") == 0) tomwalters@23: return new ModuleSlice(params); tomwalters@23: tomwalters@23: if (module_name_.compare("weighted_sai") == 0) tomwalters@23: return new ModuleSAI(params); tomwalters@23: tomwalters@23: if (module_name_.compare("ssi") == 0) tomwalters@23: return new ModuleSSI(params); tomwalters@23: tomwalters@23: if (module_name_.compare("parabola") == 0) tomwalters@23: return new ModuleParabola(params); tomwalters@23: tomwalters@23: return NULL; tomwalters@23: } tomwalters@23: } // namespace aimc