File: XdmfTestGeometryConverter.py

package info (click to toggle)
xdmf 3.0%2Bgit20160803-3
  • links: PTS
  • area: main
  • in suites: stretch
  • size: 35,388 kB
  • ctags: 36,627
  • sloc: ansic: 265,382; cpp: 162,889; python: 10,976; f90: 1,378; yacc: 687; fortran: 464; xml: 200; java: 187; lex: 125; makefile: 82; sh: 28
file content (84 lines) | stat: -rw-r--r-- 2,898 bytes parent folder | download | duplicates (6)
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
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
from Xdmf import *
from XdmfUtils import *
from math import *

if __name__ == "__main__":
  Pi = 3.1415926535897932384626433832795

  converter = XdmfGeometryConverter.New()

  cartesianGeo = XdmfGeometry.New()

  cartesianGeo.setType(XdmfGeometryType.XYZ())

  for i in range(3):
    cartesianGeo.pushBackAsFloat64(1)

  resultSphericalGeo = converter.convertToSpherical(cartesianGeo)

  sphericalGeo = XdmfGeometry.New()

  sphericalGeo.setType(XdmfGeometryType.Spherical())

  sphericalGeo.pushBackAsFloat64(sqrt(3));
  sphericalGeo.pushBackAsFloat64(asin(sqrt(2.0/3.0))); # should be equal to acos(1/sqrt(3))
  sphericalGeo.pushBackAsFloat64(Pi/4);

  print "Tolerance 10^-15\nresult\n" , resultSphericalGeo.getValuesString(), "\n?=\ncompare to\n", sphericalGeo.getValuesString()

  for i in range(sphericalGeo.getSize()):
    val1 = resultSphericalGeo.getValueAsFloat64(i)
    val2 = sphericalGeo.getValueAsFloat64(i)
    val1 = floor(val1 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0);
    val2 = floor(val2 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0);
    print val1, " ?= ", val2
    assert(val1 == val2)

  resultCartesianGeo = converter.convertToCartesian(sphericalGeo)

  print resultCartesianGeo.getValuesString(), "\n?=\n", cartesianGeo.getValuesString()

  for i in range(cartesianGeo.getSize()):
    val1 = resultCartesianGeo.getValueAsFloat64(i);
    val2 = cartesianGeo.getValueAsFloat64(i);
    val1 = floor(val1 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0)
    val2 = floor(val2 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0)
    print val1, " ?= ", val2
    assert(val1 == val2)

  # Convert in place for geometries with a lot of references

  convertedToSpherical = XdmfGeometry.New()

  convertedToSpherical.setType(XdmfGeometryType.XYZ())

  for i in range(3):
    convertedToSpherical.pushBackAsFloat64(1)

  converter.convertToSphericalOverwrite(convertedToSpherical)

  for i in range(sphericalGeo.getSize()):
    val1 = convertedToSpherical.getValueAsFloat64(i)
    val2 = sphericalGeo.getValueAsFloat64(i)
    val1 = floor(val1 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0)
    val2 = floor(val2 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0)
    print val1, " ?= ", val2
    assert(val1 == val2)

  convertedToCartesian = XdmfGeometry.New()

  convertedToCartesian.setType(XdmfGeometryType.Spherical())

  convertedToCartesian.pushBackAsFloat64(sqrt(3))
  convertedToCartesian.pushBackAsFloat64(asin(sqrt(2.0/3))) # should be equal to acos(1/sqrt(3))
  convertedToCartesian.pushBackAsFloat64(Pi/4)

  converter.convertToCartesianOverwrite(convertedToCartesian)

  for i in range(cartesianGeo.getSize()):
    val1 = convertedToCartesian.getValueAsFloat64(i)
    val2 = cartesianGeo.getValueAsFloat64(i)
    val1 = floor(val1 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0)
    val2 = floor(val2 * pow(10.0, 15.0) + 0.5) / pow(10.0, 15.0)
    print val1, " ?= ", val2
    assert(val1 == val2)