ad_map_access
ECEFCoordinateValidInputRange.hpp
Go to the documentation of this file.
1 /*
2  * ----------------- BEGIN LICENSE BLOCK ---------------------------------
3  *
4  * Copyright (C) 2018-2020 Intel Corporation
5  *
6  * SPDX-License-Identifier: MIT
7  *
8  * ----------------- END LICENSE BLOCK -----------------------------------
9  */
10 
18 #pragma once
19 
20 #include <cmath>
21 #include <limits>
23 #include "spdlog/fmt/ostr.h"
24 #include "spdlog/spdlog.h"
25 
39 inline bool withinValidInputRange(::ad::map::point::ECEFCoordinate const &input, bool const logErrors = true)
40 {
41  // check for generic numeric limits of the type
42  bool inValidInputRange = input.isValid() && (std::numeric_limits<::ad::map::point::ECEFCoordinate>::lowest() <= input)
44  if (!inValidInputRange && logErrors)
45  {
46  spdlog::error("withinValidInputRange(::ad::map::point::ECEFCoordinate)>> {} out of numerical limits [{}, {}]",
47  input,
50  }
51  // check for individual input range
52  if (inValidInputRange)
53  {
54  inValidInputRange
55  = (::ad::map::point::ECEFCoordinate(-6400000) <= input) && (input <= ::ad::map::point::ECEFCoordinate(6400000));
56  if (!inValidInputRange && logErrors)
57  {
58  spdlog::error("withinValidInputRange(::ad::map::point::ECEFCoordinate)>> {} out of valid input range [{}, {}]",
59  input,
61  ::ad::map::point::ECEFCoordinate(6400000)); // LCOV_EXCL_BR_LINE
62  }
63  }
64  return inValidInputRange;
65 }
std::numeric_limits<::ad::map::point::ECEFCoordinate >::max
static inline ::ad::map::point::ECEFCoordinate max()
Definition: ECEFCoordinate.hpp:518
ad::map::point::ECEFCoordinate
DataType ECEFCoordinate.
Definition: ECEFCoordinate.hpp:68
std::numeric_limits<::ad::map::point::ECEFCoordinate >::lowest
static inline ::ad::map::point::ECEFCoordinate lowest()
Definition: ECEFCoordinate.hpp:511
ad::map::point::ECEFCoordinate::isValid
bool isValid() const
Definition: ECEFCoordinate.hpp:391
withinValidInputRange
bool withinValidInputRange(::ad::map::point::ECEFCoordinate const &input, bool const logErrors=true)
check if the given ECEFCoordinate is within valid input range
Definition: ECEFCoordinateValidInputRange.hpp:39
ECEFCoordinate.hpp