[RFC PATCH v2 07/12] ipa: libipa: vector: Add compound assignment operators
Milan Zamazal
mzamazal at redhat.com
Mon Nov 18 14:59:05 CET 2024
Laurent Pinchart <laurent.pinchart at ideasonboard.com> writes:
> Extend the Vector class with compound assignment operators that match
> the binary arithmetic operators.
>
> Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
Reviewed-by: Milan Zamazal <mzamazal at redhat.com>
> ---
> src/ipa/libipa/vector.cpp | 56 ++++++++++++++++++++++++++++++++++++++
> src/ipa/libipa/vector.h | 57 +++++++++++++++++++++++++++++++++++++++
> 2 files changed, 113 insertions(+)
>
> diff --git a/src/ipa/libipa/vector.cpp b/src/ipa/libipa/vector.cpp
> index d0e38f402220..a45f08fde493 100644
> --- a/src/ipa/libipa/vector.cpp
> +++ b/src/ipa/libipa/vector.cpp
> @@ -127,6 +127,62 @@ namespace ipa {
> * \return The element-wise division of this vector by \a scalar
> */
>
> +/**
> + * \fn Vector::operator+=(Vector const &other)
> + * \brief Add \a other element-wise to this vector
> + * \param[in] other The other vector
> + * \return This vector
> + */
> +
> +/**
> + * \fn Vector::operator+=(T scalar)
> + * \brief Add \a scalar element-wise to this vector
> + * \param[in] scalar The scalar
> + * \return This vector
> + */
> +
> +/**
> + * \fn Vector::operator-=(Vector const &other)
> + * \brief Subtract \a other element-wise from this vector
> + * \param[in] other The other vector
> + * \return This vector
> + */
> +
> +/**
> + * \fn Vector::operator-=(T scalar)
> + * \brief Subtract \a scalar element-wise from this vector
> + * \param[in] scalar The scalar
> + * \return This vector
> + */
> +
> +/**
> + * \fn Vector::operator*=(const Vector &other)
> + * \brief Multiply this vector by \a other element-wise
> + * \param[in] other The other vector
> + * \return This vector
> + */
> +
> +/**
> + * \fn Vector::operator*=(T scalar)
> + * \brief Multiply this vector by \a scalar element-wise
> + * \param[in] scalar The scalar
> + * \return This vector
> + */
> +
> +/**
> + * \fn Vector::operator/=(const Vector &other)
> + * \brief Divide this vector by \a other element-wise
> + * \param[in] other The other vector
> + * \return This vector
> + */
> +
> +/**
> + * \fn Vector::operator/=(T scalar)
> + * \brief Divide this vector by \a scalar element-wise
> + * \param[in] scalar The scalar
> + * \return This vector
> + */
> +
> /**
> * \fn Vector::dot(const Vector<T, Rows> &other) const
> * \brief Compute the dot product
> diff --git a/src/ipa/libipa/vector.h b/src/ipa/libipa/vector.h
> index dda49b1f468b..722ffc57ea45 100644
> --- a/src/ipa/libipa/vector.h
> +++ b/src/ipa/libipa/vector.h
> @@ -114,6 +114,46 @@ public:
> return apply(*this, scalar, [](T a, T b) { return a / b; });
> }
>
> + Vector &operator+=(const Vector &other)
> + {
> + return apply(other, [](T a, T b) { return a + b; });
> + }
> +
> + Vector &operator+=(T scalar)
> + {
> + return apply(scalar, [](T a, T b) { return a + b; });
> + }
> +
> + Vector &operator-=(const Vector &other)
> + {
> + return apply(other, [](T a, T b) { return a - b; });
> + }
> +
> + Vector &operator-=(T scalar)
> + {
> + return apply(scalar, [](T a, T b) { return a - b; });
> + }
> +
> + Vector &operator*=(const Vector &other)
> + {
> + return apply(other, [](T a, T b) { return a * b; });
> + }
> +
> + Vector &operator*=(T scalar)
> + {
> + return apply(scalar, [](T a, T b) { return a * b; });
> + }
> +
> + Vector &operator/=(const Vector &other)
> + {
> + return apply(other, [](T a, T b) { return a / b; });
> + }
> +
> + Vector &operator/=(T scalar)
> + {
> + return apply(scalar, [](T a, T b) { return a / b; });
> + }
> +
> constexpr T dot(const Vector<T, Rows> &other) const
> {
> T ret = 0;
> @@ -206,6 +246,23 @@ private:
> return result;
> }
>
> + Vector &apply(const Vector &other, std::function<T(T, T)> func)
> + {
> + auto itOther = other.data_.begin();
> + std::for_each(data_.begin(), data_.end(),
> + [&func, &itOther](T &v) { v = func(v, *itOther++); });
> +
> + return *this;
> + }
> +
> + Vector &apply(T scalar, std::function<T(T, T)> func)
> + {
> + std::for_each(data_.begin(), data_.end(),
> + [&func, scalar](T &v) { v = func(v, scalar); });
> +
> + return *this;
> + }
> +
> std::array<T, Rows> data_;
> };
More information about the libcamera-devel
mailing list