From: megacz Date: Wed, 4 Mar 2009 16:15:00 +0000 (-0800) Subject: add ability to scale and transform ScalarFields X-Git-Url: http://git.megacz.com/?p=anneal.git;a=commitdiff_plain;h=ad41007be5974ac334b07b48786cf1ffc6d16dfa add ability to scale and transform ScalarFields --- diff --git a/src/edu/berkeley/qfat/voxel/ScalarField.java b/src/edu/berkeley/qfat/voxel/ScalarField.java index 7af8673..3365432 100644 --- a/src/edu/berkeley/qfat/voxel/ScalarField.java +++ b/src/edu/berkeley/qfat/voxel/ScalarField.java @@ -10,4 +10,13 @@ public interface ScalarField { public float getSample(Point p); + /** transform the scalar field in space */ + public ScalarField transform(Matrix m); + + /** add f to all scalar values */ + public ScalarField plus(float f); + + /** multiply all scalar values by f */ + public ScalarField times(float f); + } \ No newline at end of file diff --git a/src/edu/berkeley/qfat/voxel/VoxelData.java b/src/edu/berkeley/qfat/voxel/VoxelData.java index 98fffcc..9d446a4 100644 --- a/src/edu/berkeley/qfat/voxel/VoxelData.java +++ b/src/edu/berkeley/qfat/voxel/VoxelData.java @@ -18,4 +18,8 @@ public abstract class VoxelData implements ScalarField, HasBoundingBox { public abstract float getMinZ(); public abstract int getNumSamplesZ(); + public ScalarField transform(Matrix m) { throw new RuntimeException("not implemented"); } + public ScalarField plus(float f) { throw new RuntimeException("not implemented"); } + public ScalarField times(float f) { throw new RuntimeException("not implemented"); } + } \ No newline at end of file