使用派生单位进行计算
Computations using derived units
我使用这种方法来定义一个新的派生维度质量流量,其单位应kg / s
:
包括
#include <boost/units/io.hpp>
#include <boost/units/systems/si.hpp>
#include <boost/units/systems/si/io.hpp>
#include <boost/units/systems/si/prefixes.hpp>
namespace Units
{
using namespace boost::units;
namespace SI
{
using namespace boost::units::si;
}
template <class U> using Quantity = quantity<U>;
typedef Quantity<SI::time> Time;
typedef Quantity<SI::mass> Mass;
typedef Units::derived_dimension<Units::mass_base_dimension, 1,
Units::time_base_dimension, -1>::type MassFlowDimension;
typedef Quantity<MassFlowDimension> MassFlowRate;
BOOST_UNITS_STATIC_CONSTANT(kilogram_per_seconds, MassFlowRate);
}
我本以为从/到现有基本单位的转换会开箱即用,但显然情况并非如此:
int main()
{
// does work
Units::MassFlowRate mass_flow = 1.0*(Units::kilogram_per_seconds);
// does not work
Units::MassFlowRate other_mass_flow = 1.0*(Units::SI::kilogram / Units::SI::second);
// does not work either
Units::Mass total_flow = mass_flow * (1.0*Units::SI::second);
}
我想使用派生维度来定义集成到现有框架中的数量。我是否必须调用一些宏才能与现有单位进行转换
?编辑:错误消息如下:
main.cc:39:44: error: conversion from ‘boost::units::multiply_typeof_helper<double, boost::units::unit<boost::units::list<boost::units::dim<boost::units::mass_base_dimension, boost::units::static_rational<1> >, boost::units::list<boost::units::dim<boost::units::time_base_dimension, boost::units::static_rational<-1> >, boost::units::dimensionless_type> >, boost::units::homogeneous_system<boost::units::list<boost::units::si::meter_base_unit, boost::units::list<boost::units::scaled_base_unit<boost::units::cgs::gram_base_unit, boost::units::scale<10, boost::units::static_rational<3> > >, boost::units::list<boost::units::si::second_base_unit, boost::units::list<boost::units::si::ampere_base_unit, boost::units::list<boost::units::si::kelvin_base_unit, boost::units::list<boost::units::si::mole_base_unit, boost::units::list<boost::units::si::candela_base_unit, boost::units::list<boost::units::angle::radian_base_unit, boost::units::list<boost::units::angle::steradian_base_unit, boost::units::dimensionless_type> > > > > > > > > >, void> >::type {aka boost::units::quantity<boost::units::unit<boost::units::list<boost::units::dim<boost::units::mass_base_dimension, boost::units::static_rational<1> >, boost::units::list<boost::units::dim<boost::units::time_base_dimension, boost::units::static_rational<-1> >, boost::units::dimensionless_type> >, boost::units::homogeneous_system<boost::units::list<boost::units::si::meter_base_unit, boost::units::list<boost::units::scaled_base_unit<boost::units::cgs::gram_base_unit, boost::units::scale<10, boost::units::static_rational<3> > >, boost::units::list<boost::units::si::second_base_unit, boost::units::list<boost::units::si::ampere_base_unit, boost::units::list<boost::units::si::kelvin_base_unit, boost::units::list<boost::units::si::mole_base_unit, boost::units::list<boost::units::si::candela_base_unit, boost::units::list<boost::units::angle::radian_base_unit, boost::units::list<boost::units::angle::steradian_base_unit, boost::units::dimensionless_type> > > > > > > > > >, void>, double>}’ to non-scalar type ‘Units::MassFlowRate {aka boost::units::quantity<boost::units::list<boost::units::dim<boost::units::mass_base_dimension, boost::units::static_rational<1> >, boost::units::list<boost::units::dim<boost::units::time_base_dimension, boost::units::static_rational<-1> >, boost::units::dimensionless_type> >, double>}’ requested
Units::MassFlowRate other_mass_flow = 1.0*(Units::SI::kilogram / Units::SI::second);
main.cc:39:38: error: conversion from ‘boost::units::multiply_typeof_helper<boost::units::quantity<boost::units::list<boost::units::dim<boost::units::mass_base_dimension, boost::units::static_rational<1> >, boost::units::list<boost::units::dim<boost::units::time_base_dimension, boost::units::static_rational<-1> >, boost::units::dimensionless_type> >, double>, boost::units::quantity<boost::units::unit<boost::units::list<boost::units::dim<boost::units::time_base_dimension, boost::units::static_rational<1> >, boost::units::dimensionless_type>, boost::units::homogeneous_system<boost::units::list<boost::units::si::meter_base_unit, boost::units::list<boost::units::scaled_base_unit<boost::units::cgs::gram_base_unit, boost::units::scale<10, boost::units::static_rational<3> > >, boost::units::list<boost::units::si::second_base_unit, boost::units::list<boost::units::si::ampere_base_unit, boost::units::list<boost::units::si::kelvin_base_unit, boost::units::list<boost::units::si::mole_base_unit, boost::units::list<boost::units::si::candela_base_unit, boost::units::list<boost::units::angle::radian_base_unit, boost::units::list<boost::units::angle::steradian_base_unit, boost::units::dimensionless_type> > > > > > > > > > >, double> >::type {aka boost::units::quantity<boost::units::quantity<boost::units::unit<boost::units::list<boost::units::dim<boost::units::time_base_dimension, boost::units::static_rational<1> >, boost::units::dimensionless_type>, boost::units::homogeneous_system<boost::units::list<boost::units::si::meter_base_unit, boost::units::list<boost::units::scaled_base_unit<boost::units::cgs::gram_base_unit, boost::units::scale<10, boost::units::static_rational<3> > >, boost::units::list<boost::units::si::second_base_unit, boost::units::list<boost::units::si::ampere_base_unit, boost::units::list<boost::units::si::kelvin_base_unit, boost::units::list<boost::units::si::mole_base_unit, boost::units::list<boost::units::si::candela_base_unit, boost::units::list<boost::units::angle::radian_base_unit, boost::units::list<boost::units::angle::steradian_base_unit, boost::units::dimensionless_type> > > > > > > > > > >, boost::units::list<boost::units::dim<boost::units::mass_base_dimension, boost::units::static_rational<1> >, boost::units::list<boost::units::dim<boost::units::time_base_dimension, boost::units::static_rational<-1> >, boost::units::dimensionless_type> > >, double>}’ to non-scalar type ‘Units::Mass {aka boost::units::quantity<boost::units::unit<boost::units::list<boost::units::dim<boost::units::mass_base_dimension, boost::units::static_rational<1> >, boost::units::dimensionless_type>, boost::units::homogeneous_system<boost::units::list<boost::units::si::meter_base_unit, boost::units::list<boost::units::scaled_base_unit<boost::units::cgs::gram_base_unit, boost::units::scale<10, boost::units::static_rational<3> > >, boost::units::list<boost::units::si::second_base_unit, boost::units::list<boost::units::si::ampere_base_unit, boost::units::list<boost::units::si::kelvin_base_unit, boost::units::list<boost::units::si::mole_base_unit, boost::units::list<boost::units::si::candela_base_unit, boost::units::list<boost::units::angle::radian_base_unit, boost::units::list<boost::units::angle::steradian_base_unit, boost::units::dimensionless_type> > > > > > > > > > >, double>}’ requested
Units::Mass total_flow = mass_flow * (1.0*Units::SI::second);
你混淆了单位、尺寸和数量。
-
这是你的维度,
typedef Units::derived_dimension<Units::mass_base_dimension, 1, Units::time_base_dimension, -1>::type MassFlowDimension;
您不能从维度创建数量:
typedef Quantity<MassFlowDimension> MassFlowRate;
而是先创建一个单位,然后从中创建一个维度:
你的常数 应该是单位常数,而不是数量:
typedef Quantity<MassFlowDimension> MassFlowRate; BOOST_UNITS_STATIC_CONSTANT(kilogram_per_seconds, MassFlowRate);
固定
住在科里鲁
#include <boost/units/io.hpp>
#include <boost/units/systems/si.hpp>
#include <boost/units/systems/si/io.hpp>
namespace Units {
using namespace boost::units;
namespace SI = boost::units::si;
template <class U> using Quantity = quantity<U>;
typedef quantity<si::mass> Mass;
typedef quantity<si::time> Time;
typedef derived_dimension<mass_base_dimension, 1, time_base_dimension, -1>::type MassFlowDimension;
typedef unit<MassFlowDimension, si::system> MassFlow;
typedef Quantity<MassFlow> MassFlowRate;
BOOST_UNITS_STATIC_CONSTANT(kilogram_per_seconds, MassFlow);
}
#include <iostream>
int main() {
Units::MassFlowRate const mass_flow = 7.0*Units::kilogram_per_seconds;
Units::MassFlowRate const other_mass_flow = 1.0*(Units::SI::kilogram / Units::SI::second);
Units::Mass const total_flow = mass_flow * (1.0*Units::SI::second);
std::cout << "mass_flow: " << mass_flow << "n";
std::cout << "other_mass_flow: " << other_mass_flow << "n";
std::cout << "total_flow: " << total_flow << "n";
}
指纹
mass_flow: 7 kg s^-1
other_mass_flow: 1 kg s^-1
total_flow: 7 kg
相关文章:
- 为什么"do while"循环不断退出,即使条件计算结果为 false?
- 如何有效地计算将单位立方体映射到自身的反射和旋转?
- 如何以C++为单位计算向量中的字节数?
- 如何以字节为单位计算mpz_class的长度?
- 以C++为单位计算数组中的重复数字
- 使用派生单位进行计算
- 以 ns3 为单位计算数据包接收时间
- 以 C++ 为单位计算字符串中的唯一单词
- 计算以毫秒为单位的分类算法对整数阵列排序的时间
- 以秒为单位计算年龄的程序无法正常工作
- 如何在 c++ 中以度为单位计算罪恶值
- 如何计算 A、B、C <= 10^18 的 (A*B)%C(以 C++为单位)?
- 如何以毫秒为单位计算执行时间
- 在 openCV 中以像素为单位计算字符串的长度
- 以 C++ 为单位计算有序集的并集
- 当 x 为 90 度或 pi/2 弧度时,将 cos(x) 计算为 0,以C++为单位
- PCL:以毫米为单位计算点的xyz
- 提升:以秒/毫/微米/纳米为单位计算函数的运行时间
- 设计一个结构来存储时间和日期.写一个函数来计算两个时间之间的差(以分钟为单位)
- 逻辑错误:平均质心计算不正确,无限执行,'entries '函数 - K 表示一组点的聚类,以C++为单位