本文整理汇总了C++中openstudio::containsDirectScaledUnit方法的典型用法代码示例。如果您正苦于以下问题:C++ openstudio::containsDirectScaledUnit方法的具体用法?C++ openstudio::containsDirectScaledUnit怎么用?C++ openstudio::containsDirectScaledUnit使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类openstudio
的用法示例。
在下文中一共展示了openstudio::containsDirectScaledUnit方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: aMatch
TEST_F(UnitsFixture,QuantityRegex_DirectScaledUnit) {
// direct scaled unit
std::string aMatch("people/1000 ft^2");
EXPECT_TRUE(isDirectScaledUnit(aMatch));
aMatch = "1/10kg"; EXPECT_TRUE(isDirectScaledUnit(aMatch));
aMatch = "people/100*m^2"; EXPECT_TRUE(isDirectScaledUnit(aMatch));
// not a direct scaled unit
std::string notAMatch("m^2");
EXPECT_FALSE(isDirectScaledUnit(notAMatch));
notAMatch = "kg/10**m"; EXPECT_FALSE(isDirectScaledUnit(notAMatch));
// contains a direct scaled unit
std::string includesMatch("32 people/100 m^2");
EXPECT_TRUE(containsDirectScaledUnit(includesMatch));
boost::smatch m;
boost::regex_search(includesMatch,m,regexEmbeddedDirectScaledUnit());
std::string unitStr = std::string(m[1].first,m[1].second);
EXPECT_EQ("people/100 m^2",unitStr);
std::pair<std::string,std::pair<unsigned,std::string> > result;
result = decomposeDirectScaledUnit(unitStr);
EXPECT_EQ("people/",result.first);
EXPECT_EQ(static_cast<unsigned>(2),result.second.first);
EXPECT_EQ("m^2",result.second.second);
includesMatch = "Occupancy (people/1000*ft^2)";
EXPECT_TRUE(containsDirectScaledUnit(includesMatch));
boost::regex_search(includesMatch,m,regexEmbeddedDirectScaledUnit());
unitStr = std::string(m[5].first,m[5].second);
EXPECT_EQ("people/1000*ft^2",unitStr);
result = decomposeDirectScaledUnit(unitStr);
EXPECT_EQ("people/",result.first);
EXPECT_EQ(static_cast<unsigned>(3),result.second.first);
EXPECT_EQ("ft^2",result.second.second);
includesMatch = "1/10kg";
EXPECT_TRUE(containsDirectScaledUnit(includesMatch));
boost::regex_search(includesMatch,m,regexEmbeddedDirectScaledUnit());
unitStr = std::string(m[1].first,m[1].second);
EXPECT_EQ("1/10kg",unitStr);
result = decomposeDirectScaledUnit(unitStr);
EXPECT_EQ("1/",result.first);
EXPECT_EQ(static_cast<unsigned>(1),result.second.first);
EXPECT_EQ("kg",result.second.second);
}
示例2: decomposeAtomicUnitString
TEST_F(UnitsFixture,QuantityRegex_PumpFields) {
std::string aUnit;
// Design Shaft Power per Unit Flow Rate per Unit Head is posing problems
// After trial and error, I can format the IDD so it works: No parenthesis, one divisor
// Currently this is the only one that passes
aUnit = "W*s/m^3*Pa"; EXPECT_TRUE(isUnit(aUnit));
aUnit = "W*min/gal*ftH_{2}O"; EXPECT_TRUE(isUnit(aUnit));
std::pair<std::string,int> atomicDecomp;
aUnit = "ftH_{2}O";
// this shouldn't be an atomic unit!
// EXPECT_FALSE(isAtomicUnit(aUnit));
// But we can at least make sure that the decomposition at least returns the right exponent (1...)
atomicDecomp = decomposeAtomicUnitString(aUnit);
EXPECT_EQ("ftH_{2}O", atomicDecomp.first);
EXPECT_EQ(1, atomicDecomp.second);
aUnit = "1/ftH_{2}O";
EXPECT_FALSE(containsScientificNotationValue(aUnit));
// There is no multiplier (km, ms, etc)
// This returns TRUE, like above... but we'll make sure it ends up fine...
// EXPECT_FALSE(containsAtomicUnit(aUnit));
// 1 over something is a Compound Unit)
EXPECT_TRUE(containsCompoundUnit(aUnit));
EXPECT_FALSE(containsScaledUnit(aUnit));
EXPECT_FALSE(containsDirectScaledUnit(aUnit));
EXPECT_TRUE(isUnit(aUnit));
ASSERT_TRUE(isCompoundUnit(aUnit));
std::pair< std::vector<std::string>,std::vector<std::string> > result;
result = decomposeCompoundUnitString(aUnit);
// Nothing on numerator
ASSERT_EQ(static_cast<size_t>(0),result.first.size());
// Should have one unit on the denominator
ASSERT_EQ(static_cast<size_t>(1),result.second.size());
EXPECT_EQ("ftH_{2}O",result.second[0]);
// All of these variations do fail
/*
* aUnit = "(W*s)/(m^3*Pa)"; EXPECT_TRUE(isUnit(aUnit));
* aUnit = "(W*s)/(m^3*Pa)"; EXPECT_TRUE(isUnit(aUnit));
*
* aUnit = "(W*min)/(gal*ftH_{2}O)"; EXPECT_TRUE(isUnit(aUnit));
* aUnit = "W*min/(gal*ftH_{2}O)"; EXPECT_TRUE(isUnit(aUnit));
*
* aUnit = "W/((m^3/s)*Pa)"; EXPECT_TRUE(isUnit(aUnit));
* aUnit = "W/((gal/min)*ftH_{2}O)"; EXPECT_TRUE(isUnit(aUnit));
*/
}