26 #ifndef CASADI_SERIALIZING_STREAM_HPP
27 #define CASADI_SERIALIZING_STREAM_HPP
31 #include <unordered_map>
47 class SharedObjectInternal;
49 class SerializingStream;
60 void*
get() {
return node; }
65 typedef std::map<std::string, GenericType>
Dict;
102 void unpack(std::ostream& s);
103 void unpack(
Slice& e);
106 #if SIZE_MAX != UINT_MAX || defined(__EMSCRIPTEN__) || defined(__POWERPC__)
107 void unpack(
unsigned int& e);
109 void unpack(
bool& e);
110 void unpack(casadi_int& e);
111 void unpack(
size_t& e);
112 void unpack(std::string& e);
113 void unpack(
double& e);
114 void unpack(
char& e);
117 assert_decoration(
'V');
121 for (
T& i : e) unpack(i);
124 template <
class K,
class V>
126 assert_decoration(
'D');
130 for (casadi_int i=0;i<s;++i) {
139 template <
class A,
class B>
141 assert_decoration(
'p');
147 void unpack(
const std::string& descr, T& e) {
151 casadi_assert(d==descr,
"Mismatch: '" + descr +
"' expected, got '" + d +
"'.");
157 void version(
const std::string& name,
int v);
158 int version(
const std::string& name);
159 int version(
const std::string& name,
int min,
int max);
171 template <
class T,
class M>
172 void shared_unpack(T& e) {
174 unpack(
"Shared::flag", i);
177 e = T::deserialize(*
this);
178 if (shared_map_) (*shared_map_)[e.get()] = nodes_.size();
179 nodes_.emplace_back(e.get());
184 unpack(
"Shared::reference", k);
186 e = T::create(
static_cast<M*
>(t.
get()));
190 casadi_assert_dev(
false);
199 void assert_decoration(
char e);
202 std::vector<UniversalNodeOwner> nodes_;
203 std::unordered_map<void*, casadi_int>* shared_map_ =
nullptr;
209 bool set_up_ =
false;
231 void pack(
const MX& e);
232 void pack(
const SXElem& e);
233 void pack(
const Linsol& e);
241 void pack(
const Fmu& e);
242 void pack(
const Slice& e);
244 void pack(std::istream& s);
246 #if SIZE_MAX != UINT_MAX || defined(__EMSCRIPTEN__) || defined(__POWERPC__)
247 void pack(
unsigned int e);
250 void pack(casadi_int e);
253 void pack(
const std::string& e);
256 void pack(
const std::vector<T>& e) {
258 pack(
static_cast<casadi_int
>(e.size()));
259 for (
auto&& i : e) pack(i);
261 template <
class K,
class V>
262 void pack(
const std::map<K, V>& e) {
264 pack(
static_cast<casadi_int
>(e.size()));
265 for (
const auto & i : e) {
270 template <
class A,
class B>
271 void pack(
const std::pair<A, B>& e) {
277 void pack(
const std::string& descr,
const T& e) {
278 if (debug_) pack(descr);
282 void pack(
const std::string& descr, T& e) {
283 if (debug_) pack(descr);
288 void version(
const std::string& name,
int v);
299 void decorate(
char e);
307 void shared_pack(
const T& e) {
308 auto it = shared_map_.find(e.get());
309 if (it==shared_map_.end()) {
311 pack(
"Shared::flag",
'd');
313 casadi_int r = shared_map_.size();
314 shared_map_[e.get()] = r;
315 if (nodes_) nodes_->emplace_back(e.get());
317 pack(
"Shared::flag",
'r');
318 pack(
"Shared::reference", it->second);
323 std::unordered_map<void*, casadi_int> shared_map_;
324 std::vector<UniversalNodeOwner>* nodes_ =
nullptr;
Helper class for Serialization.
void unpack(Sparsity &e)
Reconstruct an object from the input stream.
DeserializingStream(const DeserializingStream &)=delete
void unpack(Matrix< T > &e)
void unpack(std::pair< A, B > &e)
void unpack(std::vector< T > &e)
void unpack(std::map< K, V > &e)
void unpack(const std::string &descr, T &e)
Generic data type, can hold different types such as bool, casadi_int, std::string etc.
Sparse matrix class. SX and DM are specializations.
void serialize(std::ostream &stream) const
Serialize an object.
static Matrix< Scalar > deserialize(std::istream &stream)
Build Sparsity from serialization.
RAII class for reading from a zip file.
The basic scalar symbolic class of CasADi.
Internal node class for SX.
Helper class for Serialization.
void pack(const std::string &descr, const T &e)
void pack(const std::map< K, V > &e)
void pack(const std::pair< A, B > &e)
void pack(const std::string &descr, T &e)
void pack(const std::vector< T > &e)
void pack(const Matrix< T > &e)
Class representing a Slice.
UniversalNodeOwner & operator=(const UniversalNodeOwner &other)=delete
UniversalNodeOwner()=delete
UniversalNodeOwner(const UniversalNodeOwner &)=delete
GenericType::Dict Dict
C++ equivalent of Python's dict or MATLAB's struct.