How do I create a 3D histogram for; x = 1*26, y=1*28, z = 26*28 ?

12 Ansichten (letzte 30 Tage)
Aaron Rampersad
Aaron Rampersad am 21 Mär. 2016
Verschoben: Rik am 14 Apr. 2023
I would basically like to bin the the 'z' data into ranges of x and y such as the attached picture:
  2 Kommentare
Joachim Schlosser
Joachim Schlosser am 21 Mär. 2016
Please attach some sample data and the code you have tried so far.
Aaron Rampersad
Aaron Rampersad am 22 Mär. 2016
I used this code from filexchange but I ended up with a very dense plot attached below:
What I would like to do is place these z-values which is a 26*28 matrix into bins associated with the x and y values

Melden Sie sich an, um zu kommentieren.

Antworten (3)

Walter Roberson
Walter Roberson am 21 Mär. 2016
There are also a lot of histogram programs in the File Exchange.
  2 Kommentare
Aaron Rampersad
Aaron Rampersad am 21 Mär. 2016
Those two commands hist3 and bar3 does not place the Z matrix which is a 26*28 into bins associated with the X and Y matrices.

Melden Sie sich an, um zu kommentieren.


Image Analyst
Image Analyst am 22 Mär. 2016
Aaron, give the x and y data as an N by 2 array, then pass in the number of bins in each direction into the poorly named hist3() to create your 2D histogram
counts = hist3([x, y], [26, 28]);
  8 Kommentare
Aaron Rampersad
Aaron Rampersad am 26 Mär. 2016
Bearbeitet: Aaron Rampersad am 26 Mär. 2016
doesn't the hist3() function only handle x and y vectors of the same size?
My x data is a vector of size 1*26 and my y data is of size 1*28 and my z data is of size 28*26 i.e. a product x and y data inputs.
Image Analyst
Image Analyst am 26 Mär. 2016
Well now you'r totally confusing everybody. We though that the x and y were basically ranges that your data could take. So one data point had both an x coordinate, and a y coordinate. And you wanted 28 bins along the y direction, and 26 bins along the x direction. And then "z" would be the counts of how many data points fell into a certain x,y bins. You don't have any z data yet, before taking the histogram, do you? It's to be computed and is the "count" data. If that's not right, then no one has read your mind correctly, and you'll need to explain better and attach your x, y, and z arrays.

Melden Sie sich an, um zu kommentieren.


Mike Garrity
Mike Garrity am 22 Mär. 2016
If you're using R2015b or later, you can use the new histogram2 function.
histogram2(10+5*randn(1e4,1),3*randn(1e4,1),'FaceColor','flat')
  13 Kommentare
Image Analyst
Image Analyst am 11 Apr. 2023
Verschoben: Rik am 14 Apr. 2023
You don't need the toolbox to run scatteredInterpolant. You can run it on just a regular 2-D matrix. Here is the main part:
%================================ MAIN PART RIGHT HERE ==============================================
% Create the scattered interpolant. x, y, and gray levels must be column vectors so use (:) to make them column vectors.
% And grayLevels must be double or else an error gets thrown.
F = scatteredInterpolant(xAll(:), yAll(:), double(grayLevelsAll(:)))
% The above line creates an interpolant that fits a surface of the form v = F(x,y).
% Vectors x and y specify the (x,y) coordinates of the sample points.
% v is a vector that contains the sample values associated with the points (x,y).
% Get a grid of points at every pixel location in the RGB image.
[xGrid, yGrid] = meshgrid(1:columns, 1:rows);
xq = xGrid(:);
yq = yGrid(:);
% Evaluate the interpolant at query locations (xq,yq).
vq = F(xq, yq);
fittedImage = reshape(vq, rows, columns);
%================================ END OF MAIN PART ==============================================
grayLevelsAll is the known values of the few locations that you know the values of.
xAll and yAll are your known coordinate values of the locations.
rows and columns are the size of the matrix you want to fill out.
fittedImage is the 2-D array - you don't have to consider it as an image if you don't want to.
CSCh
CSCh am 14 Apr. 2023
Verschoben: Rik am 14 Apr. 2023
Thank you.
Chris

Melden Sie sich an, um zu kommentieren.

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by