Skip to content

Commit

Permalink
schema: Move rotation and transform out of dev (RobotLocomotion#13949)
Browse files Browse the repository at this point in the history
  • Loading branch information
jwnimmer-tri authored Aug 31, 2020
1 parent 7da3804 commit 0ea6152
Show file tree
Hide file tree
Showing 13 changed files with 106 additions and 83 deletions.
46 changes: 46 additions & 0 deletions common/schema/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,20 @@ drake_cc_package_library(
name = "schema",
visibility = ["//visibility:public"],
deps = [
":rotation",
":stochastic",
":transform",
],
)

drake_cc_library(
name = "rotation",
srcs = ["rotation.cc"],
hdrs = ["rotation.h"],
deps = [
":stochastic",
"//common:name_value",
"//math:geometric_transform",
],
)

Expand All @@ -32,13 +45,46 @@ drake_cc_library(
],
)

drake_cc_library(
name = "transform",
srcs = ["transform.cc"],
hdrs = ["transform.h"],
deps = [
":rotation",
":stochastic",
"//common:name_value",
"//math:geometric_transform",
],
)

# === test/ ===

drake_cc_googletest(
name = "rotation_test",
deps = [
":rotation",
"//common/test_utilities:eigen_matrix_compare",
"//common/yaml:yaml_read_archive",
"//common/yaml:yaml_write_archive",
],
)

drake_cc_googletest(
name = "stochastic_test",
deps = [
":stochastic",
"//common/test_utilities:eigen_matrix_compare",
"//common/test_utilities:expect_throws_message",
"//common/test_utilities:symbolic_test_util",
"//common/yaml:yaml_read_archive",
],
)

drake_cc_googletest(
name = "transform_test",
deps = [
":transform",
"//common/test_utilities:eigen_matrix_compare",
"//common/test_utilities:symbolic_test_util",
"//common/yaml:yaml_read_archive",
],
Expand Down
59 changes: 0 additions & 59 deletions common/schema/dev/BUILD.bazel

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#include "drake/common/schema/dev/rotation.h"
#include "drake/common/schema/rotation.h"

#include "drake/common/drake_throw.h"
#include "drake/math/random_rotation.h"
Expand Down
File renamed without changes.
29 changes: 20 additions & 9 deletions common/schema/stochastic.h
Original file line number Diff line number Diff line change
Expand Up @@ -20,14 +20,14 @@ namespace schema {
@{
This page describes how to use classes such as schema::Distribution to denote
stochastic quantities, as bridge between loading a scenario specification and
stochastic quantities, as a bridge between loading a scenario specification and
populating the corresponding symbolic::Expression quantities into a
systems::System.
<h1>Stochastic variables</h1>
# Stochastic variables
We'll explain uses of schema::Distribution and related using the matching YAML
syntax as parsed by yaml::YamlReadArchive.
We'll explain uses of schema::Distribution and related types using the matching
YAML syntax as parsed by yaml::YamlReadArchive.
Given this C++ data structure:
Expand Down Expand Up @@ -101,13 +101,13 @@ These one-line spellings are the equivalent to those above.
value: !UniformDiscrete { values: [1.0, 1.5, 2.0] }
```
<h1>Vectors of stochastic variables</h1>
# Vectors of stochastic variables
For convenience, we also provide the option to specify a vector of independent
stochastic variables with the same type.
We'll explain uses of schema::DistributionVector and related using the matching
YAML syntax as parsed by yaml::YamlReadArchive.
We'll explain uses of schema::DistributionVector and related types using the
matching YAML syntax as parsed by yaml::YamlReadArchive.
Given this C++ data structure:
Expand Down Expand Up @@ -188,7 +188,7 @@ others by specifying a zero-sized range for the constant elements:
std: [0.0, 1.0]
```
<h1>See also </h1>
# See also
See @ref schema_transform for one practical application, of specifying
rotations, translations, and transforms using stochastic schemas.
Expand Down Expand Up @@ -383,6 +383,15 @@ class DeterministicVector final : public DistributionVector {
};

/// A gaussian distribution with vector `mean` and vector or scalar `stddev`.
///
/// When `mean` and `stddev` both have the same number of elements, that
/// denotes an elementwise pairing of the 0th mean with 0th stddev, 1st mean
/// with 1st stddev, etc.
///
/// Alternatively, `stddev` can be a vector with a single element, no matter
/// the size of `mean`; that denotes the same `stddev` value applied to every
/// element of `mean`.
///
/// @tparam Size rows at compile time (max 6) or else Eigen::Dynamic.
template <int Size>
class GaussianVector final : public DistributionVector {
Expand Down Expand Up @@ -447,7 +456,9 @@ struct InvalidVariantSelection {
/// Variant over all kinds of vector distributions.
///
/// If the Size parameter allows for 1-element vectors (i.e, is either 1 or
/// Eigen::Dynamic), then this variant also offers the single distributions.
/// Eigen::Dynamic), then this variant also offers the single distribution
/// types (Deterministic, Gaussian, Uniform). If the Size parameter is 2 or
/// greater, the single distribution types are not allowed.
///
/// @tparam Size rows at compile time (max 6) or else Eigen::Dynamic.
template <int Size>
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#include "drake/common/schema/dev/rotation.h"
#include "drake/common/schema/rotation.h"

#include <gtest/gtest.h>

Expand Down
22 changes: 22 additions & 0 deletions common/schema/test/stochastic_test.cc
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
#include <gtest/gtest.h>

#include "drake/common/test_utilities/eigen_matrix_compare.h"
#include "drake/common/test_utilities/expect_throws_message.h"
#include "drake/common/test_utilities/symbolic_test_util.h"
#include "drake/common/yaml/yaml_read_archive.h"

Expand Down Expand Up @@ -348,6 +349,27 @@ GTEST_TEST(StochasticTest, ZeroSizeRandomRanges) {
Eigen::VectorXd::Constant(1, 1.5)));
}

struct FixedSize2 {
template <typename Archive>
void Serialize(Archive* a) {
a->Visit(DRAKE_NVP(value));
}

DistributionVectorVariant<2> value;
};

GTEST_TEST(StochasticTest, IncorrectVectorTest) {
const char* const input = R"""(
value: !Deterministic { value: 2.0 }
)""";
FixedSize2 parsed;
DRAKE_EXPECT_THROWS_MESSAGE(
YamlReadArchive(YAML::Load(input), kStrict).Accept(&parsed),
std::exception,
".*unsupported type tag !Deterministic while selecting a variant<> entry"
" for std::variant<.*> value.*");
}

} // namespace
} // namespace schema
} // namespace drake
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#include "drake/common/schema/dev/transform.h"
#include "drake/common/schema/transform.h"

#include <gtest/gtest.h>

Expand All @@ -17,6 +17,7 @@ namespace {
// once Drake's YamlReadArchive constructor default changes to be strict.
constexpr YamlReadArchive::Options kStrict;

// TODO(jwnimmer-tri) Change use R""" per Drake GSG, throughout this file.
const char* deterministic = R"R(
base_frame: foo
translation: [1., 2., 3.]
Expand Down Expand Up @@ -97,6 +98,8 @@ GTEST_TEST(StochasticSampleTest, TransformTest) {
drake::math::RigidTransformd sampled_transform = transform.Sample(&generator);

// The sampled transforms must lie within the randomization domain.
// TODO(jwnimmer-tri) The correctness checks below traceable to rotation.cc's
// implementation would be better placed in rotation_test.cc.
const auto& translation_domain =
std::get<schema::UniformVector<3>>(transform.translation);
for (int i = 0; i < 3; i++) {
Expand All @@ -117,7 +120,7 @@ GTEST_TEST(StochasticSampleTest, TransformTest) {
EXPECT_LT(rpy[2], rotation_domain.max[2]);
EXPECT_GT(rpy[2], rotation_domain.min[2]);

// A second sample will (virtually certainly) differ from the first sample.
// A second sample will (almost certainly) differ from the first sample.
const drake::math::RigidTransformd sampled_transform_2 =
transform.Sample(&generator);
EXPECT_FALSE(sampled_transform.IsExactlyEqualTo(sampled_transform_2));
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#include "drake/common/schema/dev/transform.h"
#include "drake/common/schema/transform.h"

#include <stdexcept>

Expand Down
14 changes: 7 additions & 7 deletions common/schema/dev/transform.h → common/schema/transform.h
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
#include <string>

#include "drake/common/name_value.h"
#include "drake/common/schema/dev/rotation.h"
#include "drake/common/schema/rotation.h"
#include "drake/common/schema/stochastic.h"
#include "drake/math/rigid_transform.h"

Expand All @@ -16,8 +16,8 @@ namespace schema {
@{
This page describes how to use classes such as schema::Rotation and
schema::Transform to denote stochastic quantities, as bridge between loading a
scenario specification and populating the corresponding math::RigidTransform
schema::Transform to denote stochastic quantities, as a bridge between loading
a scenario specification and populating the corresponding math::RigidTransform
quantities.
The broader concepts are discussed at @ref schema_stochastic. Here, we cover
Expand All @@ -26,7 +26,7 @@ details related to rotations and transforms in particular.
We'll explain uses of schema::Rotation and schema::Transform using their
matching YAML syntax as parsed by yaml::YamlReadArchive.
<h1>Rotations</h1>
# Rotations
This shows the syntax for a schema::Rotation.
Expand Down Expand Up @@ -70,7 +70,7 @@ rotation: !Rpy { deg: [10.0, 20.0, 30.0] }
rotation: !AngleAxis { angle_deg: 10.0, axis: [0.0, 1.0, 0.0] }
```
<h2>Stochastic Rotations</h2>
## Stochastic Rotations
To specify a stochastic rotation sampled from a uniform distribution over
SO(3):
Expand Down Expand Up @@ -104,7 +104,7 @@ rotation: !AngleAxis
For an explanation of `!Uniform`, `!UniformVector`, and other available options
(%Gaussian, etc.) for scalar and vector quantities, see @ref schema_stochastic.
<h1>Transforms</h1>
# Transforms
This shows the syntax for a schema::Transform. A transform is merely a
translation and rotation, optionally with a some given string as a base_frame.
Expand All @@ -124,7 +124,7 @@ translation and rotation, optionally with a some given string as a base_frame.
rotation: !Identity {}
```
<h2>Stochastic Transforms</h2>
## Stochastic Transforms
Either or both of the rotational or translation component can be stochastic:
Expand Down
2 changes: 1 addition & 1 deletion multibody/parsing/dev/BUILD.bazel
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ drake_cc_library(
deps = [
"//common:essential",
"//common:name_value",
"//common/schema/dev:transform",
"//common/schema:transform",
"//math:geometric_transform",
],
)
Expand Down
2 changes: 1 addition & 1 deletion multibody/parsing/dev/model_directives.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@

#include "drake/common/eigen_types.h"
#include "drake/common/name_value.h"
#include "drake/common/schema/dev/transform.h"
#include "drake/common/schema/transform.h"
#include "drake/common/text_logging.h"
#include "drake/math/rigid_transform.h"
#include "drake/math/roll_pitch_yaw.h"
Expand Down
2 changes: 1 addition & 1 deletion multibody/parsing/dev/process_model_directives.cc
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@

#include "drake/common/filesystem.h"
#include "drake/common/find_resource.h"
#include "drake/common/schema/dev/transform.h"
#include "drake/common/schema/transform.h"
#include "drake/common/yaml/yaml_read_archive.h"
#include "drake/multibody/parsing/parser.h"

Expand Down

0 comments on commit 0ea6152

Please sign in to comment.