使用词法转换在 'string to double' 中设置双变量的精度
Set precision of a double variable in 'string to double' using lexical cast
我有一个字符串,其值为 "496934.079" 。
我使用 boost::lexical_cast () 将其转换为双变量(命名为 pVar)。
然而,转换后存储在 pVar 中的值是 "496934" 而不是 "496934.079"。小数点后的数字丢失。我已经阅读了有关 std::setprecision() 的内容,以便在输出 window here 中写入具有所需精度的双精度值。但它只显示具有给定精度的值,并且不会将其保存在具有给定精度的变量中。
但我想将 double 值完全按照字符串变量 str 中的原样存储,以便 pVar 中的值为 "496934.079".如何以与输入字符串相同的精度将值存储在变量中,以便我可以使用该变量进行进一步处理?
我的代码片段是:
int func()
{
string str = "496934.079";
double pVar = boost::lexical_cast<double> (str);
cout << pVar << endl;
return 0;
}
编辑: 这种从字符串到浮点数的转换是我正在开发的代码的一部分,它逐行解析文本文件中的值并将它们写入另一个文件( .pcd 格式)。我正在添加我用于此转换的整个代码以供参考。
int txt2pcd()
{
ifstream is("input_text_file.txt"); //read input text file
string str;
using namespace boost::algorithm;
pcl::PointCloud<pcl::PointXYZ>::Ptr point_cloud_ptr (new pcl::PointCloud<pcl::PointXYZ>);
while(getline(is, str)) //parsing the text file contents line-by-line
{
std::string s = str.c_str();
std::vector<std::string> result;
std::istringstream iss(s);
for(std::string s; iss >> s; )
result.push_back(s);
pcl::PointXYZ point;
point.x = boost::lexical_cast<double> (result[0]); //string to float conversion for adding the X coordinate of the point
point.y = boost::lexical_cast<double> (result[1]); //string to float conversion for adding the Y coordinate of the point
point.z = boost::lexical_cast<double> (result[2]); //string to float conversion for adding the Z coordinate of the point
point_cloud_ptr->points.push_back (point);
point_cloud_ptr->width = (int) point_cloud_ptr->points.size ();
point_cloud_ptr->height = 1;
}
pcl::io::savePCDFile ("output_pcd_file.pcd", *point_cloud_ptr, false); //this is where the converted float values are stored (with digits altered after decimal point when compared to text file)
return 0;
}
下面是文本文件中的几行示例以及转换后的“.pcd”文件中的相应行。
在文本文件中:
496934.999 5419547.239 265.179
496933.981 5419542.579 263.819
496934.891 5419545.399 264.849
496934.939 5419546.329 265.111
496934.829 5419544.489 264.781
在'.pcd'文件中(相应的值来自boost::lexical_cast ())
496935 5419547 265.17899
496933.97 5419542.5 263.819
496934.91 5419545.5 264.849
496934.94 5419546.5 265.11099
496934.84 5419544.5 264.78101
请注意,在输出“.pcd”文件中,这些值要么被四舍五入,要么小数点后的数字被改变。这可能是什么原因?
boost::lexical_cast<double>(str)
已经 returns 完整值 496934.079
作为 double
。此完整值存储在 pVar
中,可用于进一步处理。
string str = "496934.079";
double pVar = boost::lexical_cast<double>(str); // pVar now contains 496934.079
std::setprecision
不会影响存储的值 - 它仅设置显示 的位数(小数点前后)。默认显示精度为6
,所以:
std::cout << pVar << std::endl; // this prints "496934" (6 digits)
以更高的精度显示存储值(例如10
)给出:
#include <iomanip>
std::cout << std::setprecision(10) << pVar << std::endl; // this prints "496934.079"
但要重申:none 这会影响存储值。 pVar
仍然包含 496934.079
。例如:
std::cout << (int) (pVar * 1000) << std::endl; // this displays 496934079
编辑
问题中更新的代码表明,实际上,float
用于存储值,而不是 double
(参考 pcl::PointXYZ
)。
A float
没有足够的精度来存储完整值 496934.079
- 相反它将存储它可以表示的最佳近似值 (496934.09375
)(参考。例如What is the difference between float and double?).
如果要确保保留完整值(未修改),请确保坚持 double
。
我有一个字符串,其值为 "496934.079" 。 我使用 boost::lexical_cast () 将其转换为双变量(命名为 pVar)。
然而,转换后存储在 pVar 中的值是 "496934" 而不是 "496934.079"。小数点后的数字丢失。我已经阅读了有关 std::setprecision() 的内容,以便在输出 window here 中写入具有所需精度的双精度值。但它只显示具有给定精度的值,并且不会将其保存在具有给定精度的变量中。
但我想将 double 值完全按照字符串变量 str 中的原样存储,以便 pVar 中的值为 "496934.079".如何以与输入字符串相同的精度将值存储在变量中,以便我可以使用该变量进行进一步处理?
我的代码片段是:
int func()
{
string str = "496934.079";
double pVar = boost::lexical_cast<double> (str);
cout << pVar << endl;
return 0;
}
编辑: 这种从字符串到浮点数的转换是我正在开发的代码的一部分,它逐行解析文本文件中的值并将它们写入另一个文件( .pcd 格式)。我正在添加我用于此转换的整个代码以供参考。
int txt2pcd()
{
ifstream is("input_text_file.txt"); //read input text file
string str;
using namespace boost::algorithm;
pcl::PointCloud<pcl::PointXYZ>::Ptr point_cloud_ptr (new pcl::PointCloud<pcl::PointXYZ>);
while(getline(is, str)) //parsing the text file contents line-by-line
{
std::string s = str.c_str();
std::vector<std::string> result;
std::istringstream iss(s);
for(std::string s; iss >> s; )
result.push_back(s);
pcl::PointXYZ point;
point.x = boost::lexical_cast<double> (result[0]); //string to float conversion for adding the X coordinate of the point
point.y = boost::lexical_cast<double> (result[1]); //string to float conversion for adding the Y coordinate of the point
point.z = boost::lexical_cast<double> (result[2]); //string to float conversion for adding the Z coordinate of the point
point_cloud_ptr->points.push_back (point);
point_cloud_ptr->width = (int) point_cloud_ptr->points.size ();
point_cloud_ptr->height = 1;
}
pcl::io::savePCDFile ("output_pcd_file.pcd", *point_cloud_ptr, false); //this is where the converted float values are stored (with digits altered after decimal point when compared to text file)
return 0;
}
下面是文本文件中的几行示例以及转换后的“.pcd”文件中的相应行。
在文本文件中:
496934.999 5419547.239 265.179
496933.981 5419542.579 263.819
496934.891 5419545.399 264.849
496934.939 5419546.329 265.111
496934.829 5419544.489 264.781
在'.pcd'文件中(相应的值来自boost::lexical_cast ())
496935 5419547 265.17899
496933.97 5419542.5 263.819
496934.91 5419545.5 264.849
496934.94 5419546.5 265.11099
496934.84 5419544.5 264.78101
请注意,在输出“.pcd”文件中,这些值要么被四舍五入,要么小数点后的数字被改变。这可能是什么原因?
boost::lexical_cast<double>(str)
已经 returns 完整值 496934.079
作为 double
。此完整值存储在 pVar
中,可用于进一步处理。
string str = "496934.079";
double pVar = boost::lexical_cast<double>(str); // pVar now contains 496934.079
std::setprecision
不会影响存储的值 - 它仅设置显示 的位数(小数点前后)。默认显示精度为6
,所以:
std::cout << pVar << std::endl; // this prints "496934" (6 digits)
以更高的精度显示存储值(例如10
)给出:
#include <iomanip>
std::cout << std::setprecision(10) << pVar << std::endl; // this prints "496934.079"
但要重申:none 这会影响存储值。 pVar
仍然包含 496934.079
。例如:
std::cout << (int) (pVar * 1000) << std::endl; // this displays 496934079
编辑
问题中更新的代码表明,实际上,float
用于存储值,而不是 double
(参考 pcl::PointXYZ
)。
A float
没有足够的精度来存储完整值 496934.079
- 相反它将存储它可以表示的最佳近似值 (496934.09375
)(参考。例如What is the difference between float and double?).
如果要确保保留完整值(未修改),请确保坚持 double
。