def test_directions_2d(self):
        x = np.linspace(0.0, 20.0, 100)
        y = np.linspace(0.0, 15.0, 80)
        rng = np.random.RandomState(1479373475)
        x_rand = rng.rand(len(x))
        y_rand = rng.rand(len(y))
        # random values repeated along y-axis
        field_x = np.tile(x_rand, (len(y), 1)).T
        # random values repeated along x-axis
        field_y = np.tile(y_rand, (len(x), 1))

        try:
            gamma_x_x = variogram.vario_estimate_structured(
                field_x, direction="x"
            )
            gamma_x_y = variogram.vario_estimate_structured(
                field_x, direction="y"
            )

            gamma_y_x = variogram.vario_estimate_structured(
                field_y, direction="x"
            )
            gamma_y_y = variogram.vario_estimate_structured(
                field_y, direction="y"
            )

            self.assertAlmostEqual(gamma_x_y[1], 0.0)
            self.assertAlmostEqual(gamma_x_y[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_x_y[-1], 0.0)
            self.assertAlmostEqual(gamma_y_x[1], 0.0)
            self.assertAlmostEqual(gamma_y_x[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_y_x[-1], 0.0)
        except NotImplementedError as e:
            pass
    def test_masked_2d(self):
        rng = np.random.RandomState(1479373475)
        field = rng.rand(80, 60)
        mask = np.zeros_like(field)
        field_ma = np.ma.masked_array(field, mask=mask)

        try:
            gamma_x = variogram.vario_estimate_structured(
                field_ma, direction="x"
            )
            gamma_y = variogram.vario_estimate_structured(
                field_ma, direction="y"
            )

            var = 1.0 / 12.0
            self.assertAlmostEqual(gamma_x[0], 0.0, places=2)
            self.assertAlmostEqual(gamma_x[len(gamma_x) // 2], var, places=2)
            self.assertAlmostEqual(gamma_x[-1], var, places=2)
            self.assertAlmostEqual(gamma_y[0], 0.0, places=2)
            self.assertAlmostEqual(gamma_y[len(gamma_y) // 2], var, places=2)
            self.assertAlmostEqual(gamma_y[-1], var, places=2)

            mask = np.zeros_like(field)
            mask[0, 0] = 1
            field = np.ma.masked_array(field, mask=mask)
            gamma_x = variogram.vario_estimate_structured(
                field_ma, direction="x"
            )
            gamma_y = variogram.vario_estimate_structured(
                field_ma, direction="y"
            )
            self.assertAlmostEqual(gamma_x[0], 0.0, places=2)
            self.assertAlmostEqual(gamma_y[0], 0.0, places=2)
        except NotImplementedError as e:
            pass
Exemple #3
0
    def test_mixed(self):
        z = np.array(
            (41.2, 40.2, 39.7, 39.2, 40.1, 38.3, 39.1, 40.0, 41.1, 40.3),
            dtype=np.double,
        )
        gamma = variogram.vario_estimate_structured(z)
        self.assertAlmostEqual(gamma[1], 0.4917, places=4)

        z = np.array((10, 20, 30, 40), dtype=int)

        gamma = variogram.vario_estimate_structured(z)
        self.assertAlmostEqual(gamma[1], 50.0, places=4)
Exemple #4
0
 def test_masked_1d(self):
     # literature values
     z = np.array(
         (41.2, 40.2, 39.7, 39.2, 40.1, 38.3, 39.1, 40.0, 41.1, 40.3),
         dtype=np.double,
     )
     z_ma = np.ma.masked_array(z, mask=[0, 0, 0, 0, 0, 0, 0, 0, 0, 0])
     gamma = variogram.vario_estimate_structured(z_ma)
     self.assertAlmostEqual(gamma[0], 0.0000, places=4)
     self.assertAlmostEqual(gamma[1], 0.4917, places=4)
     self.assertAlmostEqual(gamma[2], 0.7625, places=4)
     z_ma = np.ma.masked_array(z, mask=[1, 0, 0, 0, 0, 0, 0, 0, 0, 0])
     gamma = variogram.vario_estimate_structured(z_ma)
     self.assertAlmostEqual(gamma[0], 0.0000, places=4)
     self.assertAlmostEqual(gamma[1], 0.4906, places=4)
     self.assertAlmostEqual(gamma[2], 0.7107, places=4)
Exemple #5
0
    def test_uncorrelated_3d(self):
        x = np.linspace(0.0, 100.0, 30)
        y = np.linspace(0.0, 100.0, 30)
        z = np.linspace(0.0, 100.0, 30)

        rng = np.random.RandomState(1479373475)
        field = rng.rand(len(x), len(y), len(z))

        gamma = variogram.vario_estimate_structured(field, "x")
        gamma = variogram.vario_estimate_structured(field, "y")
        gamma = variogram.vario_estimate_structured(field, "z")

        var = 1.0 / 12.0
        self.assertAlmostEqual(gamma[0], 0.0, places=2)
        self.assertAlmostEqual(gamma[len(gamma) // 2], var, places=2)
        self.assertAlmostEqual(gamma[-1], var, places=2)
 def test_list(self):
     z = [41.2, 40.2, 39.7, 39.2, 40.1, 38.3, 39.1, 40.0, 41.1, 40.3]
     try:
         gamma = variogram.vario_estimate_structured(z)
         self.assertAlmostEqual(gamma[1], 0.4917, places=4)
     except NotImplementedError as e:
         pass
 def test_np_int(self):
     z = np.array((10, 20, 30, 40), dtype=np.int)
     try:
         gamma = variogram.vario_estimate_structured(z)
         self.assertAlmostEqual(gamma[1], 50.0, places=4)
     except NotImplementedError as e:
         pass
Exemple #8
0
    def test_uncorrelated_2d(self):
        x = np.linspace(0.0, 100.0, 80)
        y = np.linspace(0.0, 100.0, 60)

        rng = np.random.RandomState(1479373475)
        field = rng.rand(len(x), len(y))

        gamma_x = variogram.vario_estimate_structured(field, direction="x")
        gamma_y = variogram.vario_estimate_structured(field, direction="y")

        var = 1.0 / 12.0
        self.assertAlmostEqual(gamma_x[0], 0.0, places=2)
        self.assertAlmostEqual(gamma_x[len(gamma_x) // 2], var, places=2)
        self.assertAlmostEqual(gamma_x[-1], var, places=2)
        self.assertAlmostEqual(gamma_y[0], 0.0, places=2)
        self.assertAlmostEqual(gamma_y[len(gamma_y) // 2], var, places=2)
        self.assertAlmostEqual(gamma_y[-1], var, places=2)
Exemple #9
0
 def test_1d(self):
     # literature values
     z = np.array(
         (41.2, 40.2, 39.7, 39.2, 40.1, 38.3, 39.1, 40.0, 41.1, 40.3),
         dtype=np.double,
     )
     gamma = variogram.vario_estimate_structured(z)
     self.assertAlmostEqual(gamma[0], 0.0000, places=4)
     self.assertAlmostEqual(gamma[1], 0.4917, places=4)
     self.assertAlmostEqual(gamma[2], 0.7625, places=4)
    def test_mixed(self):
        z = np.array(
            (41.2, 40.2, 39.7, 39.2, 40.1, 38.3, 39.1, 40.0, 41.1, 40.3),
            dtype=np.double,
        )
        try:
            gamma = variogram.vario_estimate_structured(z)
            self.assertAlmostEqual(gamma[1], 0.4917, places=4)

            z = np.array((10, 20, 30, 40), dtype=LONGTYPE)

            gamma = variogram.vario_estimate_structured(z)
            self.assertAlmostEqual(gamma[1], 50.0, places=4)

            z = np.array((10, 20, 30, 40), dtype=LONGTYPE)
            gamma = variogram.vario_estimate_structured(z)
            self.assertAlmostEqual(gamma[1], 50.0, places=4)
        except NotImplementedError as e:
            pass
Exemple #11
0
    def test_uncorrelated_cressie_2d(self):
        x = np.linspace(0.0, 100.0, 80)
        y = np.linspace(0.0, 100.0, 60)

        rng = np.random.RandomState(1479373475)
        field = rng.rand(len(x), len(y))

        gamma_x = variogram.vario_estimate_structured(field,
                                                      direction="x",
                                                      estimator="cressie")
        gamma_y = variogram.vario_estimate_structured(field,
                                                      direction="y",
                                                      estimator="cressie")

        # TODO figure out what is going on here
        var = 0.177
        self.assertAlmostEqual(gamma_x[0], 0.0, places=1)
        self.assertAlmostEqual(gamma_x[len(gamma_x) // 2], var, places=1)
        self.assertAlmostEqual(gamma_y[0], 0.0, places=1)
        self.assertAlmostEqual(gamma_y[len(gamma_y) // 2], var, places=1)
Exemple #12
0
    def test_masked_3d(self):
        rng = np.random.RandomState(1479373475)
        field = rng.rand(30, 30, 30)
        mask = np.zeros_like(field)
        field_ma = np.ma.masked_array(field, mask=mask)

        gamma_x = variogram.vario_estimate_structured(field_ma, direction="x")
        gamma_y = variogram.vario_estimate_structured(field_ma, direction="y")
        gamma_z = variogram.vario_estimate_structured(field_ma, direction="z")

        var = 1.0 / 12.0
        self.assertAlmostEqual(gamma_x[0], 0.0, places=2)
        self.assertAlmostEqual(gamma_x[len(gamma_x) // 2], var, places=2)
        self.assertAlmostEqual(gamma_x[-1], var, places=2)
        self.assertAlmostEqual(gamma_y[0], 0.0, places=2)
        self.assertAlmostEqual(gamma_y[len(gamma_y) // 2], var, places=2)
        self.assertAlmostEqual(gamma_y[-1], var, places=2)
        self.assertAlmostEqual(gamma_z[0], 0.0, places=2)
        self.assertAlmostEqual(gamma_z[len(gamma_y) // 2], var, places=2)
        self.assertAlmostEqual(gamma_z[-1], var, places=2)

        mask = np.zeros_like(field)
        mask[0, 0, 0] = 1
        field = np.ma.masked_array(field, mask=mask)
        gamma_x = variogram.vario_estimate_structured(field_ma, direction="x")
        gamma_y = variogram.vario_estimate_structured(field_ma, direction="y")
        gamma_z = variogram.vario_estimate_structured(field_ma, direction="z")
        self.assertAlmostEqual(gamma_x[0], 0.0, places=2)
        self.assertAlmostEqual(gamma_y[0], 0.0, places=2)
        self.assertAlmostEqual(gamma_z[0], 0.0, places=2)
    def test_directions_3d(self):
        x = np.linspace(0.0, 10.0, 20)
        y = np.linspace(0.0, 15.0, 25)
        z = np.linspace(0.0, 20.0, 30)
        rng = np.random.RandomState(1479373475)
        x_rand = rng.rand(len(x))
        y_rand = rng.rand(len(y))
        z_rand = rng.rand(len(z))

        field_x = np.tile(x_rand.reshape((len(x), 1, 1)), (1, len(y), len(z)))
        field_y = np.tile(y_rand.reshape((1, len(y), 1)), (len(x), 1, len(z)))
        field_z = np.tile(z_rand.reshape((1, 1, len(z))), (len(x), len(y), 1))

        try:
            gamma_x_x = variogram.vario_estimate_structured(field_x, direction="x")
            gamma_x_y = variogram.vario_estimate_structured(field_x, direction="y")
            gamma_x_z = variogram.vario_estimate_structured(field_x, direction="z")

            gamma_y_x = variogram.vario_estimate_structured(field_y, direction="x")
            gamma_y_y = variogram.vario_estimate_structured(field_y, direction="y")
            gamma_y_z = variogram.vario_estimate_structured(field_y, direction="z")

            gamma_z_x = variogram.vario_estimate_structured(field_z, direction="x")
            gamma_z_y = variogram.vario_estimate_structured(field_z, direction="y")
            gamma_z_z = variogram.vario_estimate_structured(field_z, direction="z")
            self.assertAlmostEqual(gamma_x_y[1], 0.0)
            self.assertAlmostEqual(gamma_x_y[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_x_y[-1], 0.0)
            self.assertAlmostEqual(gamma_x_z[1], 0.0)
            self.assertAlmostEqual(gamma_x_z[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_x_z[-1], 0.0)
            self.assertAlmostEqual(gamma_y_x[1], 0.0)
            self.assertAlmostEqual(gamma_y_x[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_y_x[-1], 0.0)
            self.assertAlmostEqual(gamma_y_z[1], 0.0)
            self.assertAlmostEqual(gamma_y_z[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_y_z[-1], 0.0)
            self.assertAlmostEqual(gamma_z_x[1], 0.0)
            self.assertAlmostEqual(gamma_z_x[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_z_x[-1], 0.0)
            self.assertAlmostEqual(gamma_z_y[1], 0.0)
            self.assertAlmostEqual(gamma_z_y[len(gamma_x_y) // 2], 0.0)
            self.assertAlmostEqual(gamma_z_y[-1], 0.0)
        except NotImplementedError as e:
            pass
Exemple #14
0
 def test_cressie_1d(self):
     z = [41.2, 40.2, 39.7, 39.2, 40.1, 38.3, 39.1, 40.0, 41.1, 40.3]
     gamma = variogram.vario_estimate_structured(z, estimator="cressie")
     self.assertAlmostEqual(gamma[1], 1.546, places=3)
Exemple #15
0
 def test_list(self):
     z = [41.2, 40.2, 39.7, 39.2, 40.1, 38.3, 39.1, 40.0, 41.1, 40.3]
     gamma = variogram.vario_estimate_structured(z)
     self.assertAlmostEqual(gamma[1], 0.4917, places=4)
Exemple #16
0
 def test_np_int(self):
     z = np.array((10, 20, 30, 40), dtype=np.int)
     gamma = variogram.vario_estimate_structured(z)
     self.assertAlmostEqual(gamma[1], 50.0, places=4)