#ifndef MLPP_ACTIVATION_H #define MLPP_ACTIVATION_H // // Activation.hpp // // Created by Marc Melikyan on 1/16/21. // #include "core/math/math_defs.h" #include class MLPPActivation { public: real_t linear(real_t z, bool deriv = 0); std::vector linear(std::vector z, bool deriv = 0); std::vector> linear(std::vector> z, bool deriv = 0); real_t sigmoid(real_t z, bool deriv = 0); std::vector sigmoid(std::vector z, bool deriv = 0); std::vector> sigmoid(std::vector> z, bool deriv = 0); std::vector softmax(std::vector z, bool deriv = 0); std::vector> softmax(std::vector> z, bool deriv = 0); std::vector adjSoftmax(std::vector z); std::vector> adjSoftmax(std::vector> z); std::vector> softmaxDeriv(std::vector z); std::vector>> softmaxDeriv(std::vector> z); real_t softplus(real_t z, bool deriv = 0); std::vector softplus(std::vector z, bool deriv = 0); std::vector> softplus(std::vector> z, bool deriv = 0); real_t softsign(real_t z, bool deriv = 0); std::vector softsign(std::vector z, bool deriv = 0); std::vector> softsign(std::vector> z, bool deriv = 0); real_t gaussianCDF(real_t z, bool deriv = 0); std::vector gaussianCDF(std::vector z, bool deriv = 0); std::vector> gaussianCDF(std::vector> z, bool deriv = 0); real_t cloglog(real_t z, bool deriv = 0); std::vector cloglog(std::vector z, bool deriv = 0); std::vector> cloglog(std::vector> z, bool deriv = 0); real_t logit(real_t z, bool deriv = 0); std::vector logit(std::vector z, bool deriv = 0); std::vector> logit(std::vector> z, bool deriv = 0); real_t unitStep(real_t z, bool deriv = 0); std::vector unitStep(std::vector z, bool deriv = 0); std::vector> unitStep(std::vector> z, bool deriv = 0); real_t swish(real_t z, bool deriv = 0); std::vector swish(std::vector z, bool deriv = 0); std::vector> swish(std::vector> z, bool deriv = 0); real_t mish(real_t z, bool deriv = 0); std::vector mish(std::vector z, bool deriv = 0); std::vector> mish(std::vector> z, bool deriv = 0); real_t sinc(real_t z, bool deriv = 0); std::vector sinc(std::vector z, bool deriv = 0); std::vector> sinc(std::vector> z, bool deriv = 0); real_t RELU(real_t z, bool deriv = 0); std::vector RELU(std::vector z, bool deriv = 0); std::vector> RELU(std::vector> z, bool deriv = 0); real_t leakyReLU(real_t z, real_t c, bool deriv = 0); std::vector leakyReLU(std::vector z, real_t c, bool deriv = 0); std::vector> leakyReLU(std::vector> z, real_t c, bool deriv = 0); real_t ELU(real_t z, real_t c, bool deriv = 0); std::vector ELU(std::vector z, real_t c, bool deriv = 0); std::vector> ELU(std::vector> z, real_t c, bool deriv = 0); real_t SELU(real_t z, real_t lambda, real_t c, bool deriv = 0); std::vector SELU(std::vector z, real_t lambda, real_t c, bool deriv = 0); std::vector> SELU(std::vector>, real_t lambda, real_t c, bool deriv = 0); real_t GELU(real_t z, bool deriv = 0); std::vector GELU(std::vector z, bool deriv = 0); std::vector> GELU(std::vector> z, bool deriv = 0); real_t sign(real_t z, bool deriv = 0); std::vector sign(std::vector z, bool deriv = 0); std::vector> sign(std::vector> z, bool deriv = 0); real_t sinh(real_t z, bool deriv = 0); std::vector sinh(std::vector z, bool deriv = 0); std::vector> sinh(std::vector> z, bool deriv = 0); real_t cosh(real_t z, bool deriv = 0); std::vector cosh(std::vector z, bool deriv = 0); std::vector> cosh(std::vector> z, bool deriv = 0); real_t tanh(real_t z, bool deriv = 0); std::vector tanh(std::vector z, bool deriv = 0); std::vector> tanh(std::vector> z, bool deriv = 0); real_t csch(real_t z, bool deriv = 0); std::vector csch(std::vector z, bool deriv = 0); std::vector> csch(std::vector> z, bool deriv = 0); real_t sech(real_t z, bool deriv = 0); std::vector sech(std::vector z, bool deriv = 0); std::vector> sech(std::vector> z, bool deriv = 0); real_t coth(real_t z, bool deriv = 0); std::vector coth(std::vector z, bool deriv = 0); std::vector> coth(std::vector> z, bool deriv = 0); real_t arsinh(real_t z, bool deriv = 0); std::vector arsinh(std::vector z, bool deriv = 0); std::vector> arsinh(std::vector> z, bool deriv = 0); real_t arcosh(real_t z, bool deriv = 0); std::vector arcosh(std::vector z, bool deriv = 0); std::vector> arcosh(std::vector> z, bool deriv = 0); real_t artanh(real_t z, bool deriv = 0); std::vector artanh(std::vector z, bool deriv = 0); std::vector> artanh(std::vector> z, bool deriv = 0); real_t arcsch(real_t z, bool deriv = 0); std::vector arcsch(std::vector z, bool deriv = 0); std::vector> arcsch(std::vector> z, bool deriv = 0); real_t arsech(real_t z, bool deriv = 0); std::vector arsech(std::vector z, bool deriv = 0); std::vector> arsech(std::vector> z, bool deriv = 0); real_t arcoth(real_t z, bool deriv = 0); std::vector arcoth(std::vector z, bool deriv = 0); std::vector> arcoth(std::vector> z, bool deriv = 0); std::vector activation(std::vector z, bool deriv, real_t (*function)(real_t, bool)); private: }; #endif /* Activation_hpp */