4 #ifndef XGBOOST_JSON_H_
5 #define XGBOOST_JSON_H_
8 #include <xgboost/logging.h>
15 #include <type_traits>
74 return T::IsClassOf(value);
77 template <
typename T,
typename U>
80 return dynamic_cast<T*
>(value);
82 LOG(FATAL) <<
"Invalid cast, from " + value->TypeStr() +
" to " + T().TypeStr();
84 return dynamic_cast<T*
>(value);
115 std::vector<Json> vec_;
132 std::vector<Json>
const&
GetArray() && {
return vec_; }
133 std::vector<Json>
const&
GetArray() const & {
return vec_; }
150 template <
typename T, Value::ValueKind kind>
164 void Set(
size_t i, T v) { vec_[i] = v; }
165 size_t Size()
const {
return vec_.size(); }
169 std::vector<T>
const&
GetArray() && {
return vec_; }
170 std::vector<T>
const&
GetArray() const& {
return vec_; }
207 using Map = std::map<std::string, Json, std::less<>>;
236 template <
typename T,
typename U>
237 using IsSameT = std::enable_if_t<std::is_same_v<std::remove_cv_t<T>, std::remove_cv_t<U>>>;
239 template <
typename T>
240 using IsF64T = std::enable_if_t<std::is_same_v<T, double>>;
252 template <
typename FloatT,
typename detail::IsSameT<FloatT, Float>* =
nullptr>
254 template <
typename FloatT,
typename detail::IsF64T<FloatT>* =
nullptr>
275 template <
typename IntT>
276 using Not32SizeT = std::enable_if_t<std::is_same_v<IntT, std::uint32_t> &&
277 !std::is_same_v<std::size_t, std::uint32_t>>;
290 template <
typename IntT,
typename detail::IsSameT<IntT, Int>* =
nullptr>
292 template <
typename IntT,
typename detail::IsSameT<IntT, std::
size_t>* =
nullptr>
295 template <
typename IntT,
typename detail::IsSameT<IntT, std::
int32_t>* =
nullptr>
298 template <
typename IntT,
337 bool boolean_ =
false;
342 template <
typename Bool,
typename detail::IsSameT<std::remove_cv_t<Bool>,
bool>* =
nullptr>
391 static void Dump(
Json json, std::string* out, std::ios::openmode mode = std::ios::out);
392 static void Dump(
Json json, std::vector<char>* out, std::ios::openmode mode = std::ios::out);
396 template <
typename Container = std::
string>
398 if constexpr (std::is_same_v<Container, std::string>) {
403 std::vector<char> str;
414 ptr_.reset(
new JsonNumber(std::move(number)));
426 ptr_.reset(
new JsonArray(std::forward<JsonArray>(array)));
430 template <
typename T, Value::ValueKind kind>
433 template <
typename T, Value::ValueKind kind>
441 ptr_.reset(
new JsonObject(std::forward<JsonObject>(
object)));
447 ptr_.reset(
new JsonString(std::forward<JsonString>(str)));
461 ptr_.reset(
new JsonNull(std::move(
null)));
486 return *ptr_ == *(rhs.ptr_);
511 template <
typename T>
519 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonNumber>>* =
nullptr>
521 return val.GetNumber();
523 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonNumber const>>* =
nullptr>
525 return val.GetNumber();
529 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonInteger>>* =
nullptr>
531 return val.GetInteger();
533 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonInteger const>>* =
nullptr>
535 return val.GetInteger();
539 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonString>>* =
nullptr>
541 return val.GetString();
543 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonString const>>* =
nullptr>
545 return val.GetString();
549 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonBoolean>>* =
nullptr>
551 return val.GetBoolean();
553 template <
typename T,
554 typename std::enable_if_t<std::is_same_v<T, JsonBoolean const>>* =
nullptr>
556 return val.GetBoolean();
560 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonArray>>* =
nullptr>
562 return val.GetArray();
564 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonArray const>>* =
nullptr>
566 return val.GetArray();
570 template <
typename T, Value::ValueKind kind>
574 template <
typename T, Value::ValueKind kind>
580 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonObject>>* =
nullptr>
582 return val.GetObject();
584 template <
typename T,
typename std::enable_if_t<std::is_same_v<T, JsonObject const>>* =
nullptr>
586 return val.GetObject();
598 template <
typename T,
typename U>
600 auto& value = *Cast<T>(&json.GetValue());
621 template <
typename Parameter>
624 for (
auto const& kv : param.__DICT__()) {
625 obj[kv.first] = kv.second;
640 template <
typename Parameter>
642 auto const& j_param = get<Object const>(obj);
644 for (
auto const& kv : j_param) {
645 args.emplace_back(kv.first, get<String const>(kv.second));
647 return param->UpdateAllowUnknown(args);
Helper class for embedding reference counting into client objects. See https://www....
Definition: intrusive_ptr.h:20
Implementation of Intrusive Pointer. A smart pointer that points to an object with an embedded refere...
Definition: intrusive_ptr.h:73
JsonArray(std::vector< Json > const &arr)
Definition: json.h:121
JsonArray(JsonArray const &that)=delete
Json & operator[](std::string const &key) override
Definition: json.h:130
std::vector< Json > const & GetArray() &&
Definition: json.h:132
std::vector< Json > & GetArray() &
Definition: json.h:134
JsonArray(std::vector< Json > &&arr) noexcept
Definition: json.h:119
JsonArray(JsonArray &&that) noexcept
bool operator==(Value const &rhs) const override
void Save(JsonWriter *writer) const override
JsonArray()
Definition: json.h:118
Json & operator[](int ind) override
Definition: json.h:128
Value & operator=(Value const &rhs) override=delete
static bool IsClassOf(Value const *value)
Definition: json.h:139
std::vector< Json > const & GetArray() const &
Definition: json.h:133
Describes both true and false.
Definition: json.h:336
bool const & GetBoolean() const &
Definition: json.h:350
static bool IsClassOf(Value const *value)
Definition: json.h:356
Value & operator=(Value const &rhs) override=delete
bool const & GetBoolean() &&
Definition: json.h:349
bool operator==(Value const &rhs) const override
void Save(JsonWriter *writer) const override
JsonBoolean()
Definition: json.h:340
JsonBoolean(Bool value)
Definition: json.h:343
JsonBoolean(JsonBoolean &&value) noexcept
Definition: json.h:344
bool & GetBoolean() &
Definition: json.h:351
void Save(JsonWriter *writer) const override
JsonInteger(IntT value)
Definition: json.h:291
int64_t Int
Definition: json.h:283
JsonInteger(JsonInteger &&that) noexcept
Definition: json.h:303
Value & operator=(Value const &rhs) override=delete
Int const & GetInteger() const &
Definition: json.h:310
bool operator==(Value const &rhs) const override
static bool IsClassOf(Value const *value)
Definition: json.h:314
JsonInteger()
Definition: json.h:289
Int & GetInteger() &
Definition: json.h:311
Int const & GetInteger() &&
Definition: json.h:309
JsonNull(std::nullptr_t)
Definition: json.h:322
JsonNull()
Definition: json.h:321
bool operator==(Value const &rhs) const override
JsonNull(JsonNull &&) noexcept
Definition: json.h:323
Value & operator=(Value const &rhs) override=delete
void Save(JsonWriter *writer) const override
static bool IsClassOf(Value const *value)
Definition: json.h:330
Float const & GetNumber() const &
Definition: json.h:263
Float const & GetNumber() &&
Definition: json.h:262
Value & operator=(Value const &rhs) override=delete
JsonNumber(JsonNumber const &that)=delete
Float & GetNumber() &
Definition: json.h:264
JsonNumber(JsonNumber &&that) noexcept
Definition: json.h:258
bool operator==(Value const &rhs) const override
float Float
Definition: json.h:245
JsonNumber()
Definition: json.h:251
static bool IsClassOf(Value const *value)
Definition: json.h:269
JsonNumber(FloatT value)
Definition: json.h:253
void Save(JsonWriter *writer) const override
Json & operator[](int ind) override
Definition: json.h:221
Map const & GetObject() &&
Definition: json.h:224
JsonObject(JsonObject &&that) noexcept
void Save(JsonWriter *writer) const override
Map const & GetObject() const &
Definition: json.h:225
Json & operator[](std::string const &key) override
Definition: json.h:222
bool operator==(Value const &rhs) const override
~JsonObject() override=default
std::map< std::string, Json, std::less<> > Map
Definition: json.h:207
Value & operator=(Value const &rhs) override=delete
Map & GetObject() &
Definition: json.h:226
JsonObject(JsonObject const &that)=delete
static bool IsClassOf(Value const *value)
Definition: json.h:231
JsonObject()
Definition: json.h:213
JsonObject(Map &&object) noexcept
A json reader, currently error checking and utf-8 is not fully supported.
Definition: json_io.h:20
static bool IsClassOf(Value const *value)
Definition: json.h:109
JsonString(std::string &&str) noexcept
Definition: json.h:94
void Save(JsonWriter *writer) const override
std::string const & GetString() &&
Definition: json.h:102
std::string & GetString() &
Definition: json.h:104
bool operator==(Value const &rhs) const override
Value & operator=(Value const &rhs) override=delete
JsonString(std::string const &str)
Definition: json.h:92
JsonString(JsonString &&str) noexcept
Definition: json.h:96
std::string const & GetString() const &
Definition: json.h:103
JsonString()
Definition: json.h:91
Typed array for Universal Binary JSON.
Definition: json.h:151
void Set(size_t i, T v)
Definition: json.h:164
std::vector< T > & GetArray() &
Definition: json.h:171
std::vector< T > const & GetArray() &&
Definition: json.h:169
size_t Size() const
Definition: json.h:165
T Type
Definition: json.h:155
void Save(JsonWriter *writer) const override
bool operator==(Value const &rhs) const override
JsonTypedArray(std::size_t n)
Definition: json.h:158
Value & operator=(Value const &rhs) override=delete
static bool IsClassOf(Value const *value)
Definition: json.h:173
JsonTypedArray(JsonTypedArray &&that) noexcept
Definition: json.h:159
JsonTypedArray()
Definition: json.h:157
std::vector< T > const & GetArray() const &
Definition: json.h:170
Definition: json_io.h:110
Data structure representing JSON format.
Definition: json.h:378
Json & operator=(JsonNumber number)
Definition: json.h:413
Json(JsonNull null)
Definition: json.h:458
Json & operator=(JsonTypedArray< T, kind > &&array)
Definition: json.h:434
Json & operator=(JsonString &&str)
Definition: json.h:446
Json & operator[](std::string const &key) const
Index Json object with a std::string, used for Json Object.
Definition: json.h:476
Json(JsonArray &&list)
Definition: json.h:424
Json(JsonObject &&object)
Definition: json.h:439
static void Dump(Json json, std::vector< char > *out, std::ios::openmode mode=std::ios::out)
Json(Json &&other) noexcept
Definition: json.h:469
Json(Json const &other)=default
Value const & GetValue() const &
Return the reference to stored Json value.
Definition: json.h:481
Json & operator=(Json const &other)=default
Json(JsonString &&str)
Definition: json.h:445
Json(JsonInteger integer)
Definition: json.h:418
Json & operator[](int ind) const
Index Json object with int, used for Json Array.
Definition: json.h:478
Json & operator=(JsonObject &&object)
Definition: json.h:440
Json & operator=(JsonArray &&array)
Definition: json.h:425
friend std::ostream & operator<<(std::ostream &os, Json const &j)
Definition: json.h:489
Json & operator=(JsonInteger integer)
Definition: json.h:419
Json & operator=(JsonBoolean boolean)
Definition: json.h:453
static Json Load(JsonReader *reader)
Pass your own JsonReader.
Json(JsonBoolean boolean)
Definition: json.h:451
IntrusivePtr< Value > const & Ptr() const
Definition: json.h:496
Json(JsonTypedArray< T, kind > &&list)
Definition: json.h:431
Json(JsonNumber number)
Definition: json.h:412
Json & operator=(JsonNull null)
Definition: json.h:460
static Container Dump(Json json)
Definition: json.h:397
bool operator==(Json const &rhs) const
Definition: json.h:485
static void Dump(Json json, JsonWriter *writer)
Use your own JsonWriter.
Json & operator=(Json &&other) noexcept
Definition: json.h:470
static Json Load(StringView str, std::ios::openmode mode=std::ios::in)
Decode the JSON object. Optional parameter mode for choosing between text and binary (ubjson) input.
static void Dump(Json json, std::string *out, std::ios::openmode mode=std::ios::out)
Encode the JSON object. Optional parameter mode for choosing between text and binary (ubjson) output.
Value const & GetValue() &&
Definition: json.h:482
Value & GetValue() &
Definition: json.h:483
virtual Value & operator=(Value const &rhs)=delete
virtual bool operator==(Value const &rhs) const =0
Value(ValueKind _kind)
Definition: json.h:53
virtual Json & operator[](std::string const &key)
virtual Json & operator[](int ind)
ValueKind
Simplified implementation of LLVM RTTI.
Definition: json.h:35
friend IntrusivePtrCell & IntrusivePtrRefCount(xgboost::Value const *t) noexcept
Definition: json.h:29
ValueKind Type() const
Definition: json.h:55
std::string TypeStr() const
virtual void Save(JsonWriter *writer) const =0
Implementation of Intrusive Ptr.
Definition: intrusive_ptr.h:207
void swap(xgboost::IntrusivePtr< T > &x, xgboost::IntrusivePtr< T > &y) noexcept
Definition: intrusive_ptr.h:209
std::enable_if_t< std::is_same_v< IntT, std::uint32_t > &&!std::is_same_v< std::size_t, std::uint32_t > > Not32SizeT
Definition: json.h:277
std::enable_if_t< std::is_same_v< T, double > > IsF64T
Definition: json.h:240
std::enable_if_t< std::is_same_v< std::remove_cv_t< T >, std::remove_cv_t< U > >> IsSameT
Definition: json.h:237
JsonNumber::Float & GetImpl(T &val)
Definition: json.h:520
Core data structure for multi-target trees.
Definition: base.h:89
std::vector< std::pair< std::string, std::string > > Args
Definition: base.h:316
bool IsA(Value const *value)
Definition: json.h:73
auto get(U &json) -> decltype(detail::GetImpl(*Cast< T >(&json.GetValue())))&
Get Json value.
Definition: json.h:599
T * Cast(U *value)
Definition: json.h:78
Object ToJson(Parameter const ¶m)
Convert XGBoost parameter to JSON object.
Definition: json.h:622
Args FromJson(Json const &obj, Parameter *param)
Load a XGBoost parameter from a JSON object.
Definition: json.h:641
macro for using C++11 enum class as DMLC parameter
Definition: string_view.h:16