Eclipse SUMO - Simulation of Urban MObility
Loading...
Searching...
No Matches
Position.cpp
Go to the documentation of this file.
1/****************************************************************************/
2// Eclipse SUMO, Simulation of Urban MObility; see https://eclipse.dev/sumo
3// Copyright (C) 2001-2025 German Aerospace Center (DLR) and others.
4// This program and the accompanying materials are made available under the
5// terms of the Eclipse Public License 2.0 which is available at
6// https://www.eclipse.org/legal/epl-2.0/
7// This Source Code may also be made available under the following Secondary
8// Licenses when the conditions for such availability set forth in the Eclipse
9// Public License 2.0 are satisfied: GNU General Public License, version 2
10// or later which is available at
11// https://www.gnu.org/licenses/old-licenses/gpl-2.0-standalone.html
12// SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-or-later
13/****************************************************************************/
21// A position in the 2D- or 3D-world
22/****************************************************************************/
23#include <config.h>
24
25#include <limits>
26#include "GeomHelper.h"
27#include "Position.h"
28
29
30// ===========================================================================
31// static member definitions
32// ===========================================================================
33
34// Position 1Mio km below the surface should suffice for signaling invalidity inside the solar system
36 - 1024 * 1024 * 1024,
37 - 1024 * 1024 * 1024,
38 - 1024 * 1024 * 1024);
39
40
42Position::rotateAround2D(double rad, const Position& origin) {
43 const double s = sin(rad);
44 const double c = cos(rad);
45 Position p = (*this) - origin;
46 return Position(
47 p.x() * c - p.y() * s,
48 p.x() * s + p.y() * c) + origin;
49
50}
51
52void
53Position::round(int precision) {
54 // bankers rounding as in iostream
55 myX = roundDecimalToEven(myX, precision);
56 myY = roundDecimalToEven(myY, precision);
57 myZ = roundDecimalToEven(myZ, precision);
58}
double roundDecimalToEven(double x, int precision)
round to the given number of decimal digits (bankers rounding)
Definition StdDefs.cpp:63
A point in 2D or 3D with translation and scaling methods.
Definition Position.h:37
Position()
default constructor
Definition Position.h:40
static const Position INVALID
used to indicate that a position is valid
Definition Position.h:323
double x() const
Returns the x-position.
Definition Position.h:52
double myZ
The z-position.
Definition Position.h:333
void round(int precision)
round all coordinates to the given precision
Definition Position.cpp:53
double myY
The y-position.
Definition Position.h:330
Position rotateAround2D(double rad, const Position &origin)
rotate this position by rad around origin and return the result
Definition Position.cpp:42
double myX
The x-position.
Definition Position.h:327
double y() const
Returns the y-position.
Definition Position.h:57