hilbertCurve

Version 1.0.1.0 (2.59 KB) by Kenny Kim
Convert 2D data to 1D data and back easily by applying Hilbert curve transformation
189 Downloads
Updated 6 Jul 2018

View License

The benefit of Hilbert curve transformation is that the 1D data can be downsampled or upsampled without worrying about whether the 2D coordinate of the data point changes. Hilbert curve is designed in such a way that the absolute index of the data point does not matter; only the relative index compared to the whole data size matters.

Consists of three files:

hilbertCurve takes in 2D data and outputs it as 1D data.
hilbertCurveRev takes in 1D data and outputs it as 2D data.
hilbertCurveExample gives examples of using the functions.

Example:

% toy data
rowLen = 256;
data = zeros(rowLen,rowLen);
for x = 1:rowLen
for y = 1:rowLen
data(x,y) = exp(-(0.125/rowLen)*((x-(rowLen+1)/2)^2+(y-(rowLen+1)/2)^2));
end
end

% transform to hilbert curve
transData = hilbertCurve(data);

% reduce dimensionality
reduceRatio = 16; % has to be power of 4
transData = downsample(transData,reduceRatio);

%%%%% this is where you would place any of your analysis scripts %%%%%

% reverse transform to 2D
twoDimData = hilbertCurveRev(transData);

% plot
figure('Position',[100 100 1000 400]);
subplot(1,2,1);
imagesc(data,[0 1]);
subplot(1,2,2);
imagesc(twoDimData,[0 1]);

Cite As

Kenny Kim (2024). hilbertCurve (https://www.mathworks.com/matlabcentral/fileexchange/67957-hilbertcurve), MATLAB Central File Exchange. Retrieved .

MATLAB Release Compatibility
Created with R2017b
Compatible with any release
Platform Compatibility
Windows macOS Linux

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!
Version Published Release Notes
1.0.1.0

Adding image and putting an example on description. No change to actual code.
another minor change to description (just spacing)
minor change to description
minor change to description

1.0.0.0