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 (atan2 (v.y, v.
x
)),
77
theta (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 (atan2 (v.y - o.y, v.
x
- o.
x
)),
83
theta (acos ((v.z - o.z) /
CalculateDistance
(v, o)))
84
{
85
}
86
87
88
}
89
src
antenna
model
angles.cc
Generated on Tue Nov 13 2012 10:32:08 for ns-3 by
1.8.1.2