[PATCH v2 06/17] test: Add minimal test for Matrix
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Tue Apr 1 03:09:08 CEST 2025
On Mon, Mar 31, 2025 at 06:07:24PM +0100, Kieran Bingham wrote:
> Quoting Stefan Klug (2025-03-19 16:11:11)
> > Add a few tests for the Matrix class. This is not full fledged but at
> > least a starter.
> >
> > Signed-off-by: Stefan Klug <stefan.klug at ideasonboard.com>
> >
> > ---
> >
> > Changes in v2:
> > - Added this patch
> > ---
> > test/matrix.cpp | 53 ++++++++++++++++++++++++++++++++++++++++++++++++
> > test/meson.build | 1 +
> > 2 files changed, 54 insertions(+)
> > create mode 100644 test/matrix.cpp
> >
> > diff --git a/test/matrix.cpp b/test/matrix.cpp
> > new file mode 100644
> > index 000000000000..93a3b95db2dc
> > --- /dev/null
> > +++ b/test/matrix.cpp
> > @@ -0,0 +1,53 @@
> > +/* SPDX-License-Identifier: GPL-2.0-or-later */
> > +/*
> > + * Copyright (C) 2024, Ideas on Board Oy
> > + *
> > + * Vector tests
> > + */
> > +
> > +#include "libcamera/internal/matrix.h"
> > +
> > +#include <cmath>
> > +#include <iostream>
> > +
> > +#include "test.h"
> > +
> > +using namespace libcamera;
> > +
> > +#define ASSERT_EQ(a, b) \
> > + if ((a) != (b)) { \
> > + std::cout << #a " != " #b << " (line " << __LINE__ << ")" \
> > + << std::endl; \
> > + return TestFail; \
> > + }
> > +
> > +class VectorTest : public Test
> > +{
> > +protected:
> > + int run()
> > + {
> > + Matrix<double, 3, 3> m1;
> > +
> > + ASSERT_EQ(m1[0][0], 0.0);
> > + ASSERT_EQ(m1[0][1], 0.0);
> > +
> > + constexpr Matrix<float, 2, 2> m2 = Matrix<float, 2, 2>().identity();
> > + ASSERT_EQ(m2[0][0], 1.0);
> > + ASSERT_EQ(m2[0][1], 0.0);
> > + ASSERT_EQ(m2[1][0], 0.0);
> > + ASSERT_EQ(m2[1][1], 1.0);
> > +
> > + Matrix<float, 2, 2> m3{ { 2.0, 0.0, 0.0, 2.0 } };
> > + Matrix<float, 2, 2> m4 = m3.inverse();
> > +
> > + Matrix<float, 2, 2> m5 = m3 * m4;
> > + ASSERT_EQ(m5[0][0], 1.0);
> > + ASSERT_EQ(m5[0][1], 0.0);
> > + ASSERT_EQ(m5[1][0], 0.0);
> > + ASSERT_EQ(m5[1][1], 1.0);
> > +
> > + return TestPass;
> > + }
> > +};
> > +
> > +TEST_REGISTER(VectorTest)
>
> Not 'MatrixTest' ?
>
> Aside from that, I'd put a tag, as tests here are helpful ... I'll leave
> the implementation detail on how to implement the Matrix features to
> Barnabas+Laurent to continue to discuss....
With the test class renamed,
Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> > diff --git a/test/meson.build b/test/meson.build
> > index 4095664994fd..52f04364e4fc 100644
> > --- a/test/meson.build
> > +++ b/test/meson.build
> > @@ -60,6 +60,7 @@ internal_tests = [
> > {'name': 'file', 'sources': ['file.cpp']},
> > {'name': 'flags', 'sources': ['flags.cpp']},
> > {'name': 'hotplug-cameras', 'sources': ['hotplug-cameras.cpp']},
> > + {'name': 'matrix', 'sources': ['matrix.cpp']},
> > {'name': 'message', 'sources': ['message.cpp']},
> > {'name': 'object', 'sources': ['object.cpp']},
> > {'name': 'object-delete', 'sources': ['object-delete.cpp']},
--
Regards,
Laurent Pinchart
More information about the libcamera-devel
mailing list