Line data Source code
1 : // SPDX-License-Identifier: BSD-3-Clause 2 : // Copyright (c) 2023 Scipp contributors (https://github.com/scipp) 3 : /// @file 4 : /// @author Simon Heybrock 5 : #include "scipp/core/element/creation.h" 6 : #include "scipp/core/time_point.h" 7 : #include "scipp/variable/creation.h" 8 : #include "scipp/variable/shape.h" 9 : #include "scipp/variable/transform.h" 10 : #include "scipp/variable/variable_factory.h" 11 : 12 : namespace scipp::variable { 13 : 14 46367 : Variable empty(const Dimensions &dims, const units::Unit &unit, 15 : const DType type, const bool with_variances, 16 : const bool aligned) { 17 46367 : auto var = variableFactory().create(type, dims, unit, with_variances); 18 46367 : var.set_aligned(aligned); 19 46367 : return var; 20 : } 21 : 22 12711 : Variable ones(const Dimensions &dims, const units::Unit &unit, const DType type, 23 : const bool with_variances) { 24 12710 : const auto make_prototype = [&](auto &&one) { 25 12710 : return with_variances 26 12736 : ? Variable{type, Dimensions{}, unit, Values{one}, Variances{one}} 27 38156 : : Variable{type, Dimensions{}, unit, Values{one}}; 28 12711 : }; 29 12711 : if (type == dtype<core::time_point>) { 30 2 : return copy(broadcast(make_prototype(core::time_point{1}), dims)); 31 12710 : } else if (type == dtype<std::string>) { 32 : // This would result in a Variable containing (char)1. 33 1 : throw std::invalid_argument("Cannot construct 'ones' of strings."); 34 : } else { 35 25418 : return copy(broadcast(make_prototype(1), dims)); 36 : } 37 : } 38 : 39 : /// Create empty (uninitialized) variable with same parameters as prototype. 40 : /// 41 : /// If specified, `shape` defines the shape of the output. If `prototype` 42 : /// contains binned data `shape` may not be specified, instead `sizes` defines 43 : /// the sizes of the desired bins. 44 291350 : Variable empty_like(const Variable &prototype, 45 : const std::optional<Dimensions> &shape, 46 : const Variable &sizes) { 47 291350 : return variableFactory().empty_like(prototype, shape, sizes); 48 : } 49 : 50 : /// Create a variable with the same parameters as `prototype` with 51 : /// values filled according to `fill`. 52 46184 : Variable special_like(const Variable &prototype, const FillValue &fill) { 53 46184 : const char *name = "special_like"; 54 46184 : if (fill == FillValue::Default) 55 2000 : return Variable(prototype, prototype.dims()); 56 44184 : if (fill == FillValue::ZeroNotBool) 57 22328 : return transform(prototype, core::element::zeros_not_bool_like, name); 58 21856 : if (fill == FillValue::True) 59 485 : return transform(prototype, core::element::values_like<bool, true>, name); 60 21371 : if (fill == FillValue::False) 61 106 : return transform(prototype, core::element::values_like<bool, false>, name); 62 21265 : if (fill == FillValue::Max) 63 10619 : return transform(prototype, core::element::numeric_limits_max_like, name); 64 10646 : if (fill == FillValue::Lowest) 65 : return transform(prototype, core::element::numeric_limits_lowest_like, 66 10646 : name); 67 0 : throw std::runtime_error("Unsupported fill value."); 68 : } 69 : 70 : /// Create a variable with the same parameters as `prototype` with the given 71 : /// dimensions and values filled according to `fill`. 72 : /// If `prototype` is binned, `accum` is dense 73 : /// with the elem dtype of `prototype`. 74 45974 : Variable dense_special_like(const Variable &prototype, 75 : const Dimensions &target_dims, 76 : const FillValue &fill) { 77 45974 : const auto type = variableFactory().elem_dtype(prototype); 78 45974 : const auto unit = variableFactory().elem_unit(prototype); 79 45974 : const auto has_variances = variableFactory().has_variances(prototype); 80 45974 : const auto scalar_prototype = empty(Dimensions{}, unit, type, has_variances); 81 137922 : return special_like(scalar_prototype.broadcast(target_dims), fill); 82 45974 : } 83 : 84 : /// Create scalar variable containing 0 with same parameters as prototype. 85 243 : Variable zero_like(const Variable &prototype) { 86 486 : return {prototype, Dimensions{}}; 87 : } 88 : 89 : } // namespace scipp::variable