src/core/model/vector.h
author Vedran Miletić <rivanvx@gmail.com>
Tue, 02 Aug 2011 17:42:33 -0400
changeset 7385 10beb0e53130
parent 7383 c5e131450339
child 11036 1e03af4311bd
permissions -rw-r--r--
standardize emacs c++ mode comments
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
7385
10beb0e53130 standardize emacs c++ mode comments
Vedran Miletić <rivanvx@gmail.com>
parents: 7383
diff changeset
     1
/* -*- Mode:C++; c-file-style:"gnu"; indent-tabs-mode:nil; -*- */
1460
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     2
/*
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     3
 * Copyright (c) 2007 INRIA
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     4
 *
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     6
 * it under the terms of the GNU General Public License version 2 as
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     7
 * published by the Free Software Foundation;
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     8
 *
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    12
 * GNU General Public License for more details.
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    13
 *
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    14
 * You should have received a copy of the GNU General Public License
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    15
 * along with this program; if not, write to the Free Software
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    16
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    17
 *
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    18
 * Author: Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
0c9be520ba9f fix copyright statements
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1002
diff changeset
    19
 */
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    20
#ifndef NS3_VECTOR_H
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    21
#define NS3_VECTOR_H
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    22
7383
c5e131450339 remove ns3/ prefix which is un-needed now that all files are in same module.
Mathieu Lacage <mathieu.lacage@gmail.com>
parents: 7256
diff changeset
    23
#include "attribute.h"
c5e131450339 remove ns3/ prefix which is un-needed now that all files are in same module.
Mathieu Lacage <mathieu.lacage@gmail.com>
parents: 7256
diff changeset
    24
#include "attribute-helper.h"
2387
a74c89d71cba add Value support to Vector
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1815
diff changeset
    25
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    26
namespace ns3 {
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    27
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    28
/**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    29
 * \brief a 3d vector
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    30
 */
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    31
class Vector3D
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    32
{
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    33
public:
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    34
  /**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    35
   * \param _x x coordinate of vector
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    36
   * \param _y y coordinate of vector
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    37
   * \param _z z coordinate of vector
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    38
   *
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    39
   * Create vector (_x, _y, _z)
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    40
   */
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    41
  Vector3D (double _x, double _y, double _z);
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    42
  /**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    43
   * Create vector (0.0, 0.0, 0.0)
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    44
   */
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    45
  Vector3D ();
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    46
  /**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    47
   * x coordinate of vector
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    48
   */
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    49
  double x;
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    50
  /**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    51
   * y coordinate of vector
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    52
   */
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    53
  double y;
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    54
  /**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    55
   * z coordinate of vector
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    56
   */
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    57
  double z;
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    58
};
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
    59
3226
8c191779d1c2 doxygen a couple of missing functions. Add acouple of more comments to existing mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3094
diff changeset
    60
/**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    61
 * \brief a 3d vector
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    62
 */
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    63
class Vector2D
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    64
{
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    65
public:
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    66
  /**
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    67
   * \param _x x coordinate of vector
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    68
   * \param _y y coordinate of vector
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    69
   *
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    70
   * Create vector (_x, _y)
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    71
   */
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    72
  Vector2D (double _x, double _y);
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    73
  /**
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    74
   * Create vector vector (0.0, 0.0)
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    75
   */
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    76
  Vector2D ();
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    77
  /**
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    78
   * x coordinate of vector
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    79
   */
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    80
  double x;
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    81
  /**
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    82
   * y coordinate of vector
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    83
   */
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    84
  double y;
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    85
};
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    86
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    87
/**
3226
8c191779d1c2 doxygen a couple of missing functions. Add acouple of more comments to existing mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3094
diff changeset
    88
 * \param a one point
8c191779d1c2 doxygen a couple of missing functions. Add acouple of more comments to existing mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3094
diff changeset
    89
 * \param b another point
8c191779d1c2 doxygen a couple of missing functions. Add acouple of more comments to existing mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3094
diff changeset
    90
 * \returns the cartesian distance between a and b.
8c191779d1c2 doxygen a couple of missing functions. Add acouple of more comments to existing mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3094
diff changeset
    91
 */
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    92
double CalculateDistance (const Vector3D &a, const Vector3D &b);
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    93
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    94
/**
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    95
 * \param a one point
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    96
 * \param b another point
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    97
 * \returns the cartesian distance between a and b.
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    98
 */
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
    99
double CalculateDistance (const Vector2D &a, const Vector2D &b);
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   100
2969
9d05d2a95dfa improve the auto-generated doxygen output.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2582
diff changeset
   101
/**
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   102
 * \class ns3::Vector3DValue
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   103
 * \brief hold objects of type ns3::Vector3D
2969
9d05d2a95dfa improve the auto-generated doxygen output.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2582
diff changeset
   104
 */
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   105
/**
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   106
 * \class ns3::Vector2DValue
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   107
 * \brief hold objects of type ns3::Vector2D
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   108
 */
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   109
ATTRIBUTE_HELPER_HEADER (Vector3D);
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   110
ATTRIBUTE_HELPER_HEADER (Vector2D);
2969
9d05d2a95dfa improve the auto-generated doxygen output.
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 2582
diff changeset
   111
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   112
std::ostream &operator << (std::ostream &os, const Vector3D &vector);
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   113
std::istream &operator >> (std::istream &is, Vector3D &vector);
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   114
std::ostream &operator << (std::ostream &os, const Vector2D &vector);
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   115
std::istream &operator >> (std::istream &is, Vector2D &vector);
2387
a74c89d71cba add Value support to Vector
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1815
diff changeset
   116
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   117
// for compatibility with mobility models
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   118
typedef Vector3D Vector;
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   119
typedef Vector3DValue VectorValue;
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   120
typedef Vector3DChecker VectorChecker;
7256
b04ba6772f8c rerun check-style.py at default level to enforce space after function name
Tom Henderson <tomh@tomh.org>
parents: 6821
diff changeset
   121
ATTRIBUTE_ACCESSOR_DEFINE (Vector);
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   122
Ptr<const AttributeChecker> MakeVectorChecker (void);
2387
a74c89d71cba add Value support to Vector
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 1815
diff changeset
   123
968
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   124
} // namespace ns3
70d02500c9d5 mobility models
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents:
diff changeset
   125
4718
7138f037be1f introduce Vector2D and Vector3D
Mathieu Lacage <mathieu.lacage@sophia.inria.fr>
parents: 3226
diff changeset
   126
#endif /* NS3_VECTOR_H */