我有一个将静态Eigen
向量转换为字节向量的功能:
template<typename T, int N>
static std::vector<uint8_t> toBytes(std::vector<Eigen::Matrix<T, N, 1>> const & vectors)
{
std::vector<uint8_t> bytes;
uint8_t const * rawData = reinterpret_cast<uint8_t const *>(vectors.data());
bytes.insert(bytes.end(), rawData, rawData + vectors.size() * N * sizeof(T));
return bytes
}
这是足够的,直到出现动态Eigen
向量(即Eigen::VectorXf
),并且将N
设置为-1
为止。所以我想出了这个:
template<typename T>
static std::vector<uint8_t> toBytes(std::vector<Eigen::Matrix<T, -1, 1>> const & vectors)
{
std::vector<uint8_t> bytes;
uint8_t const * rawData = reinterpret_cast<uint8_t const *>(vectors.data());
bytes.insert(bytes.end(), rawData, rawData + vectors.size() * sizeof(vectors[0]));
return bytes
}
但是,这导致矢量是预期大小的四倍,因此我想不能将动态矢量简单地转换为字节作为静态矢量。我可以这样解决尺寸问题:
template<typename T>
static std::vector<uint8_t> toBytes(std::vector<Eigen::Matrix<T, -1, 1>> const & vectors)
{
std::vector<uint8_t> bytes;
uint8_t const * rawData = reinterpret_cast<uint8_t const *>(vectors.data());
bytes.insert(bytes.end(), rawData, rawData + vectors.size() * vectors[0].size() * sizeof(T));
return bytes
}
这将导致长度正确的矢量填充值,但这些值不正确。如何将动态Eigen
向量转换为字节向量?
答案 0 :(得分:0)
好的,对此有一个非常明显的解决方案:
template<typename T>
static std::vector<uint8_t> createBuffer(std::vector<Eigen::Matrix<T, -1, 1>> const & vectors)
{
std::vector<uint8_t> & bytes = buffer.bytes;
bytes.reserve(vectors.size() * vectors[0].size() * sizeof(T));
for (auto const & vector : vectors)
{
for (int i = 0; i < vector.size(); ++i)
{
uint8_t const * rawData = reinterpret_cast<uint8_t const *>(&vector(0));
bytes.insert(bytes.end(), rawData, rawData + sizeof(T));
}
}
return bytes;
}