[ncl-talk] Drawing several polygons on a xy plot

Giorgio Graffino g.graffino at tim.it
Wed Mar 10 09:43:59 MST 2021


 Hi Dave,


 



 Thanks for the hint. I haven't thought about looping gsn_add_polygon over years, and setting five (!) vertices. I've managed to find a good setting (see code snippet below and attached plot). 


 



 do j = 0, nyear-1


 if (.not.ismissing(temp_amip2_tpi_year_filter(j))) then


 if (temp_amip2_tpi_year_filter(j).lt.0.) then


  plot1x(j) = gsn_add_polygon(wks,plot1g(i),(/years(j)-0.5,years(j)+0.5,years(j)+0.5,years(j)-0.5,years(j)-0.5/),(/temp_amip2_tpi_year_filter(j)-1.e2,temp_amip2_tpi_year_filter(j)-1.e2,temp_amip2_tpi_year_filter(j)+1.e2,temp_amip2_tpi_year_filter(j)+1.e2,temp_amip2_tpi_year_filter(j)-1.e2/),pg_res)


 end if


 end if


 end do


 


Cheers,Giorgio


  ----Messaggio originale---- 
 
 Da: dave.allured at noaa.gov 
 
 Data: 10-mar-2021 14.04 
 
 A: "Giorgio Graffino"<g.graffino at tim.it> 
 
 Cc: <ncl-talk at ucar.edu> 
 
 Ogg: Re: [ncl-talk] Drawing several polygons on a xy plot 
 

 

 
  
    P.S.  I just remembered you are making a panel plot.  You will probably need to increase the size of the graphics array to hold all polygons in all six panels, due to that memory requirement.  Something like this: 
  
  
   

  
  
        poly = new ( (/ nyears, npanels /), graphic) 
   

  
  
   

  
  
    There is more than one way to do this.  The array can be 1-D, 2-D, or 3-D, whatever you think is most convenient for the looping and indexing structure of your program. 
  
  
   

  
  

  
   
     On Wed, Mar 10, 2021 at 5:54 AM Dave Allured - NOAA Affiliate < 
    dave.allured at noaa.gov> wrote: 
    

   
   
    
     
      
        Gsn_add_polygon does not work like that.  It draws only a single polygon per call, and you must specify all vertices of the polygon.  Missing values can not be used to create discontinuities or unfilled areas of a polygon. 
      
      
       

      
      
        The simplest approach is to draw multiple polygons, one narrow rectangle for each year on the X axis.  Loop over years, and skip (i.e. do not draw) polygons unless the IPO index is negative.  Within the loop, remember to assign each polygon to a different element of a type graphics array, to satisfy the memory requirement of the function. 
      
      
       

      
      
            poly = new (nyear, graphic) 
      
      
            do i = 0, nyear-1 
       
        if (temp_amip2_tpi_year_filter(i) .lt. 0) then 
       
            poly(i) = gsn_add_polygon (...) 
      
      
                end if 
      
      
            end do 
      
      
       

      
      
        I leave it up to you to calculate the correct polygon vertices for each year.  Your initial code version is almost doing this already.  I recommend using a fully closed polygon for each year.  That is 5 vertices, not 4, for each rectangle.  Function behavior for non-closed polygons is undefined. 
      
      
       

      
      

      
       
         On Wed, Mar 10, 2021 at 3:20 AM Giorgio Graffino via ncl-talk < 
        ncl-talk at mailman.ucar.edu> wrote: 
        

       
       
        Short addition to this thread: I'm running NCL 6.6.2 on 
        Linux 5.4.101-1-MANJARO.
        
         

        
        
          Best, 
        
        
          Giorgio 
        
        
         
           ----Messaggio originale---- 
          
 Da: 
          ncl-talk at mailman.ucar.edu
          
 Data: 10-mar-2021 0.11 
          
 A: < 
          ncl-talk at ucar.edu> 
          
 Ogg: [ncl-talk] Drawing several polygons on a xy plot 
          

          

          Dear NCL people,
          
           

          
          
            I'm trying to draw several polygons on a time series plot, to obtain something like this ( 
           https://www.nature.com/articles/nclimate2106/figures/1). Basically, I need separate filled boxes to be drawn anywhere the IPO index is negative. I'd like to not draw individual polygons myself, because I should set the x and y ranges explicitly. (That is, at all times when the IPO index changes sign). Rather, I'd like the boxes to be drawn automatically, without knowing where the index is negative. 
          
          
           

          
          
            So far, my best attempt at the problem is to create a 1-D mask, setting all positive value of the index to missing values. Then, I'm creating one big box over the whole domain, relying on the missing values of the masked time series. The relevant snippet of my code is shown here. 
          
          
           

          
          
           
            
             ;; Create polygons where AMIP II TPI/IPO index is negative
            
            
              temp_amip2_tpi_year_filter_neg = where(temp_amip2_tpi_year_filter.lt.0.,temp_amip2_tpi_year_filter,temp_amip2_tpi_year_filter at _FillValue)
            
            
              temp_amip2_tpi_year_filter_neg_xp = new((/2*nyear/),typeof(temp_amip2_tpi_year_filter_neg),temp_amip2_tpi_year_filter_neg at _FillValue)
            
            
              temp_amip2_tpi_year_filter_neg_yp = new((/2*nyear/),typeof(temp_amip2_tpi_year_filter_neg),temp_amip2_tpi_year_filter_neg at _FillValue)
            
            
             do i = 0, nyear-1
            
            
              temp_amip2_tpi_year_filter_neg_yp(i)          = temp_amip2_tpi_year_filter_neg(i)+1.e2
            
            
              temp_amip2_tpi_year_filter_neg_xp(i)          = years(i)
            
            
              temp_amip2_tpi_year_filter_neg_xp(2*nyear-1-i) = years(i)
            
            
              temp_amip2_tpi_year_filter_neg_yp(2*nyear-1-i) = temp_amip2_tpi_year_filter_neg(i)-1.e2
            
            
             end do
            
           
          
          
           

          
          
            After, I'm calling gsn_add_polygon to draw the boxes over the time series plot, but I'm getting only one big box (see attached). It seems that the function doesn't care about missing values, and in the description that's clearly stated ("If a missing value is encountered in 
           x and/or 
           y, then this pair is ignored, but the polygon will still be closed"; 
           https://www.ncl.ucar.edu/Document/Graphics/Interfaces/gsn_add_polygon.shtml). 
          
          
           

          
          
            My question: is there a way to make gsn_add_polygon not closing the polygon? Is there a better way to draw those polygons with NCL? 
          
          
           

          
          
            Best, 
          
          
            Giorgio 
          
         
        
       
      
     
    
   
  
 
 



-------------- next part --------------
An HTML attachment was scrubbed...
URL: <https://mailman.ucar.edu/pipermail/ncl-talk/attachments/20210310/91dd8991/attachment-0001.html>
-------------- next part --------------
A non-text attachment was scrubbed...
Name: Volcano_tempeofanalysis.000001.png
Type: image/png
Size: 281009 bytes
Desc: not available
URL: <https://mailman.ucar.edu/pipermail/ncl-talk/attachments/20210310/91dd8991/attachment-0001.png>


More information about the ncl-talk mailing list