File Exchange

image thumbnail

Taylor Diagram

version 1.1 (22.4 KB) by

Plot a Taylor Diagram

3.55556
22 Ratings

62 Downloads

Updated

View License

Plot a Taylor diagram from statistics values given by STDs (standard deviations), RMSs (centered root mean square difference) and CORs (correlation)

Ref: K. Taylor
Summarizing multiple aspects of model performance in a single diagram. JGR 2001

Comments and Ratings (54)

Hi,
how can I change the RMSD values in the Taylor diagram?The greater range of 2 gives me not exact values

HI , how to set range standar deviation from 0 until reference ?

Meriem Deli

Hello,

I tried to plot with the taylordiag_test.m but I get this error

Undefined function 'taylordiag' for input arguments of type 'double'.

Error in taylordiag_test (line 77)
[pp tt axl] =
taylordiag(squeeze(statm(:,2)),squeeze(statm(:,3)),squeeze(statm(:,4)),...
 
>>
How to fix it please
many thanks

invain

invain (view profile)

The sub functions are missing

Bian

Bian (view profile)

Hi, could you please guide me to the location where you have saved ptable.m and allstat.m? Thank you very much!

Simon Lind

Kavina Dayal

Hi, could you please guide me to the location where you have saved ptable.m and allstat.m. I tried this link http://code.guillaumemaze.org/matlab
but the files are no longer there.

Annu Panwar

How to create a semicircle taylor's diagram in which Vertical radius is RMSE, The horizontal diameter of semicircle is BIAS which is positive and negative both. Correlation is positive.

Robert Waters

Kadek Nova

hello,
anyone can help me
where i can download ptable.m and allstats.m ??

Hello.
When I run the test I got this error
"Undefined function 'ptable' for input arguments of type 'double'."

Do you know how I can solve this problem?

Carlos

Carlos (view profile)

Hello

I am a new user of Matlab, however I want to do a Taylor diagram. I already have the figures of the three variables (STD,RMS and Coorrelation factor)

Could you please help me?
Joel

Rita

Rita (view profile)

Thanks I got it.

Rita

Rita (view profile)

Thanks a lot for sharing!
When I run your test I got this error
"Undefined function 'ptable' for input arguments of type 'double'."
Any advice would be appreciated

Hazel

Hazel (view profile)

Hi, thanks for the code.

I've had to normalize my statistics to the observations as I'm looking at various models with different time periods. Is there a way to edit the axis labels so that I can get it to say 'Standard deviation (normalized)' like in http://www-pcmdi.llnl.gov/about/staff/Taylor/CV/Taylor_diagram_examples.pdf? I found the warning in draw_blank_TaylorDiag.m which says do not touch!

Many thanks

Shruti

Shruti (view profile)

I am getting the following error when I run the function. Can someone suggest any solutio for this?

Error using text
Invalid parameter/value pair arguments

Error in taylordiag (line 281)
text((i+rincRMS/20)*c82+dx,(i+rincRMS/20)*s82, ...

pioneer

At last i got it! thanks to Guillaume,for the scripts.Glory to God!

pioneer

please i have tried to make Taylor diagrams for a whole week ! can some one help me.Moving from mat lab to R program.So desperate!

Jamie Wilson

Sagar

Sagar (view profile)

Hi,
I am using the function 'taylordiag' as follows:
[ hp, ht, axl ] = taylordiag ( stn { 1 } (2, : ), stn { 1 } ( 3, : ), stn { 1 } ( 4, : ) );

where stn is a 1*23 cell. I need to execute the function 'taylordiag' in each cells i.e. in stn { 1 }, stn { 2 } .... stn { 23 }, so that I can plot all the points that I need in the same plot obtained by executing 'taylordiag'.

Could you please suggest how to do this?

Thank you,

-Sagar

Xingwang

Kelly Kearney

Kelly Kearney (view profile)

Very helpful function. My only issue is that the font sizes are difficult to alter. The axis labels inherit from the original axis, but the tick labels themselves are hardcoded and their handles are hidden on creation, so one can't alter that later.

Gino

Gino (view profile)

Dear Guillaume,

Thanks for your function, it is indeed very useful. I have a little issue for plotting multiple stations in 1 graph. Let say, I have the following matrices:

STD_A =

         1.69 1.2771
       2.7889 2.393
       2.5981 2.1398
       1.5963 0.97035

RMS_A =

            0 1.1754
            0 1.8935
            0 1.9204
            0 1.1649

CORR_A =

            1 0.71945
            1 0.74311
            1 0.68721
            1 0.68843

With the Standard Deviation (STD_A), RMS (RMS_A), correlations (CORR_A) for four stations. The statistics where obtained using allstats, so:

STD_A(1,:) correspond to the standard deviations obtained via allstats for station # 1,

STD_A(2,:) correspond to the standard deviations obtained via allstats for station # 2, and so on. The same is for RMS_A and CORR_A.

When I try to plot the stations on the same plot, using different colors and markers, the axes after the first plot do not coincide, so the RMS lines and position of the points in the plot are off. I try to play with the axes but it did not work. I know a little bit of MATLAB, but I don't consider myself an expert.

I will really appreciate if you could help me out with this and suggest a way that I could plot all the stations in one plot, so when I plot them the axes from all the plots coincide. I understand that I will have 4 'Obs' point in the X axis, that's what I was trying to do and I would differentiate them by changing colors.

This is a little bit different from the example you have on your short tutorial and on taylordiag_test , because I have 4 different stations in which on each of them I'm comparing observations with model data, and not comparing just one 'Obs' time series with different reanalysis data.

Here's the code that I've being using:

STD_A=[1.69 1.2771; 2.7889 2.393;2.5981 2.1398; 1.5963 0.97035];

RMS_A = [0 1.1754; 0 1.8935;0 1.9204;0 1.1649];

CORR_A=[1 0.71945;1 0.74311;1 0.68721;1 0.68843];

% Main code for Taylor Diagram
 
% Plotting 1st Station
 
[pp tt axl]=taylordiag(STD_A(1,:),RMS_A(1,:),CORR_A(1,:),...
    'tickRMS',[0:.5:2.5],'titleRMS',0,'showlabelsRMS',1,...
    'widthRMS',1,'colRMS','r',...
    'tickSTD',[0:.25:2],'limSTD',2,'styleSTD','-',...
    'tickCOR',[.1:.1:.9 .95 .99],'showlabelsCOR',1,'titleCOR',1);
 
        
% Deals with names, colors and size of markers for 1st Station
       
for ii = 1 : length(tt)
    set(tt(ii),'fontsize',9,'fontweight','bold','color','g')
    set(pp(ii),'markersize',12,'MarkerEdgeColor','g','MarkerFaceColor','g')
    if ii == 1
        set(tt(ii),'String','Obs');
    else
        set(tt(ii),'String',alphab(ii-1));
    end
end
 
title(sprintf('Buoy vs WRF: Temperature at 2m'),'fontweight','bold',...
'fontsize',12);
 
 
% Deals with Axes of Taylor Diagram

tt = axl(2).handle;
for ii = 1 : length(tt)
    set(tt(ii),'fontsize',10,'fontweight','bold');
end
 
set(axl(1).handle,'fontweight','bold','fontsize',10);
 
 
% Get info about the current axes to use on all the other axes

nPos = get( gca, 'position' );
nAx = axis();
 
 
% Create all the other overlapping Taylor diagrams
 
[rr,jj]=size(STD_A);
 
for kk=2:rr
    
    % Create the new axes
    axes( 'position', nPos );
 
[pp tt axl]=taylordiag(squeeze(STD_A(kk,:)),squeeze(RMS_A(kk,:)),squeeze(CORR_A(kk,:)),...
    'tickRMS',[0:.5:2.5],'titleRMS',0,'showlabelsRMS',1,'widthRMS',1,'colRMS','r',...
    'tickSTD',[0:.25:2],'limSTD',2,'styleSTD','-',...
    'tickCOR',[.1:.1:.9 .95 .99],'showlabelsCOR',1,'titleCOR',1);
 
 
        
% Deals with names, colors and size of markers CMPCH
 
for ii = 1 : length(tt)
    set(tt(ii),'fontsize',9,'fontweight','bold')
    set(pp(ii),'markersize',12)
    if ii == 1
        set(tt(ii),'String','Obs');
    else
        set(tt(ii),'String',alphab(ii-1));
    end
    
end
        
% Deals with names, colors and size of markers CMPCH
 
for ii = 1 : length(tt)
    set(tt(ii),'fontsize',9,'fontweight','bold','color','m')
    set(pp(ii),'markersize',12,'MarkerEdgeColor','k','MarkerFaceColor','k')
    if ii == 1
        set(tt(ii),'String','Obs');
    else
        set(tt(ii),'String',alphab(ii-1));
    end
end
 
% set the first axes show through & line up the axis limits
    set( gca, 'visible', 'off' );
    axis( gca, nAx );
 
end

Thank you very much and any suggestion will be greatly appreciate.

Best Regards,

Gino

Sarah

Sarah (view profile)

I have the same problem as what ulas im described in May.
Thank you.

kouekk

kouekk (view profile)

Hi, I want to know to do a Taylor diagram

Am a new user of matlab

ulas im

Hello

I am trying to use your code to plot a taylor diagram for the below matrix that contains the observations on the first row and 2 sets of models in the other rows:

63.6218 18.6781 0 1.0000
68.3743 19.1750 18.2357 0.5283 50.4187 17.7198 16.2621 0.8528 33.6676 12.4900 32.3996 0.7256
However i am getting the following error:

Error using taylordiag (line 110) taylordiag.m : Something's wrong with data indice(s): 2? You must have: RMSs - sqrt(STDs.2 + STDs(1)2 - 2*STDs*STDs(1).CORs) = 0 !taylordiag.m : Something's wrong with data indice(s): 3? You must have: RMSs - sqrt(STDs.2 + STDs(1)2 - 2*STDs*STDs(1).CORs) = 0 !taylordiag.m : Something's wrong with data indice(s): 4? You must have: RMSs - sqrt(STDs.2 + STDs(1)2 - 2*STDs*STDs(1).CORs) = 0 !

can you help me on this please

thank you

Josh

Josh (view profile)

This is a great function. However I am experiencing the same issue as Lang (above). I can get the function to work with my model output, but it seems to only plot the std and corr. The RMSE lines appear on the diagram, but does not relate...Does anyone else agree and perhaps have an answer?

Aisling

This is a brilliant function. However, I am struggling to get the correlation lines eminating from the origin to plot when the correlation is negative (the points plot perfectly). Is there a way of doing this? Thanks.

Ming Chen

Hi all, I can plot the diagram with only positive correlations. However, when I tried to plot both positive and negative correlations (Npan=2) with the same data, I got this error message:
??? Error using ==> set
Value must be numeric.

Error in ==> xlabel at 43
  set(h, 'FontAngle', get(ax, 'FontAngle'), ...

Error in ==> xlabel at 22
  h = xlabel(gca,varargin{:});

Error in ==> taylordiag at 399
ax(ix).handle =xlabel('Standard deviation','fontweight',axlabweight,...

Error in ==> All_3_years at 601
[hp ht axl] = taylordiag(STD_G21_08,RMS_G21_08,COR_G21_08,'Npan',2,'tickSTD',(0:0.25:1.5));

Is there anybody who has the same problem?

Lang

Lang (view profile)

I could plot using example data sets. But there is no information of rmsd on plot other than some green lines. Whether the rmsd intervals label on the plot?

Ming Chen

This is very handy! Thanks to Guillaume MAZE!

ww

ww (view profile)

I cant get the example to even work.. I have the latest allstats..

>> statm(:,2)
??? Index exceeds matrix dimensions.

ww

ww (view profile)

Benrique

aMAZEing. Thanks heaps.

museum

museum (view profile)

It succeed now, thanks MAZE!

museum

museum (view profile)

Sorry, MAZE, I meet the same problem with jenny, and I found the generated 'Statm' matrix is 5x1, not 5x4....The matlab version I used is 7.0

Q.

Q. (view profile)

http://code.google.com/p/guillaumemaze/wiki/matlab_routines_ptable
http://code.google.com/p/guillaumemaze/wiki/matlab_routines_allstats

Page "matlab_routines_allstats" Not Found

So, you move to another places? why not put the test data here?

Thanks.

Guillaume MAZE

Guillaume MAZE (view profile)

To Jenny and others having the same problem,
If you get the error message about: "Something's wrong with the datas", this is because the statistics are wrong and trigonometric relations are wrong as well, see my comment from Jul.28th.
If you also have an error message running the test script, I can't figure out why it would be. The 'statm' matrix should be 5x4. I tried this test on many different platforms, removing all my custom path, etc. and it always works fine. The only reason why you would have an error and I can think about is that somewhere in your path a function overwrites something done in the script which makes it to behave not as expected.
So, please be sure you have the correct test datas and routines. To run the test you'll also need these two functions:
http://code.google.com/p/guillaumemaze/wiki/matlab_routines_ptable
http://code.google.com/p/guillaumemaze/wiki/matlab_routines_allstats

i am getting the same problem as jenny????
Any one know how to solve this?????

Prashant

Georgina

Guillaume MAZE

Guillaume MAZE (view profile)

The whole idea of a Taylor diagram is the triangulation of a point given statistical properties it represents in a trigonometric context. A point needs only 2 parameters to be placed in the 2D diagram but we have 3 parameters which can be used. RMSd is therefore not used to plot the point but statistics/trigonometry requirements are checked and require RMSd.

Carlos

Carlos (view profile)

Hi, I noted that the script doesn't use the RMSd value for drawing the lines or placing the dots. What's wrong with it?

Hi, Can anybody let me know where I can get the subroutine allstats, I tried to get this from here: http://code.google.com/p/guillaumemaze/source/browse/#svn/trunk/matlab/routines

but doesnt work.
Thanks.
Robert.

I agree with Jenny

Jenny

Jenny (view profile)

Hi Ben!

You can get the ptable script here:
http://code.google.com/p/guillaumemaze/wiki/matlab_routines_ptable

However, I still can't get the script to work. not with my own data and not with the example.

With my own data I get something like this:
??? Error using ==> taylordiag at 85
taylordiag.m : Something's wrong with the datas

With the example the error message is:
??? Index exceeds matrix dimensions.

Error in ==> taylordiag_test at 77
[pp tt axl] =
taylordiag(squeeze(statm(:,2)),squeeze(statm(:,3)),squeeze(statm(:,4)),...

Does anyone know what is wrong?
I think I've misunderstood something about what input to give the script...

Cheers!

Ben

Ben (view profile)

Thank you for the nice script and the examples.
I just have one question. What kind of function is the 'ptable' in the example: ax = ptable([2 3],[2 2;4 6]);
Thanks
Cheers Ben

Guillaume MAZE

Guillaume MAZE (view profile)

You'll find bellow links to .mat file with datas you can use to test the routine, and with the scripts I used myself to plot these datas (they are daily time series of sea surface net heat flux at a mooring in the North Atlantic, and results from numerical models to compare with)

hope this will be helpful
cheers
guillaume

.mat file is here: http://guillaumemaze.googlecode.com/svn/trunk/matlab/routines/taylordiag_egdata.mat
the example is here: http://guillaumemaze.googlecode.com/svn/trunk/matlab/routines/taylordiag_test.m

ps: I use the subroutine allstats in this peace of code to make things easier, you can get it here:
http://code.google.com/p/guillaumemaze/source/browse/#svn/trunk/matlab/routines

Damian Brady

I agree with Georgina!

Georgina

Does anyone have an example of the inputs required for this script. I am having trouble with it.
I get "Something''s wrong with the datas"
I think it is because I don't understand what is supposed to be in the 1st row of of each of the arrays.

C Schwalm

I had started to code this up myself, now I don't have to... These plots are wonderful for diagnostics and comparing numerous models. Well done.

Pierre Hubertin Andrianirina

Updates

1.1

I made the help, well, more helpful regarding all the comments ! I also added a complete example in the zip file.

MATLAB Release
MATLAB 7.5 (R2007b)
Acknowledgements

Inspired: PeterRochford/SkillMetricsToolbox

Download apps, toolboxes, and other File Exchange content using Add-On Explorer in MATLAB.

» Watch video