CONTOURF AS PATCH COMMAND

Hello,
I have 3 column matrix. I want to plot contourf but plot shape is wrong. When i try with patch command shape is true. How can i do this with contourf? Here is example picture.
01.jpg
here is my patch figure code:
a=load('xyz.txt');
x=a(:,1);
y=a(:,2);
m1=a(:,3);
cor=[x y];
ff=reshape( 1:length(cor), 4, length(cor)/4)';
fig = figure;
pm=patch('Faces',ff,'Vertices',cor,'FaceVertexCData',m1,'FaceColor','interp','Selected','on');
colormap(flipud(jet(20)))
shading interp
colorbar
set(pm, 'edgecolor','black','LineWidth',0.5)
grid on
grid minor

3 Comments

How are you generating the data for contourf() ?
here is my code for contourf:
xi=linspace(min(x),max(x),300);
yi=linspace(min(y),max(y),300);
[XI YI]=meshgrid(xi,yi);
M1I = griddata(x,y,m1,XI,YI);
figure
contourf(XI,YI,M1I,'edgecolor','none')
colormap(flipud(jet(10)))
shading interp
colorbar
title('X MOMENT','FontSize',14)
grid on
grid minor
this code plots out of boundaries of shape.
Do you have any idea about this my friends?
I am looking forward to your help :)

Sign in to comment.

 Accepted Answer

Walter Roberson
Walter Roberson on 30 Oct 2019
What you observe is expected for griddata() and other scattered interpolants. You do not have data in a number of areas, but you ask for the values in those areas, so griddata() interpolates from the existing points. By asking for data in those areas but wanting blanks there, you are implicitly saying that lack of data in an area should be treated as-if data were there and was NaN there -- but that somehow the system should know to insert those implicit nans locally, and be smart about it. For example in the place where you have two rectangles touching diagonally, you do not want interpolation between the two rectangles, even though some of those points are closer together than some of the points in the bounds that you do want to influence interpolation.
You will need to segment your data into distinct regions and grid them separately.
For the case you loaded the file for, probably the easiest would be to use an editor to divide into parts.
If you had a number of similar files to process, you can do some processing based upon clustering such as k-means, or using nearest-neighbor-with-cutoff approaches, but automatically dividing out touching diagonal boxes is probably going to take more thought.

7 Comments

Thank you for ypur advices friend :)
I have already group my data as rectangles with accumarray command. In my data above, there are 300 rectangles and i can grup them with accumaaray. After this point i use "for loop" with every group for every rectangle and plot contourf. But this takes a lot of time to get figure and i wait long time for result.
Any advice for making this fast?
Thank you again :)
Discretize your coordinates, accumarray() the [y x] indices for first parameter and z as second parameter, with @mean and nan filler. Now contourf() that with appropriate x y coordinates.
i cant understand what i should do :)
here is my data. first column x coordinate, second column y coordinate,third column z coordinate and fourth column is rectangle number. I can make groups witth accumarray using unique elements in the fourth column. After that what should i do?
Thank you for your time and help :)
minx = min(x); miny = min(y);
xidx = round((x-minx)*2) + 1;
yidx = round((y-miny)*2) + 1;
G = accumarray([yidx, xidx], z, [], @mean, nan);
xi = minx + 0.5 * (0:size(G,2)-1);
yi = miny + 0.5 * (0:size(G,1)-1);
contourf(xi, yi, G)
Mooner Land
Mooner Land on 31 Oct 2019
Edited: Mooner Land on 31 Oct 2019
thank you friend, the code works for this example but does not gives correct results for another example data. thank for yor all help. :)
You could do a morphological dilation on "isnan()" of the array in order to disconnect areas that barely touch.
I am not really good at matlab, so its hard to do this thing. Thank you friend, you are so kind :)

Sign in to comment.

More Answers (0)

Products

Release

R2019b

Community Treasure Hunt

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

Start Hunting!