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-2026 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>
27#include "GeomHelper.h"
28#include "Position.h"
29
30
31// ===========================================================================
32// static member definitions
33// ===========================================================================
34
35// Position 1Mio km below the surface should suffice for signaling invalidity inside the solar system
37 - 1024 * 1024 * 1024,
38 - 1024 * 1024 * 1024,
39 - 1024 * 1024 * 1024);
40
41
43Position::rotateAround2D(double rad, const Position& origin) {
44 const double s = sin(rad);
45 const double c = cos(rad);
46 Position p = (*this) - origin;
47 return Position(
48 p.x() * c - p.y() * s,
49 p.x() * s + p.y() * c) + origin;
50
51}
52
53void
54Position::round(int precision) {
55 // bankers rounding as in iostream
56 myX = roundDecimalToEven(myX, precision);
57 myY = roundDecimalToEven(myY, precision);
58 myZ = roundDecimalToEven(myZ, precision);
59}
double roundDecimalToEven(double x, int precision)
round to the given number of decimal digits (bankers rounding)
Definition StdDefs.cpp:67
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:54
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:43
double myX
The x-position.
Definition Position.h:327
double y() const
Returns the y-position.
Definition Position.h:57