File: complex.cpp

package info (click to toggle)
falconpl 0.9.6.9-git20120606-2
  • links: PTS, VCS
  • area: main
  • in suites: wheezy
  • size: 46,176 kB
  • sloc: cpp: 181,389; ansic: 109,025; yacc: 2,310; xml: 1,218; sh: 403; objc: 245; makefile: 82; sql: 20
file content (51 lines) | stat: -rw-r--r-- 1,060 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
/*
   FALCON - The Falcon Programming Language.
   FILE: complex.cpp

   Complex class for Falcon
   Interface extension functions
   -------------------------------------------------------------------
   Author: Giancarlo Niccolai
   Begin: Wed, 09 Sep 2009 23:44:53 +0200

   -------------------------------------------------------------------
   (C) Copyright 2009: the FALCON developers (see list in AUTHORS file)

   See LICENSE file for licensing details.

*/

/** \file
   Complex class for Falcon
   Internal logic functions - implementation.
*/

#include <falcon/complex.h>
#include <falcon/error.h>
#include <falcon/eng_messages.h>

#include <math.h>

namespace Falcon {

void Complex::throw_div_by_zero()
{
   throw new MathError( ErrorParam( e_div_by_zero, __LINE__ )
      .origin( e_orig_runtime )
      .extra( "Complex number division by zero") );
}

numeric Complex::abs() const
{
   return sqrt( m_real * m_real + m_imag * m_imag );
}

Complex Complex::conj() const
{
   return Complex( m_real, m_imag * -1 );
}

}


/* end of complex.cpp */