我正在通过串行端口将固定长度的字节流发送到另一台计算机,我想尝试将字节流转换为浮点数矢量。
我的流具有定界符stop
,并且我正在使用this串行库。
我当前的实现涉及以下内容:
我读了一个字符串
std::string data_string;
ser.readline(data_string, 2052, "stop");
检查字符串是否以定界符结尾
if(boost::algorithm::ends_with(stop_string, "stop"))
{
if(data_string.length() == 2052)
然后将字符串转换为向量
std::vector<unsigned char>bytes(stop_string.begin(), stop_string.end());
然后我使用for循环和memcpy
将bytes
转换为浮点数数组。
unsigned char temp_buffer[4];
float float_values[513] = { 0 };
int j = 0;
for(size_t i = 4; i < 2052; i+=4)
{
temp_buffer[0] = bytes[i - 4];
temp_buffer[1] = bytes[i - 3];
temp_buffer[2] = bytes[i - 2];
temp_buffer[3] = bytes[i - 1];
memcpy(&float_values[j], temp_buffer, sizeof(float));
j++;
}
但是这种方法看起来很麻烦,我想避免for循环。有没有办法:
将bytes
向量转换为浮点数向量吗?
避免for循环吗?
答案 0 :(得分:2)
浮点数数组和无符号字符向量的字节大小相同。您可以直接从缓冲区中将memcpy放入浮点数组中。
这好像不是您的字节已交换或其他任何内容。您只想将4个连续字节解释为一个浮点数。
这也消除了循环
编辑更新:
如果您使用的是C ++ 11或更高版本,则可以依靠std::string's internal buffer is stored contiguously并直接从中复制的事实。不需要临时字节缓冲区,这样可以为您节省大量内存(半页)。
示例:
// copy directly from string
float float_values[data_string.size()/sizeof(float)]; // 513
std::memcpy(float_values, data_string.data(), data_string.size());
答案 1 :(得分:1)
自从您标记为通用C ++之后,我将使用C ++ 20引入的一些很酷的新功能:)
#include <algorithm>
#include <cstddef>
#include <span>
#include <vector>
std::vector<float> ToFloats(const std::vector<std::byte>& bytes) {
std::vector<float> floats(bytes.size() / sizeof(float), 0.0f);
std::copy_n(bytes.begin(), floats.size() * sizeof(float),
std::as_writable_bytes(std::span(floats)).begin());
return floats;
}