Ejemplo n.º 1
0
    def assertZeroShift(self, order, regularization, num_boundary_points):
        """Check that warping with zero displacements doesn't change the image."""
        batch_size = 1
        image_height = 4
        image_width = 4
        channels = 3

        image = np.random.uniform(
            size=[batch_size, image_height, image_width, channels])

        input_image_op = constant_op.constant(np.float32(image))

        control_point_locations = [[1., 1.], [2., 2.], [2., 1.]]
        control_point_locations = constant_op.constant(
            np.float32(np.expand_dims(control_point_locations, 0)))

        control_point_displacements = np.zeros(
            control_point_locations.shape.as_list())
        control_point_displacements = constant_op.constant(
            np.float32(control_point_displacements))

        (warped_image_op, flow_field) = sparse_image_warp.sparse_image_warp(
            input_image_op,
            control_point_locations,
            control_point_locations + control_point_displacements,
            interpolation_order=order,
            regularization_weight=regularization,
            num_boundary_points=num_boundary_points)

        with self.test_session() as sess:
            warped_image, input_image, _ = sess.run(
                [warped_image_op, input_image_op, flow_field])

            self.assertAllClose(warped_image, input_image)
  def assertZeroShift(self, order, regularization, num_boundary_points):
    """Check that warping with zero displacements doesn't change the image."""
    batch_size = 1
    image_height = 4
    image_width = 4
    channels = 3

    image = np.random.uniform(
        size=[batch_size, image_height, image_width, channels])

    input_image_op = constant_op.constant(np.float32(image))

    control_point_locations = [[1., 1.], [2., 2.], [2., 1.]]
    control_point_locations = constant_op.constant(
        np.float32(np.expand_dims(control_point_locations, 0)))

    control_point_displacements = np.zeros(
        control_point_locations.shape.as_list())
    control_point_displacements = constant_op.constant(
        np.float32(control_point_displacements))

    (warped_image_op, flow_field) = sparse_image_warp.sparse_image_warp(
        input_image_op,
        control_point_locations,
        control_point_locations + control_point_displacements,
        interpolation_order=order,
        regularization_weight=regularization,
        num_boundary_points=num_boundary_points)

    with self.test_session() as sess:
      warped_image, input_image, _ = sess.run(
          [warped_image_op, input_image_op, flow_field])

      self.assertAllClose(warped_image, input_image)
Ejemplo n.º 3
0
    def testThatBackpropRuns(self):
        """Run optimization to ensure that gradients can be computed."""

        batch_size = 1
        image_height = 9
        image_width = 12
        image = variables.Variable(
            np.float32(
                np.random.uniform(
                    size=[batch_size, image_height, image_width, 3])))
        control_point_locations = [[3., 3.]]
        control_point_locations = constant_op.constant(
            np.float32(np.expand_dims(control_point_locations, 0)))
        control_point_displacements = [[0.25, -0.5]]
        control_point_displacements = constant_op.constant(
            np.float32(np.expand_dims(control_point_displacements, 0)))
        warped_image, _ = sparse_image_warp.sparse_image_warp(
            image,
            control_point_locations,
            control_point_locations + control_point_displacements,
            num_boundary_points=3)

        loss = math_ops.reduce_mean(math_ops.abs(warped_image - image))
        optimizer = momentum.MomentumOptimizer(0.001, 0.9)
        grad = gradients.gradients(loss, [image])
        grad, _ = clip_ops.clip_by_global_norm(grad, 1.0)
        opt_func = optimizer.apply_gradients(zip(grad, [image]))
        init_op = variables.global_variables_initializer()

        with self.test_session() as sess:
            sess.run(init_op)
            for _ in range(5):
                sess.run([loss, opt_func])
  def testThatBackpropRuns(self):
    """Run optimization to ensure that gradients can be computed."""

    batch_size = 1
    image_height = 9
    image_width = 12
    image = variables.Variable(
        np.float32(
            np.random.uniform(size=[batch_size, image_height, image_width, 3])))
    control_point_locations = [[3., 3.]]
    control_point_locations = constant_op.constant(
        np.float32(np.expand_dims(control_point_locations, 0)))
    control_point_displacements = [[0.25, -0.5]]
    control_point_displacements = constant_op.constant(
        np.float32(np.expand_dims(control_point_displacements, 0)))
    warped_image, _ = sparse_image_warp.sparse_image_warp(
        image,
        control_point_locations,
        control_point_locations + control_point_displacements,
        num_boundary_points=3)

    loss = math_ops.reduce_mean(math_ops.abs(warped_image - image))
    optimizer = momentum.MomentumOptimizer(0.001, 0.9)
    grad = gradients.gradients(loss, [image])
    grad, _ = clip_ops.clip_by_global_norm(grad, 1.0)
    opt_func = optimizer.apply_gradients(zip(grad, [image]))
    init_op = variables.global_variables_initializer()

    with self.test_session() as sess:
      sess.run(init_op)
      for _ in range(5):
        sess.run([loss, opt_func])
Ejemplo n.º 5
0
    def testSmileyFace(self):
        """Check warping accuracy by comparing to hardcoded warped images."""

        test_data_dir = test.test_src_dir_path('contrib/image/python/'
                                               'kernel_tests/test_data/')
        input_file = test_data_dir + 'Yellow_Smiley_Face.png'
        with self.test_session() as sess:
            input_image = self.load_image(input_file, sess)
        control_points = np.asarray([[64, 59], [180 - 64, 59], [39, 111],
                                     [180 - 39, 111], [90, 143], [58, 134],
                                     [180 - 58, 134]])  # pyformat: disable
        control_point_displacements = np.asarray([[-10.5, 10.5], [10.5, 10.5],
                                                  [0, 0], [0, 0], [0, -10],
                                                  [-20, 10.25], [10, 10.75]])
        control_points_op = constant_op.constant(
            np.expand_dims(np.float32(control_points[:, [1, 0]]), 0))
        control_point_displacements_op = constant_op.constant(
            np.expand_dims(np.float32(control_point_displacements[:, [1, 0]]),
                           0))
        float_image = np.expand_dims(np.float32(input_image) / 255, 0)
        input_image_op = constant_op.constant(float_image)

        for interpolation_order in (1, 2, 3):
            for num_boundary_points in (0, 1, 4):
                warp_op, _ = sparse_image_warp.sparse_image_warp(
                    input_image_op,
                    control_points_op,
                    control_points_op + control_point_displacements_op,
                    interpolation_order=interpolation_order,
                    num_boundary_points=num_boundary_points)
                with self.test_session() as sess:
                    warped_image = sess.run(warp_op)
                    out_image = np.uint8(warped_image[0, :, :, :] * 255)
                    target_file = (
                        test_data_dir + 'Yellow_Smiley_Face_Warp-interp' +
                        '-{}-clamp-{}.png'.format(interpolation_order,
                                                  num_boundary_points))

                    target_image = self.load_image(target_file, sess)

                    # Check that the target_image and out_image difference is no
                    # bigger than 2 (on a scale of 0-255). Due to differences in
                    # floating point computation on different devices, the float
                    # output in warped_image may get rounded to a different int
                    # than that in the saved png file loaded into target_image.
                    self.assertAllClose(target_image,
                                        out_image,
                                        atol=2,
                                        rtol=1e-3)
Ejemplo n.º 6
0
    def assertMoveSinglePixel(self, order, num_boundary_points, type_to_use):
        """Move a single block in a small grid using warping."""
        batch_size = 1
        image_height = 7
        image_width = 7
        channels = 3

        image = np.zeros([batch_size, image_height, image_width, channels])
        image[:, 3, 3, :] = 1.0
        input_image_op = constant_op.constant(image, dtype=type_to_use)

        # Place a control point at the one white pixel.
        control_point_locations = [[3., 3.]]
        control_point_locations = constant_op.constant(np.float32(
            np.expand_dims(control_point_locations, 0)),
                                                       dtype=type_to_use)
        # Shift it one pixel to the right.
        control_point_displacements = [[0., 1.0]]
        control_point_displacements = constant_op.constant(np.float32(
            np.expand_dims(control_point_displacements, 0)),
                                                           dtype=type_to_use)

        (warped_image_op, flow_field) = sparse_image_warp.sparse_image_warp(
            input_image_op,
            control_point_locations,
            control_point_locations + control_point_displacements,
            interpolation_order=order,
            num_boundary_points=num_boundary_points)

        with self.test_session() as sess:
            warped_image, input_image, flow = sess.run(
                [warped_image_op, input_image_op, flow_field])
            # Check that it moved the pixel correctly.
            self.assertAllClose(warped_image[0, 4, 5, :],
                                input_image[0, 4, 4, :],
                                atol=1e-5,
                                rtol=1e-5)

            # Test that there is no flow at the corners.
            for i in (0, image_height - 1):
                for j in (0, image_width - 1):
                    self.assertAllClose(flow[0, i, j, :],
                                        np.zeros([2]),
                                        atol=1e-5,
                                        rtol=1e-5)
  def testSmileyFace(self):
    """Check warping accuracy by comparing to hardcoded warped images."""

    test_data_dir = test.test_src_dir_path('contrib/image/python/'
                                           'kernel_tests/test_data/')
    input_file = test_data_dir + 'Yellow_Smiley_Face.png'
    with self.test_session() as sess:
      input_image = self.load_image(input_file, sess)
    control_points = np.asarray([[64, 59], [180 - 64, 59], [39, 111],
                                 [180 - 39, 111], [90, 143], [58, 134],
                                 [180 - 58, 134]])  # pyformat: disable
    control_point_displacements = np.asarray(
        [[-10.5, 10.5], [10.5, 10.5], [0, 0], [0, 0], [0, -10], [-20, 10.25],
         [10, 10.75]])
    control_points_op = constant_op.constant(
        np.expand_dims(np.float32(control_points[:, [1, 0]]), 0))
    control_point_displacements_op = constant_op.constant(
        np.expand_dims(np.float32(control_point_displacements[:, [1, 0]]), 0))
    float_image = np.expand_dims(np.float32(input_image) / 255, 0)
    input_image_op = constant_op.constant(float_image)

    for interpolation_order in (1, 2, 3):
      for num_boundary_points in (0, 1, 4):
        warp_op, _ = sparse_image_warp.sparse_image_warp(
            input_image_op,
            control_points_op,
            control_points_op + control_point_displacements_op,
            interpolation_order=interpolation_order,
            num_boundary_points=num_boundary_points)
        with self.test_session() as sess:
          warped_image = sess.run(warp_op)
          out_image = np.uint8(warped_image[0, :, :, :] * 255)
          target_file = (
              test_data_dir +
              'Yellow_Smiley_Face_Warp-interp' + '-{}-clamp-{}.png'.format(
                  interpolation_order, num_boundary_points))

          target_image = self.load_image(target_file, sess)

          # Check that the target_image and out_image difference is no
          # bigger than 2 (on a scale of 0-255). Due to differences in
          # floating point computation on different devices, the float
          # output in warped_image may get rounded to a different int
          # than that in the saved png file loaded into target_image.
          self.assertAllClose(target_image, out_image, atol=2, rtol=1e-3)
  def assertMoveSinglePixel(self, order, num_boundary_points, type_to_use):
    """Move a single block in a small grid using warping."""
    batch_size = 1
    image_height = 7
    image_width = 7
    channels = 3

    image = np.zeros([batch_size, image_height, image_width, channels])
    image[:, 3, 3, :] = 1.0
    input_image_op = constant_op.constant(image, dtype=type_to_use)

    # Place a control point at the one white pixel.
    control_point_locations = [[3., 3.]]
    control_point_locations = constant_op.constant(
        np.float32(np.expand_dims(control_point_locations, 0)),
        dtype=type_to_use)
    # Shift it one pixel to the right.
    control_point_displacements = [[0., 1.0]]
    control_point_displacements = constant_op.constant(
        np.float32(np.expand_dims(control_point_displacements, 0)),
        dtype=type_to_use)

    (warped_image_op, flow_field) = sparse_image_warp.sparse_image_warp(
        input_image_op,
        control_point_locations,
        control_point_locations + control_point_displacements,
        interpolation_order=order,
        num_boundary_points=num_boundary_points)

    with self.test_session() as sess:
      warped_image, input_image, flow = sess.run(
          [warped_image_op, input_image_op, flow_field])
      # Check that it moved the pixel correctly.
      self.assertAllClose(
          warped_image[0, 4, 5, :],
          input_image[0, 4, 4, :],
          atol=1e-5,
          rtol=1e-5)

      # Test that there is no flow at the corners.
      for i in (0, image_height - 1):
        for j in (0, image_width - 1):
          self.assertAllClose(
              flow[0, i, j, :], np.zeros([2]), atol=1e-5, rtol=1e-5)