HDK
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
metrics.h
Go to the documentation of this file.
1 //
2 // Copyright 2021 Pixar
3 //
4 // Licensed under the Apache License, Version 2.0 (the "Apache License")
5 // with the following modification; you may not use this file except in
6 // compliance with the Apache License and the following modification to it:
7 // Section 6. Trademarks. is deleted and replaced with:
8 //
9 // 6. Trademarks. This License does not grant permission to use the trade
10 // names, trademarks, service marks, or product names of the Licensor
11 // and its affiliates, except as required to comply with Section 4(c) of
12 // the License and to reproduce the content of the NOTICE file.
13 //
14 // You may obtain a copy of the Apache License at
15 //
16 // http://www.apache.org/licenses/LICENSE-2.0
17 //
18 // Unless required by applicable law or agreed to in writing, software
19 // distributed under the Apache License with the above modification is
20 // distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
21 // KIND, either express or implied. See the Apache License for the specific
22 // language governing permissions and limitations under the Apache License.
23 //
24 #ifndef PXR_USD_USD_PHYSICS_METRICS_H
25 #define PXR_USD_USD_PHYSICS_METRICS_H
26 
27 #include "pxr/pxr.h"
28 #include "pxr/usd/usdPhysics/api.h"
29 #include "pxr/usd/usd/common.h"
30 
32 
33 /// \file usdPhysics/metrics.h
34 ///
35 /// Helper APIs for physics related metrics operations.
36 
37 /// Return *stage*'s authored *kilogramsPerUnit*, or 1.0 if unauthored.
40 
41 /// Return whether *stage* has an authored *kilogramsPerUnit*.
44 
45 /// Author *stage*'s *kilogramsPerUnit*.
46 ///
47 /// \return true if kilogramsPerUnit was successfully set. The stage's
48 /// UsdEditTarget must be either its root layer or session layer.
51  double kilogramsPerUnit);
52 
53 /// Return *true* if the two given metrics are within the provided
54 /// relative *epsilon* of each other, when you need to know an absolute
55 /// metric rather than a scaling factor.
56 ///
57 /// Use like so:
58 /// \code
59 /// double stageUnits = UsdPhysicsGetStageKilogramsPerUnit(stage);
60 ///
61 /// if (UsdPhysicsMassUnitsAre(stageUnits, UsdPhysicsMassUnits::kilograms))
62 /// // do something for kilograms
63 /// else if (UsdPhysicsMassUnitsAre(stageUnits, UsdPhysicsMassUnits::grams))
64 /// // do something for grams
65 /// \endcode
66 ///
67 /// \return *false* if either input is zero or negative, otherwise relative
68 /// floating-point comparison between the two inputs.
70 bool UsdPhysicsMassUnitsAre(double authoredUnits, double standardUnits,
71  double epsilon = 1e-5);
72 
73 /// \class UsdPhysicsMassUnits
74 /// Container class for static double-precision symbols representing common
75 /// mass units of measure expressed in kilograms.
77 public:
78  static constexpr double grams = 0.001;
79  static constexpr double kilograms = 1.0;
80  static constexpr double slugs = 14.5939;
81 };
82 
84 
85 #endif // PXR_USD_USD_PHYSICS_METRICS_H
static constexpr double grams
Definition: metrics.h:78
USDPHYSICS_API bool UsdPhysicsMassUnitsAre(double authoredUnits, double standardUnits, double epsilon=1e-5)
USDPHYSICS_API bool UsdPhysicsSetStageKilogramsPerUnit(const UsdStageWeakPtr &stage, double kilogramsPerUnit)
UsdStagePtr UsdStageWeakPtr
Definition: common.h:55
USDPHYSICS_API double UsdPhysicsGetStageKilogramsPerUnit(const UsdStageWeakPtr &stage)
Return stage's authored kilogramsPerUnit, or 1.0 if unauthored.
USDPHYSICS_API bool UsdPhysicsStageHasAuthoredKilogramsPerUnit(const UsdStageWeakPtr &stage)
Return whether stage has an authored kilogramsPerUnit.
#define USDPHYSICS_API
Definition: api.h:40
static constexpr double kilograms
Definition: metrics.h:79
PXR_NAMESPACE_CLOSE_SCOPE PXR_NAMESPACE_OPEN_SCOPE
Definition: path.h:1441
#define PXR_NAMESPACE_CLOSE_SCOPE
Definition: pxr.h:91
static constexpr double slugs
Definition: metrics.h:80