repmat.hpp
1 /*
2  * This file is part of CasADi.
3  *
4  * CasADi -- A symbolic framework for dynamic optimization.
5  * Copyright (C) 2010-2023 Joel Andersson, Joris Gillis, Moritz Diehl,
6  * KU Leuven. All rights reserved.
7  * Copyright (C) 2011-2014 Greg Horn
8  *
9  * CasADi is free software; you can redistribute it and/or
10  * modify it under the terms of the GNU Lesser General Public
11  * License as published by the Free Software Foundation; either
12  * version 3 of the License, or (at your option) any later version.
13  *
14  * CasADi is distributed in the hope that it will be useful,
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17  * Lesser General Public License for more details.
18  *
19  * You should have received a copy of the GNU Lesser General Public
20  * License along with CasADi; if not, write to the Free Software
21  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
22  *
23  */
24 
25 
26 #ifndef CASADI_REPMAT_HPP
27 #define CASADI_REPMAT_HPP
28 
29 #include "mx_node.hpp"
30 #include <map>
31 #include <stack>
32 
34 
35 namespace casadi {
36 
43  class CASADI_EXPORT HorzRepmat : public MXNode {
44  public:
45 
47  HorzRepmat(const MX& x, casadi_int n);
48 
50  template<typename T>
51  int eval_gen(const T** arg, T** res, casadi_int* iw, T* w) const;
52 
54  ~HorzRepmat() override {}
55 
59  std::string disp(const std::vector<std::string>& arg) const override;
60 
62  int eval(const double** arg, double** res, casadi_int* iw, double* w) const override;
63 
65  int eval_sx(const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w) const override;
66 
70  void eval_mx(const std::vector<MX>& arg, std::vector<MX>& res) const override;
71 
75  void eval_linear(const std::vector<std::array<MX, 3> >& arg,
76  std::vector<std::array<MX, 3> >& res) const override {
77  eval_linear_rearrange(arg, res);
78  }
79 
83  int sp_forward(const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w) const override;
84 
88  int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w) const override;
89 
93  void ad_forward(const std::vector<std::vector<MX> >& fseed,
94  std::vector<std::vector<MX> >& fsens) const override;
95 
99  void ad_reverse(const std::vector<std::vector<MX> >& aseed,
100  std::vector<std::vector<MX> >& asens) const override;
101 
105  void generate(CodeGenerator& g,
106  const std::vector<casadi_int>& arg,
107  const std::vector<casadi_int>& res,
108  const std::vector<bool>& arg_is_ref,
109  std::vector<bool>& res_is_ref) const override;
110 
114  casadi_int op() const override { return OP_HORZREPMAT;}
115 
116  casadi_int n_;
117 
121  void serialize_body(SerializingStream& s) const override;
122 
126  static MXNode* deserialize(DeserializingStream& s) { return new HorzRepmat(s); }
127 
128  protected:
132  explicit HorzRepmat(DeserializingStream& s);
133  };
134 
141  class CASADI_EXPORT HorzRepsum : public MXNode {
142  public:
143 
145  HorzRepsum(const MX& x, casadi_int n);
146 
148  template<typename T, typename R>
149  int eval_gen(const T** arg, T** res, casadi_int* iw, T* w, R reduction) const;
150 
152  ~HorzRepsum() override {}
153 
157  std::string disp(const std::vector<std::string>& arg) const override;
158 
160  int eval(const double** arg, double** res, casadi_int* iw, double* w) const override;
161 
163  int eval_sx(const SXElem** arg, SXElem** res, casadi_int* iw, SXElem* w) const override;
164 
168  void eval_mx(const std::vector<MX>& arg, std::vector<MX>& res) const override;
169 
173  int sp_forward(const bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w) const override;
174 
178  int sp_reverse(bvec_t** arg, bvec_t** res, casadi_int* iw, bvec_t* w) const override;
179 
183  void ad_forward(const std::vector<std::vector<MX> >& fseed,
184  std::vector<std::vector<MX> >& fsens) const override;
185 
189  void ad_reverse(const std::vector<std::vector<MX> >& aseed,
190  std::vector<std::vector<MX> >& asens) const override;
191 
195  void generate(CodeGenerator& g,
196  const std::vector<casadi_int>& arg,
197  const std::vector<casadi_int>& res,
198  const std::vector<bool>& arg_is_ref,
199  std::vector<bool>& res_is_ref) const override;
200 
204  casadi_int op() const override { return OP_HORZREPSUM;}
205 
206  casadi_int n_;
207 
211  void serialize_body(SerializingStream& s) const override;
212 
216  static MXNode* deserialize(DeserializingStream& s) { return new HorzRepsum(s); }
217 
218  protected:
222  explicit HorzRepsum(DeserializingStream& s);
223  };
224 
225 } // namespace casadi
227 
228 #endif // CASADI_REPMAT_HPP
The casadi namespace.
Definition: archiver.hpp:32