def test_convert(self):
    """
    Test convert().
    """
    from spatialdata.geocoords.CSGeo import CSGeo
    csNAD27 = CSGeo()
    csNAD27.inventory.ellipsoid = "clrk66"
    csNAD27.inventory.datumHoriz = "NAD27"
    csNAD27.inventory.datumVert = "mean sea level"
    csNAD27._configure()

    from spatialdata.geocoords.CSGeoLocalCart import CSGeoLocalCart
    csLocal = CSGeoLocalCart()
    csLocal.inventory.originLon = -100.0
    csLocal.inventory.originLat = 39.0
    from pyre.units.length import m
    csLocal.inventory.originElev = 0.01*m
    csLocal.inventory.ellipsoid = "clrk66"
    csLocal.inventory.datumHoriz = "NAD27"
    csLocal.inventory.datumVert = "mean sea level"
    csLocal._configure()

    from spatialdata.utils.ChangeCoordSys import ChangeCoordSys
    converter = ChangeCoordSys()
    converter.inventory.csDest = csLocal
    converter.inventory.csSrc = csNAD27
    converter._configure()

    coordsXYZ = lonlatNAD27ElevVals
    converter.convert(coordsXYZ)
    xyzLocalValsT = numpy.array(coordsXYZ)

    self.assertEqual(len(xyzLocalVals.shape), len(xyzLocalValsT.shape))
    for (xyz, xyzT) in zip(numpy.reshape(xyzLocalVals,-1),
                           numpy.reshape(xyzLocalValsT, -1)):
      self.assertAlmostEqual(1.0, xyz/xyzT, 6)
    return
Example #2
0
  def test_main(self):
    """
    Test main().
    """
    filename = "in.txt"

    from spatialdata.utils.PointsStream import PointsStream
    s = PointsStream()
    s.inventory.filename = filename
    s.inventory.numFormat = "%20.8e"
    s._configure()
    
    s.write(lonlatNAD27ElevVals)

    from spatialdata.geocoords.CSGeo import CSGeo
    csNAD27 = CSGeo()
    csNAD27.inventory.ellipsoid = "clrk66"
    csNAD27.inventory.datumHoriz = "NAD27"
    csNAD27.inventory.datumVert = "mean sea level"
    csNAD27._configure()

    from spatialdata.geocoords.CSGeoLocalCart import CSGeoLocalCart
    csLocal = CSGeoLocalCart()
    csLocal.inventory.originLon = -100.0
    csLocal.inventory.originLat = 39.0
    from pyre.units.length import m
    csLocal.inventory.originElev = 0.01*m
    csLocal.inventory.ellipsoid = "clrk66"
    csLocal.inventory.datumHoriz = "NAD27"
    csLocal.inventory.datumVert = "mean sea level"
    csLocal._configure()

    from spatialdata.utils.ChangeCoordSys import ChangeCoordSys
    converter = ChangeCoordSys()
    converter.inventory.csDest = csLocal
    converter.inventory.csSrc = csNAD27
    converter._configure()

    from spatialdata.utils.ConvertApp import ConvertApp
    reader = PointsStream()
    reader.inventory.filename = filename
    reader.inventory.numFormat = "%20.8e"
    reader._configure()

    writer = PointsStream()
    writer.inventory.filename = "out.txt"
    writer.inventory.numFormat = "%20.8e"
    writer._configure()

    app = ConvertApp()
    app.inventory.reader = reader
    app.inventory.writer = writer
    app.inventory.converter = converter
    app._configure()

    app.main()

    points = writer.read()
    self.assertEqual(len(xyzLocalVals.shape), len(points.shape))
    for dE,d in zip(xyzLocalVals.shape, points.shape):
      self.assertEqual(dE, d)
    for vE,v in zip(numpy.reshape(xyzLocalVals, -1),
                    numpy.reshape(points, -1)):
      self.assertAlmostEqual(1.0, vE/v, 6)
    return
Example #3
0
    def test_main(self):
        """
    Test main().
    """
        filename = "in.txt"

        from spatialdata.utils.PointsStream import PointsStream
        s = PointsStream()
        s.inventory.filename = filename
        s.inventory.numFormat = "%20.8e"
        s._configure()

        s.write(lonlatNAD27ElevVals)

        from spatialdata.geocoords.CSGeo import CSGeo
        csNAD27 = CSGeo()
        csNAD27.inventory.ellipsoid = "clrk66"
        csNAD27.inventory.datumHoriz = "NAD27"
        csNAD27.inventory.datumVert = "mean sea level"
        csNAD27._configure()

        from spatialdata.geocoords.CSGeoLocalCart import CSGeoLocalCart
        csLocal = CSGeoLocalCart()
        csLocal.inventory.originLon = -100.0
        csLocal.inventory.originLat = 39.0
        from pyre.units.length import m
        csLocal.inventory.originElev = 0.01 * m
        csLocal.inventory.ellipsoid = "clrk66"
        csLocal.inventory.datumHoriz = "NAD27"
        csLocal.inventory.datumVert = "mean sea level"
        csLocal._configure()

        from spatialdata.utils.ChangeCoordSys import ChangeCoordSys
        converter = ChangeCoordSys()
        converter.inventory.csDest = csLocal
        converter.inventory.csSrc = csNAD27
        converter._configure()

        from spatialdata.utils.ConvertApp import ConvertApp
        reader = PointsStream()
        reader.inventory.filename = filename
        reader.inventory.numFormat = "%20.8e"
        reader._configure()

        writer = PointsStream()
        writer.inventory.filename = "out.txt"
        writer.inventory.numFormat = "%20.8e"
        writer._configure()

        app = ConvertApp()
        app.inventory.reader = reader
        app.inventory.writer = writer
        app.inventory.converter = converter
        app._configure()

        app.main()

        points = writer.read()
        self.assertEqual(len(xyzLocalVals.shape), len(points.shape))
        for dE, d in zip(xyzLocalVals.shape, points.shape):
            self.assertEqual(dE, d)
        for vE, v in zip(numpy.reshape(xyzLocalVals, -1),
                         numpy.reshape(points, -1)):
            self.assertAlmostEqual(1.0, vE / v, 6)
        return