#ifndef MLPP_NUMERICAL_ANALYSIS_H #define MLPP_NUMERICAL_ANALYSIS_H /*************************************************************************/ /* numerical_analysis.h */ /*************************************************************************/ /* This file is part of: */ /* PMLPP Machine Learning Library */ /* https://github.com/Relintai/pmlpp */ /*************************************************************************/ /* Copyright (c) 2023-present Péter Magyar. */ /* Copyright (c) 2022-2023 Marc Melikyan */ /* */ /* Permission is hereby granted, free of charge, to any person obtaining */ /* a copy of this software and associated documentation files (the */ /* "Software"), to deal in the Software without restriction, including */ /* without limitation the rights to use, copy, modify, merge, publish, */ /* distribute, sublicense, and/or sell copies of the Software, and to */ /* permit persons to whom the Software is furnished to do so, subject to */ /* the following conditions: */ /* */ /* The above copyright notice and this permission notice shall be */ /* included in all copies or substantial portions of the Software. */ /* */ /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */ /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */ /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/ /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */ /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */ /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */ /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */ /*************************************************************************/ // // NumericalAnalysis.hpp // // #ifdef USING_SFW #include "sfw.h" #else #include "core/math/math_defs.h" #include "core/object/reference.h" #include "core/containers/vector.h" #include "core/string/ustring.h" #endif class MLPPVector; class MLPPMatrix; class MLPPTensor3; class MLPPNumericalAnalysis : public Reference { GDCLASS(MLPPNumericalAnalysis, Reference); public: /* A numerical method for derivatives is used. This may be subject to change, as an analytical method for calculating derivatives will most likely be used in the future. */ real_t num_diffr(real_t (*function)(real_t), real_t x); real_t num_diff_2r(real_t (*function)(real_t), real_t x); real_t num_diff_3r(real_t (*function)(real_t), real_t x); real_t constant_approximationr(real_t (*function)(real_t), real_t c); real_t linear_approximationr(real_t (*function)(real_t), real_t c, real_t x); real_t quadratic_approximationr(real_t (*function)(real_t), real_t c, real_t x); real_t cubic_approximationr(real_t (*function)(real_t), real_t c, real_t x); real_t num_diffv(real_t (*function)(const Ref &), const Ref &, int axis); real_t num_diff_2v(real_t (*function)(const Ref &), const Ref &, int axis1, int axis2); real_t num_diff_3v(real_t (*function)(const Ref &), const Ref &, int axis1, int axis2, int axis3); real_t newton_raphson_method(real_t (*function)(real_t), real_t x_0, real_t epoch_num); real_t halley_method(real_t (*function)(real_t), real_t x_0, real_t epoch_num); real_t inv_quadratic_interpolation(real_t (*function)(real_t), const Ref &x_0, int epoch_num); real_t eulerian_methodr(real_t (*derivative)(real_t), real_t q_0, real_t q_1, real_t p, real_t h); // Euler's method for solving diffrential equations. real_t eulerian_methodv(real_t (*derivative)(const Ref &), real_t q_0, real_t q_1, real_t p, real_t h); // Euler's method for solving diffrential equations. real_t growth_method(real_t C, real_t k, real_t t); // General growth-based diffrential equations can be solved by seperation of variables. Ref jacobian(real_t (*function)(const Ref &), const Ref &x); // Indeed, for functions with scalar outputs the Jacobians will be vectors. Ref hessian(real_t (*function)(const Ref &), const Ref &x); Ref third_order_tensor(real_t (*function)(const Ref &), const Ref &x); Vector> third_order_tensorvt(real_t (*function)(const Ref &), const Ref &x); real_t constant_approximationv(real_t (*function)(const Ref &), const Ref &c); real_t linear_approximationv(real_t (*function)(const Ref &), const Ref &c, const Ref &x); real_t quadratic_approximationv(real_t (*function)(const Ref &), const Ref &c, const Ref &x); real_t cubic_approximationv(real_t (*function)(const Ref &), const Ref &c, const Ref &x); real_t laplacian(real_t (*function)(const Ref &), const Ref &x); // laplacian String second_partial_derivative_test(real_t (*function)(const Ref &), const Ref &x); protected: static void _bind_methods(); }; #endif /* NumericalAnalysis_hpp */