A Discrete-Event Network Simulator
Home
Tutorials ▼
English
Portuguese
Docs ▼
Wiki
Manual
Models
Develop ▼
API
Bugs
API
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Properties
Friends
Macros
Groups
Pages
angles.cc
Go to the documentation of this file.
1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
2
/*
3
* Copyright (c) 2011, 2012 CTTC
4
*
5
* This program is free software; you can redistribute it and/or modify
6
* it under the terms of the GNU General Public License version 2 as
7
* published by the Free Software Foundation;
8
*
9
* This program is distributed in the hope that it will be useful,
10
* but WITHOUT ANY WARRANTY; without even the implied warranty of
11
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
* GNU General Public License for more details.
13
*
14
* You should have received a copy of the GNU General Public License
15
* along with this program; if not, write to the Free Software
16
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17
*
18
* Author: Nicola Baldo <nbaldo@cttc.es>
19
*/
20
21
22
#include <ns3/log.h>
23
#include <cmath>
24
#include "
angles.h
"
25
26
27
NS_LOG_COMPONENT_DEFINE
(
"Angles"
);
28
29
namespace
ns3 {
30
31
32
double
DegreesToRadians
(
double
degrees)
33
{
34
return
degrees * M_PI / 180.0;
35
36
}
37
38
double
RadiansToDegrees
(
double
radians)
39
{
40
return
radians * 180.0 / M_PI;
41
}
42
43
std::ostream&
operator<<
(std::ostream& os,
const
Angles
& a)
44
{
45
os <<
"("
<< a.
phi
<<
", "
<< a.
theta
<<
")"
;
46
return
os;
47
}
48
49
std::istream &
operator >>
(std::istream &is,
Angles
&a)
50
{
51
char
c;
52
is >> a.
phi
>> c >> a.
theta
;
53
if
(c !=
':'
)
54
{
55
is.setstate (std::ios_base::failbit);
56
}
57
return
is;
58
}
59
60
61
Angles::Angles
()
62
: phi (0),
63
theta (0)
64
{
65
}
66
67
68
Angles::Angles
(
double
p,
double
t)
69
: phi (p),
70
theta (t)
71
{
72
}
73
74
75
Angles::Angles
(
Vector
v)
76
: phi (std::atan2 (v.y, v.
x
)),
77
theta (std::acos (v.z / sqrt (v.
x
*v.
x
+ v.y*v.y + v.z*v.z)))
78
{
79
}
80
81
Angles::Angles
(
Vector
v,
Vector
o)
82
: phi (std::atan2 (v.y - o.y, v.
x
- o.
x
)),
83
theta (std::acos ((v.z - o.z) /
CalculateDistance
(v, o)))
84
{
85
}
86
87
88
}
89
ns3::operator>>
std::istream & operator>>(std::istream &is, Angles &a)
initialize a struct Angles from input
Definition:
angles.cc:49
ns3::DegreesToRadians
double DegreesToRadians(double degrees)
converts degrees to radians
Definition:
angles.cc:32
ns3::Angles::theta
double theta
the inclination angle in radians
Definition:
angles.h:117
ns3::Vector3D
a 3d vector
Definition:
vector.h:31
ns3::CalculateDistance
double CalculateDistance(const Vector3D &a, const Vector3D &b)
Definition:
vector.cc:71
ns3::operator<<
std::ostream & operator<<(std::ostream &os, const Angles &a)
print a struct Angles to output
Definition:
angles.cc:43
ns3::RadiansToDegrees
double RadiansToDegrees(double radians)
converts radians to degrees
Definition:
angles.cc:38
ns3::Angles::phi
double phi
the azimuth angle in radians
Definition:
angles.h:111
NS_LOG_COMPONENT_DEFINE
NS_LOG_COMPONENT_DEFINE("Angles")
angles.h
ns3::Angles
struct holding the azimuth and inclination angles of spherical coordinates.
Definition:
angles.h:71
ns3::Angles::Angles
Angles()
default constructor, will initialize phi and theta to zero
Definition:
angles.cc:61
sample-rng-plot.x
list x
Definition:
sample-rng-plot.py:26
src
antenna
model
angles.cc
Generated on Sat Apr 19 2014 14:06:49 for ns-3 by
1.8.6