57 std::vector<value::status> value_status;
59 std::optional<std::vector<T>> global_data;
60 std::optional<std::vector<value::status>> global_value_status;
63 bool operator==(
const FieldData& other)
const {
64 return this->data == other.data &&
65 this->value_status == other.value_status &&
66 this->kw_info == other.kw_info &&
67 this->global_data == other.global_data &&
68 this->global_value_status == other.global_value_status;
75 data(std::vector<T>(active_size)),
76 value_status(active_size, value::status::uninitialized),
80 if (global_size != 0) {
81 this->global_data = std::vector<T>(global_size);
82 this->global_value_status = std::vector<value::status>(global_size, value::status::uninitialized);
86 this->default_assign( *info.scalar_init );
90 std::size_t size()
const {
91 return this->data.size();
98 static const std::array<value::status,2> invalid_value = {value::status::uninitialized, value::status::empty_default};
99 const auto& it = std::find_first_of(this->value_status.begin(), this->value_status.end(), invalid_value.begin(), invalid_value.end());
100 this->all_set = (it == this->value_status.end());
102 return this->all_set;
105 bool valid_default()
const {
106 return std::all_of( this->value_status.begin(), this->value_status.end(), [] (
const value::status& status) {return status == value::status::valid_default; });
110 void compress(
const std::vector<bool>& active_map) {
111 Fieldprops::compress(this->data, active_map);
112 Fieldprops::compress(this->value_status, active_map);
115 void copy(
const FieldData<T>& src,
const std::vector<Box::cell_index>& index_list) {
116 for (
const auto& ci : index_list) {
117 this->data[ci.active_index] = src.data[ci.active_index];
118 this->value_status[ci.active_index] = src.value_status[ci.active_index];
122 void default_assign(T value) {
123 std::fill(this->data.begin(), this->data.end(), value);
124 std::fill(this->value_status.begin(), this->value_status.end(), value::status::valid_default);
126 if (this->global_data) {
127 std::fill(this->global_data->begin(), this->global_data->end(), value);
128 std::fill(this->global_value_status->begin(), this->global_value_status->end(), value::status::valid_default);
132 void default_assign(
const std::vector<T>& src) {
133 if (src.size() != this->size())
134 throw std::invalid_argument(
"Size mismatch got: " + std::to_string(src.size()) +
" expected: " + std::to_string(this->size()));
136 std::copy(src.begin(), src.end(), this->data.begin());
137 std::fill(this->value_status.begin(), this->value_status.end(), value::status::valid_default);
140 void default_update(
const std::vector<T>& src) {
141 if (src.size() != this->size())
142 throw std::invalid_argument(
"Size mismatch got: " + std::to_string(src.size()) +
" expected: " + std::to_string(this->size()));
144 for (std::size_t i = 0; i < src.size(); i++) {
145 if (!value::has_value(this->value_status[i])) {
146 this->value_status[i] = value::status::valid_default;
147 this->data[i] = src[i];
152 void update(std::size_t index, T value, value::status status) {
153 this->data[index] = value;
154 this->value_status[index] = status;