File: complextest_runme.cs

package info (click to toggle)
swig 4.1.0-0.2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 47,992 kB
  • sloc: cpp: 50,555; ansic: 27,840; java: 15,366; python: 11,221; cs: 8,852; ruby: 6,307; yacc: 6,290; makefile: 5,702; sh: 5,492; perl: 3,818; php: 3,046; ml: 2,094; lisp: 1,756; javascript: 1,751; tcl: 1,499; xml: 115
file content (43 lines) | stat: -rw-r--r-- 1,405 bytes parent folder | download | duplicates (4)
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
// This is the complex runtime testcase. It checks that the C++ std::complex type works.
// It requires .NET 4.0 as the previous versions didn't have System.Numerics.Complex type.

using System;
using System.Numerics;

using complextestNamespace;

public class complextest_runme {

  public static void Main() {
    var a = new Complex(-1, 2);
    if ( complextest.Conj(a) != Complex.Conjugate(a) )
        throw new Exception("std::complex<double> test failed");

    if ( complextest.Conjf(a) != Complex.Conjugate(a) )
        throw new Exception("std::complex<float> test failed");

    if ( complextest.Conj2(a) != Complex.Conjugate(a) )
        throw new Exception("std::complex<double> test failed");

    if ( complextest.Conjf2(a) != Complex.Conjugate(a) )
        throw new Exception("std::complex<float> test failed");

    var vec = new VectorStdCplx();
    vec.Add(new Complex(1, 2));
    vec.Add(new Complex(2, 3));
    vec.Add(new Complex(4, 3));
    vec.Add(new Complex(1, 0));

    if ( complextest.CopyHalf(vec).Count != 2 )
        throw new Exception("CopyHalf test failed");

    if ( complextest.CopyHalfRef(vec).Count != 2 )
        throw new Exception("CopyHalfRef test failed");

    var p = new ComplexPair();
    p.z1 = new Complex(0, 1);
    p.z2 = new Complex(0, -1);
    if ( Complex.Conjugate(p.z2) != p.z1 )
        throw new Exception("vector<complex> test failed");
  }
}