fixed_ratio_sampler_test.cc
Go to the documentation of this file.
1 /*
2  * Copyright 2016 The Cartographer Authors
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
18 
19 #include "gtest/gtest.h"
20 
21 namespace cartographer {
22 namespace common {
23 namespace {
24 
25 TEST(FixedRatioSamplerTest, AlwaysTrue) {
26  FixedRatioSampler fixed_ratio_sampler(1.);
27  for (int i = 0; i < 100; ++i) {
28  EXPECT_TRUE(fixed_ratio_sampler.Pulse());
29  }
30 }
31 
32 TEST(FixedRatioSamplerTest, AlwaysFalse) {
33  FixedRatioSampler fixed_ratio_sampler(0.);
34  for (int i = 0; i < 100; ++i) {
35  EXPECT_FALSE(fixed_ratio_sampler.Pulse());
36  }
37 }
38 
39 TEST(FixedRatioSamplerTest, SometimesTrue) {
40  FixedRatioSampler fixed_ratio_sampler(0.5);
41  for (int i = 0; i < 100; ++i) {
42  EXPECT_EQ(i % 2 == 0, fixed_ratio_sampler.Pulse());
43  }
44 }
45 
46 TEST(FixedRatioSamplerTest, FirstPulseIsTrue) {
47  // Choose a very very small positive number for the ratio.
48  FixedRatioSampler fixed_ratio_sampler(1e-20);
49  EXPECT_TRUE(fixed_ratio_sampler.Pulse());
50  for (int i = 0; i < 100; ++i) {
51  EXPECT_FALSE(fixed_ratio_sampler.Pulse());
52  }
53 }
54 
55 } // namespace
56 } // namespace common
57 } // namespace cartographer


cartographer
Author(s):
autogenerated on Mon Jun 10 2019 12:51:38