add multitype data type and unittest (including tests for ubuf)
This commit is contained in:
@ -232,6 +232,84 @@ union ubuf {
|
|||||||
ubuf(const int64_t &arg) : i(arg) {}
|
ubuf(const int64_t &arg) : i(arg) {}
|
||||||
ubuf(const int &arg) : i(arg) {}
|
ubuf(const int &arg) : i(arg) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/** Data structure for dynamic typing of int, bigint, and double
|
||||||
|
*
|
||||||
|
* Using this union allows to store any of the supported data types
|
||||||
|
* in the same container and allows to "see" its current type.
|
||||||
|
\verbatim embed:rst
|
||||||
|
|
||||||
|
**Usage:**
|
||||||
|
|
||||||
|
.. code-block:: c++
|
||||||
|
:caption: To store data in multitype array:
|
||||||
|
|
||||||
|
multitype m[5];
|
||||||
|
int foo = 1;
|
||||||
|
double bar = 2.5;
|
||||||
|
bigint baz = 1<<40 - 1;
|
||||||
|
m[0] = foo;
|
||||||
|
m[1] = bar;
|
||||||
|
m[2] = -1;
|
||||||
|
m[3] = 2.0;
|
||||||
|
m[4] = baz;
|
||||||
|
|
||||||
|
.. code-block:: c++
|
||||||
|
:caption: To format data from multitype array into a space separated string:
|
||||||
|
|
||||||
|
std::string str;
|
||||||
|
for (int i = 0; i < 5; ++i) {
|
||||||
|
switch (m[i].type) {
|
||||||
|
case multitype::DOUBLE:
|
||||||
|
str += std::to_string(m[i].data.d) + ' ';
|
||||||
|
break;
|
||||||
|
case multitype::INT:
|
||||||
|
str += std::to_string(m[i].data.i) + ' ';
|
||||||
|
break;
|
||||||
|
case multitype::BIGINT:
|
||||||
|
str += std::to_string(m[i].data.b) + ' ';
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
\endverbatim
|
||||||
|
*/
|
||||||
|
struct multitype {
|
||||||
|
enum { NONE, DOUBLE, INT, BIGINT };
|
||||||
|
|
||||||
|
int type;
|
||||||
|
union {
|
||||||
|
double d;
|
||||||
|
int i;
|
||||||
|
int64_t b;
|
||||||
|
} data;
|
||||||
|
|
||||||
|
multitype() : type(NONE) { data.d = 0.0; }
|
||||||
|
multitype(const multitype &) = default;
|
||||||
|
multitype(multitype &&) = default;
|
||||||
|
~multitype() = default;
|
||||||
|
|
||||||
|
multitype &operator=(const double &_d)
|
||||||
|
{
|
||||||
|
type = DOUBLE;
|
||||||
|
data.d = _d;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
multitype &operator=(const int &_i)
|
||||||
|
{
|
||||||
|
type = INT;
|
||||||
|
data.i = _i;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
multitype &operator=(const int64_t &_b)
|
||||||
|
{
|
||||||
|
type = BIGINT;
|
||||||
|
data.b = _b;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
} // namespace LAMMPS_NS
|
} // namespace LAMMPS_NS
|
||||||
|
|
||||||
// preprocessor macros for compiler specific settings
|
// preprocessor macros for compiler specific settings
|
||||||
|
|||||||
@ -7,6 +7,10 @@ add_executable(test_mempool test_mempool.cpp)
|
|||||||
target_link_libraries(test_mempool PRIVATE lammps GTest::GMockMain)
|
target_link_libraries(test_mempool PRIVATE lammps GTest::GMockMain)
|
||||||
add_test(NAME MemPool COMMAND test_mempool)
|
add_test(NAME MemPool COMMAND test_mempool)
|
||||||
|
|
||||||
|
add_executable(test_lmptype test_lmptype.cpp)
|
||||||
|
target_link_libraries(test_lmptype PRIVATE lammps GTest::GMockMain)
|
||||||
|
add_test(NAME LmpType COMMAND test_lmptype)
|
||||||
|
|
||||||
add_executable(test_argutils test_argutils.cpp)
|
add_executable(test_argutils test_argutils.cpp)
|
||||||
target_link_libraries(test_argutils PRIVATE lammps GTest::GMockMain)
|
target_link_libraries(test_argutils PRIVATE lammps GTest::GMockMain)
|
||||||
add_test(NAME ArgUtils COMMAND test_argutils)
|
add_test(NAME ArgUtils COMMAND test_argutils)
|
||||||
|
|||||||
84
unittest/utils/test_lmptype.cpp
Normal file
84
unittest/utils/test_lmptype.cpp
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
/* ----------------------------------------------------------------------
|
||||||
|
LAMMPS - Large-scale Atomic/Molecular Massively Parallel Simulator
|
||||||
|
https://www.lammps.org/, Sandia National Laboratories
|
||||||
|
LAMMPS Development team: developers@lammps.org
|
||||||
|
|
||||||
|
Copyright (2003) Sandia Corporation. Under the terms of Contract
|
||||||
|
DE-AC04-94AL85000 with Sandia Corporation, the U.S. Government retains
|
||||||
|
certain rights in this software. This software is distributed under
|
||||||
|
the GNU General Public License.
|
||||||
|
|
||||||
|
See the README file in the top-level LAMMPS directory.
|
||||||
|
------------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
#include "lmptype.h"
|
||||||
|
|
||||||
|
#include "gmock/gmock.h"
|
||||||
|
#include "gtest/gtest.h"
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
|
||||||
|
using namespace LAMMPS_NS;
|
||||||
|
|
||||||
|
TEST(Types, ubuf)
|
||||||
|
{
|
||||||
|
double buf[3];
|
||||||
|
double d1 = 0.1;
|
||||||
|
int i1 = -10;
|
||||||
|
#if defined(LAMMPS_SMALLSMALL)
|
||||||
|
bigint b1 = 2048;
|
||||||
|
#else
|
||||||
|
bigint b1 = (1L << 58) + (1L << 50);
|
||||||
|
#endif
|
||||||
|
buf[0] = d1;
|
||||||
|
buf[1] = ubuf(i1).d;
|
||||||
|
buf[2] = ubuf(b1).d;
|
||||||
|
|
||||||
|
EXPECT_EQ(d1, buf[0]);
|
||||||
|
EXPECT_EQ(i1, (int)ubuf(buf[1]).i);
|
||||||
|
EXPECT_EQ(b1, (bigint)ubuf(buf[2]).i);
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(Types, multitype)
|
||||||
|
{
|
||||||
|
multitype m[6];
|
||||||
|
int64_t b1 = (3L << 48) - 1;
|
||||||
|
int i1 = 20;
|
||||||
|
double d1 = 0.1;
|
||||||
|
|
||||||
|
m[0] = b1;
|
||||||
|
m[1] = i1;
|
||||||
|
m[2] = d1;
|
||||||
|
|
||||||
|
#if !defined(LAMMPS_SMALLSMALL)
|
||||||
|
m[3] = -((1L << 40) + (1L << 50));
|
||||||
|
#endif
|
||||||
|
m[4] = -1023;
|
||||||
|
m[5] = -2.225;
|
||||||
|
|
||||||
|
#if defined(LAMMPS_SMALLSMALL)
|
||||||
|
EXPECT_EQ(m[0].type, multitype::INT);
|
||||||
|
#else
|
||||||
|
EXPECT_EQ(m[0].type, multitype::BIGINT);
|
||||||
|
#endif
|
||||||
|
EXPECT_EQ(m[1].type, multitype::INT);
|
||||||
|
EXPECT_EQ(m[2].type, multitype::DOUBLE);
|
||||||
|
|
||||||
|
#if defined(LAMMPS_SMALLSMALL)
|
||||||
|
EXPECT_EQ(m[3].type, multitype::NONE);
|
||||||
|
#else
|
||||||
|
EXPECT_EQ(m[3].type, multitype::BIGINT);
|
||||||
|
#endif
|
||||||
|
EXPECT_EQ(m[4].type, multitype::INT);
|
||||||
|
EXPECT_EQ(m[5].type, multitype::DOUBLE);
|
||||||
|
|
||||||
|
EXPECT_EQ(m[0].data.b, b1);
|
||||||
|
EXPECT_EQ(m[1].data.i, i1);
|
||||||
|
EXPECT_EQ(m[2].data.d, d1);
|
||||||
|
|
||||||
|
#if !defined(LAMMPS_SMALLSMALL)
|
||||||
|
EXPECT_EQ(m[3].data.b, -((1L << 40) + (1L << 50)));
|
||||||
|
#endif
|
||||||
|
EXPECT_EQ(m[4].data.i, -1023);
|
||||||
|
EXPECT_EQ(m[5].data.d, -2.225);
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user