Skip to content

Conversation

bogovicj
Copy link
Contributor

@bogovicj bogovicj commented Sep 5, 2025

This PR adds a SphericalCurvatureDistortionTransform that can serve to model a particular kind of distortion in optical systems.

This example code:

final int numDimensions = 2;
final int dimensionToTransform = 1;
final double radiusOfCurvature = 250;
final SphericalCurvatureDistortionTransform tform = new SphericalCurvatureDistortionTransform(
		numDimensions,
		dimensionToTransform,
		radiusOfCurvature);

final ArrayImg<UnsignedByteType, ByteArray> img = ArrayImgs.unsignedBytes(256,256);
img.view().interval(Intervals.createMinMax(36,128,164,164)).forEach( x -> x.set(255) );

final RandomAccessibleIntervalView<UnsignedByteType> imgTform = RealViews.transform(
	img.view()
		.extend(Extension.zero())
		.interpolate(Interpolation.nLinear()),
	tform).realView().raster().view().interval(img);

ImageJFunctions.show(img, "toy tile");
ImageJFunctions.show(imgTform, "toy tile distorted");

produces this output:
image

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

1 participant