26 #ifndef CASADI_LOGSUMEXP_HPP
27 #define CASADI_LOGSUMEXP_HPP
29 #include "mx_node.hpp"
53 int eval_gen(
const T** arg, T** res, casadi_int* iw, T* w)
const;
56 int eval(
const double** arg,
double** res, casadi_int* iw,
double* w)
const override;
61 void eval_mx(
const std::vector<MX>& arg, std::vector<MX>& res)
const override;
66 void ad_forward(
const std::vector<std::vector<MX> >& fseed,
67 std::vector<std::vector<MX> >& fsens)
const override;
72 void ad_reverse(
const std::vector<std::vector<MX> >& aseed,
73 std::vector<std::vector<MX> >& asens)
const override;
79 const std::vector<casadi_int>& arg,
80 const std::vector<casadi_int>& res,
81 const std::vector<bool>& arg_is_ref,
82 std::vector<bool>& res_is_ref)
const override;
90 std::string disp(
const std::vector<std::string>& arg)
const override;
Helper class for C code generation.
Helper class for Serialization.
Calculate logsumexp update.
casadi_int op() const override
Get the operation.
~LogSumExp() override
Destructor.
LogSumExp(DeserializingStream &s)
static MXNode * deserialize(DeserializingStream &s)
Deserialize without type information.
casadi_int n_inplace() const override
Can the operation be performed inplace (i.e. overwrite the result)
Node class for MX objects.