polarPcolor aims to represent a pseudocolour plot in polar coordinates, with a radial grid to allow clear visualization of the data. It is well suited for Plan Position Indicator (PPI) scan for radar or lidar for example . A similar function is available in ref. , which propose a visualization in 3D.
 Cheynet, E., Jakobsen, J. B., Snæbjörnsson, J., Reuder, J., Kumer, V., & Svardal, B. (2017). Assessing the potential of a commercial pulsed lidar for wind characterisation at a bridge site. Journal of Wind Engineering and Industrial Aerodynamics, 161, 17-26. http://dx.doi.org/10.1016/j.jweia.2016.12.002
E. Cheynet (2020). pcolor in polar coordinates (https://github.com/ECheynet/polarPcolor/releases/tag/v3.8), GitHub. Retrieved .
Cheynet, E. ECheynet/PolarPcolor v3.8. Zenodo, 2020, doi:10.5281/ZENODO.3774156.
If you have r, theta, f(r,theta), then most of the work is done. All you need is to do as in the examples provided in the Matlab LiveScript (example 1: "Minimalist example")
Hello, I have a three column data file of the form r, theta, f(r,theta). I want to visualize my data as a polar map. How can I achieve this with this package?
I only have two variables: elevation angles (from 3 to 90 degrees) and azimuth angles(from 0 to 360 degrees), as well as the functions P depending on the two variables.
So I suppose you have both elevation and azimuth angle. So that means you likely have a third variable such as the " radial distance" to your source. Is it correct?
Supposing R is taken as elevation angles, varing from 3 degree to 90 degree. I wanna set origin as 90 degree, and the outermost circle as 3 degree. Only the circle represents the elevation angle, which isn't related to the radius. I have taken a look at the examples in the .mlx file, however I still don't find the method to solve this problem.
Hi xc q,
Have a look at the examples in the .mlx file. They should help you. Also, I'm not sure I understand how you can have a radius R that both increases (from inner to outer) and decreases at the same time (from 90 to 3).
Hey! Thank you very much for the code.
Supposing R ranges from 3 to 90. How can I specify Origin as R max, that is R changes from 90 (inner) to 3 (outer)?
Given the low number of data points you have, I suggest that you use a table. Alternatively, you have the following plotting possibilities:
Thanks so much for laying this out. I am dealing with a fairly small number of data points (8 theta values and 3 r values). Is there any way to smooth the colors? Right now, the graph is very block-y and not a continuous contour. Thanks!
I have updated the function for the input parameter "Origin", which is now named "autoOrigin" for the sake of clarity. In the example file (interactive Matlab script), the last section of the example illustrates the use of the option "autoOrigin". In a few words: this option changes the visualization of the area plotted: either an annulus if the lowest value of R is different of zero ("autoOrigin" is 'on') or a disk if "autoOrigin" is 'off'
Thank you for the code. I wonder, what is the use of the input parameter "Origin"? How should it be used in different cases? I think the help text does not tell this.
Hi Seunguk Lee,
Assuming that "myDir" is the variable storing the direction from 0 to 360 degree, you can come back to a clockwise orientation with the zero in the eastern direction by writing:
myDir = 90-myDir;
hello! it's pretty good!!!!
i have a question .
With the library now, the data is placed clockwise. But I want the data to be placed counterclockwise. In addition, 0 direction always faces upward. Can I set this direction?
The colorbar is still activated by default on the Matlab version I use (>R2018). Note that the circle for the lowest value of R is normal since I need to "close" the border of the pseudocolour plot. I have updated a new version but I am unsure it will solve your problem.
That is brilliant, thank you! However, I think the colorbar is not activated anymore by default.
And also, my R ranges from 6 to 90, I specify Origin as R min so it starts from 6 (which it does), and then pos = [16 22 34 64] to have circles at 22, 28, 40 and 70. However, the code creates an extra inner circle at Rmin + Origin, so at 12 in my case and I end up with 5 circles rather than 4. Other than that, flawless.
Thank for the suggestions. I have added three new options in the function: One to change the colourmap more easily, one to limit the number of colour used and one to specify the radial grid more freely, i.e. a non-equidistant grid. The example file includes these new options.
This is excellent, thanks a bunch!
I was wondering if you could hardcode the colormap it uses, as colorpmap(jet) does not seem to work, but it works from the Property Editor of the figure.
Also, could you plot this in finer steps? Similar to defining the 'LevelStep' to whatever value in contourf.
Oh and another quick one: can you get the circles at values that are not equidistant? I had a look through your code and you are using linspace; I tried to change that, but it would not work. Example:
tickMesh = linspace(rMin,rMax,Ncircles); %%MODIFY HERE FOR CUSTOM THETA ANGLES
I changed that to something like:
tickMesh = [6 22 28 40 70 90];
This works nicely - thank you.
A small comment: it seems the range of radii is rescaled to the interval [0,1] for plotting; this becomes relevant if one wants to add additional graphical elements to the same plot later.
I had, unfortunately, not the occasion to try the function with macOS. What error message do you get?
@E. Cheynet Thank you for this! Is there a reason why this wouldn't work for macOS?
I noticed one small (possibly intentional?) issue with this function. The function assumes the theta values you give are the start point for each drawn sector, not the center. I would have defined the given theta values as the center of each sector, but it was easy enough to fix by giving an offset to my data before passing it to the program. However, if you do this the spokes are also off (requiring a similar offset to be passed to the program to fix). It might be nice to have an option to set whether to plot centered on the theta data or the current default. Anyway, great work!
Hei James, sorry for the late answer. I have updated the function and included an option to change the radial tick label as you asked. You can see an example where I change the radial label in the live script file.
@E. Cheynet, thanks. Is there a simple way to add labels, i.e. one for each "circle"?
@James, yes it is possible to change the colormap. If you want to use the colormap 'autumn' for example, just write colormap('autumn'). If you want to reverse it, use: colormap(flipud(colormap('autumn')))
Great function. Is it possible to change the color mapping? I am being asked to use a map similar to a temperature weather map where the high temperatures are red.
Now the tool is working flawlessly!!! Many thanks for all help ! The new improved tool is now very complete, easy to use and professional.
All the best,
I uploaded a simple code and the data in the following link:
Is it possible that you send me in PM (using the link in my FileExchange profile) a simple example where polarPcolor fails ? Thank!
I still got the same problem. I think there is still an issue on the rNorm definition.
I have seen I had written unproperly the normalization of the R axis when the radial axis is written in a logarithmic format. Now it should work better. Thank again for the feedback!
Many thanks for such a quick reply. What if the RData do not start from values close to 0? what's happening here is that my Rdata starts from 0.13, so the grid it's being drawn shifted upwards and the pcolor is being drawn from the origin.
I have updated the function with an option to transform the radial direction from a linear scale to a logarithmic one (See Example.mlx). So far it seems it is working. Do not hesitate to contact me if you find any bug.
Do you have any thoughts on how to draw the circles in a semilog fashion ? I really appreciate any help on this issue.
Many thanks for the reply, Cheynet ! Your tool is really nice and has been very useful for me :)
I have solved the first problem using log10(R), as you said.Then I convert the values back to linear scale in Lines 182 and 196 so it shows the original input labelR values (and not in log values) when plotted. I guess this solves the second problem as I don't need to change the ticks anymore.
Now, the semilog-plot like grid issue has been a nightmare that I could not solve so far. It would be very nice to add a functionality to plot the data like a semilog-plot, specially if we could change the ticks and values to be showed on the grid.
Thank for the feedback!
Regarding your first question, you can have the radial axis in semilog if you use log(R) instead of R. However, the grid is not displayed as for a semilog-plot, so that is something to improve in this function. Regarding your second question, I had not implemented the possibility to change the Ticks for the different circles. It can be done by adding a new option in the inputParser object that is at the beginning of the function. I will try to update the function in a near future.
Very usefull tool !!! Is it possible to change the Ticks showed by 'circles' using command lines ? many thanks
Is it possible to have the RAxis in log scale ? like in a semilogx plot ?
Works like a charm, thank you very much.
It's strange that this is not a standard function inside matlab.
To create your NxN matrix for the variable Z, you can use the Matlab function "griddata":
Alternatively, you can try to use a scatter plot instead of a pseudo-color plot, as shown below:
hey, really nice piece of work. I have a question particular to my query for your code. I have a 1xN matrice for R and theta. and corresponding 1xN for the Z values. And the cell values in R and theta are not repeating, so I cant really make the Z as NxN matrice with the R and theta having the common values. It was difficult figuring how I could modify your code to suit my requirement. Could you help me out?
This link has an excel sheet with my data points. It would help you understand my question if you just have a look at it. Thanks!
Very useful! Thanks very much for the great work.
I tested on R2013b that works great and your example save my time and your code is understandable
Thank you E. Ch3yn3t !!!
It was just what I was looking for.
It is also well explained from your examples.
It works properly on R2013b.
Thank you again for your patience！
If only a small area is of interest, just "crop" your data around this area. That should also speed up the computation since you would have a matrix with a smaller size.
The matter is:
I use you function to plot a figure, for my data is too large(1126*1000), and the quantities of the nonzero data is small, which lead the figure could not display the spot unless you zoom in it.
Since the data are presented in polar coordinates, "axis(xmin,xmax,ymin,ymax)" is unlikely to be directly useful. Here, the limit of the axis are automatically calculated from R and theta. If you want to modify the axis, just change the extrema of R and theta (cf. last 2 paragraph of the html example).
Thank you for your reply!
I mean I want to know whether their is a function like axis(xmin,xmax,ymin,ymax) to control the display of the figure.
It's very kind of you that solve my problem!
Thanks for the suggestion, that is a good idea !
Are you referring to the colorbar axis ? If yes, I use the function "caxis". I have implemented today a new version where the axis is automatically scaled. In the example file, I also illustrate the role of caxis.
It's pretty good，there are 2 questions.
1st,How to adjust the axis.
2nd,Could u share the version that can adjust the axis adaptively, like image to imagesc.
See release notes for this release on GitHub: https://github.com/ECheynet/polarPcolor/releases/tag/v3.8
Added Github repository
The option "Origin" has been updated and is named now "autoOrigin"
Update of the example + more robust definition of "Rmin", which should not interact with the option "CirclesPos".
Three new options have been added:
Added project website
Updated the screenshot
Update the example file and added an option to change the radial tick label ('Rticklabel')
The bug related to the option "Rscale" has been correct (hopefully). A new option "Origin" has been added to let the user choose between a polar plot centred around 0 or min(R). The circles and spokes are now drawn as solid lines instead of dots.
Correction of a bug for the "Rscale" option
The html example is removed as the LiveScript file fulfils the same role
Added HTML example
Added LiveScript example
Added the possibility to include a log scale on the radial axis (see Example.m) + correction of a minor bug when theta and R have the same size.
Description updated with an illustration of the method applied to wind data
correction of a bug when Nspokes is lower than Ncircles/2
- automatic scaling of colorbar + new example + multiple options are added
- updated for 2014b
added html example
- picture updated
- example updated
More accurate description added