gphys 1.1.1 → 1.2.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- data/.gitignore +17 -0
- data/ChangeLog +221 -0
- data/Gemfile +4 -0
- data/LICENSE.txt +18 -30
- data/README +23 -26
- data/README.md +29 -0
- data/Rakefile +1 -56
- data/bin/gpaop +2 -1
- data/bin/gpcut +3 -2
- data/bin/gpedit +6 -2
- data/bin/gpmath +3 -2
- data/bin/gpmaxmin +3 -2
- data/bin/gpprint +2 -1
- data/bin/gpvect +28 -5
- data/bin/gpview +43 -5
- data/extconf.rb +5 -6
- data/gphys.gemspec +34 -0
- data/interpo.c +63 -24
- data/lib/gphys.rb +2 -0
- data/lib/numru/dclext.rb +2636 -0
- data/lib/numru/derivative.rb +53 -12
- data/lib/numru/ganalysis/eof.rb +4 -0
- data/lib/numru/ganalysis/histogram.rb +73 -5
- data/lib/numru/ganalysis/met.rb +163 -2
- data/lib/numru/ganalysis/planet.rb +230 -20
- data/lib/numru/ggraph.rb +147 -2247
- data/lib/numru/gphys/assoccoords.rb +19 -3
- data/lib/numru/gphys/axis.rb +1 -1
- data/lib/numru/gphys/coordmapping.rb +2 -2
- data/lib/numru/gphys/derivative.rb +56 -13
- data/lib/numru/gphys/gphys.rb +17 -1
- data/lib/numru/gphys/gphys_grads_io.rb +6 -5
- data/lib/numru/gphys/gphys_grib_io.rb +6 -6
- data/lib/numru/gphys/gphys_io.rb +25 -6
- data/lib/numru/gphys/grads_gridded.rb +31 -29
- data/lib/numru/gphys/grib.rb +13 -9
- data/lib/numru/gphys/interpolate.rb +153 -29
- data/lib/numru/gphys/unumeric.rb +29 -6
- data/lib/numru/gphys/varray.rb +9 -0
- data/lib/numru/gphys/varraygrib.rb +70 -8
- data/lib/version.rb +3 -0
- metadata +247 -531
- data/doc/attribute.html +0 -19
- data/doc/attributenetcdf.html +0 -15
- data/doc/axis.html +0 -376
- data/doc/coordmapping.html +0 -111
- data/doc/coordtransform.html +0 -36
- data/doc/derivative/gphys-derivative.html +0 -80
- data/doc/derivative/index.html +0 -21
- data/doc/derivative/index.rd +0 -14
- data/doc/derivative/math-doc/document/document.css +0 -30
- data/doc/derivative/math-doc/document/document.html +0 -57
- data/doc/derivative/math-doc/document/images.aux +0 -1
- data/doc/derivative/math-doc/document/images.log +0 -385
- data/doc/derivative/math-doc/document/images.pl +0 -186
- data/doc/derivative/math-doc/document/images.tex +0 -364
- data/doc/derivative/math-doc/document/img1.png +0 -0
- data/doc/derivative/math-doc/document/img10.png +0 -0
- data/doc/derivative/math-doc/document/img11.png +0 -0
- data/doc/derivative/math-doc/document/img12.png +0 -0
- data/doc/derivative/math-doc/document/img13.png +0 -0
- data/doc/derivative/math-doc/document/img14.png +0 -0
- data/doc/derivative/math-doc/document/img15.png +0 -0
- data/doc/derivative/math-doc/document/img16.png +0 -0
- data/doc/derivative/math-doc/document/img17.png +0 -0
- data/doc/derivative/math-doc/document/img18.png +0 -0
- data/doc/derivative/math-doc/document/img19.png +0 -0
- data/doc/derivative/math-doc/document/img2.png +0 -0
- data/doc/derivative/math-doc/document/img20.png +0 -0
- data/doc/derivative/math-doc/document/img21.png +0 -0
- data/doc/derivative/math-doc/document/img22.png +0 -0
- data/doc/derivative/math-doc/document/img23.png +0 -0
- data/doc/derivative/math-doc/document/img24.png +0 -0
- data/doc/derivative/math-doc/document/img25.png +0 -0
- data/doc/derivative/math-doc/document/img26.png +0 -0
- data/doc/derivative/math-doc/document/img27.png +0 -0
- data/doc/derivative/math-doc/document/img28.png +0 -0
- data/doc/derivative/math-doc/document/img29.png +0 -0
- data/doc/derivative/math-doc/document/img3.png +0 -0
- data/doc/derivative/math-doc/document/img30.png +0 -0
- data/doc/derivative/math-doc/document/img4.png +0 -0
- data/doc/derivative/math-doc/document/img5.png +0 -0
- data/doc/derivative/math-doc/document/img6.png +0 -0
- data/doc/derivative/math-doc/document/img7.png +0 -0
- data/doc/derivative/math-doc/document/img8.png +0 -0
- data/doc/derivative/math-doc/document/img9.png +0 -0
- data/doc/derivative/math-doc/document/index.html +0 -57
- data/doc/derivative/math-doc/document/labels.pl +0 -13
- data/doc/derivative/math-doc/document/next.png +0 -0
- data/doc/derivative/math-doc/document/next_g.png +0 -0
- data/doc/derivative/math-doc/document/node1.html +0 -238
- data/doc/derivative/math-doc/document/node2.html +0 -75
- data/doc/derivative/math-doc/document/prev.png +0 -0
- data/doc/derivative/math-doc/document/prev_g.png +0 -0
- data/doc/derivative/math-doc/document/up.png +0 -0
- data/doc/derivative/math-doc/document/up_g.png +0 -0
- data/doc/derivative/math-doc/document.pdf +0 -0
- data/doc/derivative/math-doc/document.tex +0 -158
- data/doc/derivative/numru-derivative.html +0 -129
- data/doc/ep_flux/ep_flux.html +0 -469
- data/doc/ep_flux/ggraph_on_merdional_section.html +0 -71
- data/doc/ep_flux/index.html +0 -31
- data/doc/ep_flux/index.rd +0 -24
- data/doc/ep_flux/math-doc/document/WARNINGS +0 -1
- data/doc/ep_flux/math-doc/document/contents.png +0 -0
- data/doc/ep_flux/math-doc/document/crossref.png +0 -0
- data/doc/ep_flux/math-doc/document/document.css +0 -30
- data/doc/ep_flux/math-doc/document/document.html +0 -101
- data/doc/ep_flux/math-doc/document/images.aux +0 -1
- data/doc/ep_flux/math-doc/document/images.log +0 -1375
- data/doc/ep_flux/math-doc/document/images.pl +0 -1328
- data/doc/ep_flux/math-doc/document/images.tex +0 -1471
- data/doc/ep_flux/math-doc/document/img1.png +0 -0
- data/doc/ep_flux/math-doc/document/img10.png +0 -0
- data/doc/ep_flux/math-doc/document/img100.png +0 -0
- data/doc/ep_flux/math-doc/document/img101.png +0 -0
- data/doc/ep_flux/math-doc/document/img102.png +0 -0
- data/doc/ep_flux/math-doc/document/img103.png +0 -0
- data/doc/ep_flux/math-doc/document/img104.png +0 -0
- data/doc/ep_flux/math-doc/document/img105.png +0 -0
- data/doc/ep_flux/math-doc/document/img106.png +0 -0
- data/doc/ep_flux/math-doc/document/img107.png +0 -0
- data/doc/ep_flux/math-doc/document/img108.png +0 -0
- data/doc/ep_flux/math-doc/document/img109.png +0 -0
- data/doc/ep_flux/math-doc/document/img11.png +0 -0
- data/doc/ep_flux/math-doc/document/img110.png +0 -0
- data/doc/ep_flux/math-doc/document/img111.png +0 -0
- data/doc/ep_flux/math-doc/document/img112.png +0 -0
- data/doc/ep_flux/math-doc/document/img113.png +0 -0
- data/doc/ep_flux/math-doc/document/img114.png +0 -0
- data/doc/ep_flux/math-doc/document/img115.png +0 -0
- data/doc/ep_flux/math-doc/document/img116.png +0 -0
- data/doc/ep_flux/math-doc/document/img117.png +0 -0
- data/doc/ep_flux/math-doc/document/img118.png +0 -0
- data/doc/ep_flux/math-doc/document/img119.png +0 -0
- data/doc/ep_flux/math-doc/document/img12.png +0 -0
- data/doc/ep_flux/math-doc/document/img120.png +0 -0
- data/doc/ep_flux/math-doc/document/img121.png +0 -0
- data/doc/ep_flux/math-doc/document/img122.png +0 -0
- data/doc/ep_flux/math-doc/document/img123.png +0 -0
- data/doc/ep_flux/math-doc/document/img124.png +0 -0
- data/doc/ep_flux/math-doc/document/img125.png +0 -0
- data/doc/ep_flux/math-doc/document/img126.png +0 -0
- data/doc/ep_flux/math-doc/document/img127.png +0 -0
- data/doc/ep_flux/math-doc/document/img128.png +0 -0
- data/doc/ep_flux/math-doc/document/img129.png +0 -0
- data/doc/ep_flux/math-doc/document/img13.png +0 -0
- data/doc/ep_flux/math-doc/document/img130.png +0 -0
- data/doc/ep_flux/math-doc/document/img131.png +0 -0
- data/doc/ep_flux/math-doc/document/img132.png +0 -0
- data/doc/ep_flux/math-doc/document/img133.png +0 -0
- data/doc/ep_flux/math-doc/document/img134.png +0 -0
- data/doc/ep_flux/math-doc/document/img135.png +0 -0
- data/doc/ep_flux/math-doc/document/img136.png +0 -0
- data/doc/ep_flux/math-doc/document/img137.png +0 -0
- data/doc/ep_flux/math-doc/document/img138.png +0 -0
- data/doc/ep_flux/math-doc/document/img139.png +0 -0
- data/doc/ep_flux/math-doc/document/img14.png +0 -0
- data/doc/ep_flux/math-doc/document/img140.png +0 -0
- data/doc/ep_flux/math-doc/document/img141.png +0 -0
- data/doc/ep_flux/math-doc/document/img142.png +0 -0
- data/doc/ep_flux/math-doc/document/img143.png +0 -0
- data/doc/ep_flux/math-doc/document/img144.png +0 -0
- data/doc/ep_flux/math-doc/document/img145.png +0 -0
- data/doc/ep_flux/math-doc/document/img146.png +0 -0
- data/doc/ep_flux/math-doc/document/img147.png +0 -0
- data/doc/ep_flux/math-doc/document/img148.png +0 -0
- data/doc/ep_flux/math-doc/document/img149.png +0 -0
- data/doc/ep_flux/math-doc/document/img15.png +0 -0
- data/doc/ep_flux/math-doc/document/img150.png +0 -0
- data/doc/ep_flux/math-doc/document/img151.png +0 -0
- data/doc/ep_flux/math-doc/document/img152.png +0 -0
- data/doc/ep_flux/math-doc/document/img153.png +0 -0
- data/doc/ep_flux/math-doc/document/img154.png +0 -0
- data/doc/ep_flux/math-doc/document/img155.png +0 -0
- data/doc/ep_flux/math-doc/document/img156.png +0 -0
- data/doc/ep_flux/math-doc/document/img157.png +0 -0
- data/doc/ep_flux/math-doc/document/img158.png +0 -0
- data/doc/ep_flux/math-doc/document/img159.png +0 -0
- data/doc/ep_flux/math-doc/document/img16.png +0 -0
- data/doc/ep_flux/math-doc/document/img160.png +0 -0
- data/doc/ep_flux/math-doc/document/img161.png +0 -0
- data/doc/ep_flux/math-doc/document/img162.png +0 -0
- data/doc/ep_flux/math-doc/document/img163.png +0 -0
- data/doc/ep_flux/math-doc/document/img164.png +0 -0
- data/doc/ep_flux/math-doc/document/img165.png +0 -0
- data/doc/ep_flux/math-doc/document/img166.png +0 -0
- data/doc/ep_flux/math-doc/document/img167.png +0 -0
- data/doc/ep_flux/math-doc/document/img168.png +0 -0
- data/doc/ep_flux/math-doc/document/img169.png +0 -0
- data/doc/ep_flux/math-doc/document/img17.png +0 -0
- data/doc/ep_flux/math-doc/document/img170.png +0 -0
- data/doc/ep_flux/math-doc/document/img171.png +0 -0
- data/doc/ep_flux/math-doc/document/img172.png +0 -0
- data/doc/ep_flux/math-doc/document/img173.png +0 -0
- data/doc/ep_flux/math-doc/document/img174.png +0 -0
- data/doc/ep_flux/math-doc/document/img175.png +0 -0
- data/doc/ep_flux/math-doc/document/img176.png +0 -0
- data/doc/ep_flux/math-doc/document/img177.png +0 -0
- data/doc/ep_flux/math-doc/document/img178.png +0 -0
- data/doc/ep_flux/math-doc/document/img179.png +0 -0
- data/doc/ep_flux/math-doc/document/img18.png +0 -0
- data/doc/ep_flux/math-doc/document/img180.png +0 -0
- data/doc/ep_flux/math-doc/document/img181.png +0 -0
- data/doc/ep_flux/math-doc/document/img182.png +0 -0
- data/doc/ep_flux/math-doc/document/img183.png +0 -0
- data/doc/ep_flux/math-doc/document/img184.png +0 -0
- data/doc/ep_flux/math-doc/document/img185.png +0 -0
- data/doc/ep_flux/math-doc/document/img186.png +0 -0
- data/doc/ep_flux/math-doc/document/img187.png +0 -0
- data/doc/ep_flux/math-doc/document/img188.png +0 -0
- data/doc/ep_flux/math-doc/document/img189.png +0 -0
- data/doc/ep_flux/math-doc/document/img19.png +0 -0
- data/doc/ep_flux/math-doc/document/img190.png +0 -0
- data/doc/ep_flux/math-doc/document/img191.png +0 -0
- data/doc/ep_flux/math-doc/document/img192.png +0 -0
- data/doc/ep_flux/math-doc/document/img193.png +0 -0
- data/doc/ep_flux/math-doc/document/img194.png +0 -0
- data/doc/ep_flux/math-doc/document/img195.png +0 -0
- data/doc/ep_flux/math-doc/document/img196.png +0 -0
- data/doc/ep_flux/math-doc/document/img197.png +0 -0
- data/doc/ep_flux/math-doc/document/img198.png +0 -0
- data/doc/ep_flux/math-doc/document/img199.png +0 -0
- data/doc/ep_flux/math-doc/document/img2.png +0 -0
- data/doc/ep_flux/math-doc/document/img20.png +0 -0
- data/doc/ep_flux/math-doc/document/img200.png +0 -0
- data/doc/ep_flux/math-doc/document/img21.png +0 -0
- data/doc/ep_flux/math-doc/document/img22.png +0 -0
- data/doc/ep_flux/math-doc/document/img23.png +0 -0
- data/doc/ep_flux/math-doc/document/img24.png +0 -0
- data/doc/ep_flux/math-doc/document/img25.png +0 -0
- data/doc/ep_flux/math-doc/document/img26.png +0 -0
- data/doc/ep_flux/math-doc/document/img27.png +0 -0
- data/doc/ep_flux/math-doc/document/img28.png +0 -0
- data/doc/ep_flux/math-doc/document/img29.png +0 -0
- data/doc/ep_flux/math-doc/document/img3.png +0 -0
- data/doc/ep_flux/math-doc/document/img30.png +0 -0
- data/doc/ep_flux/math-doc/document/img31.png +0 -0
- data/doc/ep_flux/math-doc/document/img32.png +0 -0
- data/doc/ep_flux/math-doc/document/img33.png +0 -0
- data/doc/ep_flux/math-doc/document/img34.png +0 -0
- data/doc/ep_flux/math-doc/document/img35.png +0 -0
- data/doc/ep_flux/math-doc/document/img36.png +0 -0
- data/doc/ep_flux/math-doc/document/img37.png +0 -0
- data/doc/ep_flux/math-doc/document/img38.png +0 -0
- data/doc/ep_flux/math-doc/document/img39.png +0 -0
- data/doc/ep_flux/math-doc/document/img4.png +0 -0
- data/doc/ep_flux/math-doc/document/img40.png +0 -0
- data/doc/ep_flux/math-doc/document/img41.png +0 -0
- data/doc/ep_flux/math-doc/document/img42.png +0 -0
- data/doc/ep_flux/math-doc/document/img43.png +0 -0
- data/doc/ep_flux/math-doc/document/img44.png +0 -0
- data/doc/ep_flux/math-doc/document/img45.png +0 -0
- data/doc/ep_flux/math-doc/document/img46.png +0 -0
- data/doc/ep_flux/math-doc/document/img47.png +0 -0
- data/doc/ep_flux/math-doc/document/img48.png +0 -0
- data/doc/ep_flux/math-doc/document/img49.png +0 -0
- data/doc/ep_flux/math-doc/document/img5.png +0 -0
- data/doc/ep_flux/math-doc/document/img50.png +0 -0
- data/doc/ep_flux/math-doc/document/img51.png +0 -0
- data/doc/ep_flux/math-doc/document/img52.png +0 -0
- data/doc/ep_flux/math-doc/document/img53.png +0 -0
- data/doc/ep_flux/math-doc/document/img54.png +0 -0
- data/doc/ep_flux/math-doc/document/img55.png +0 -0
- data/doc/ep_flux/math-doc/document/img56.png +0 -0
- data/doc/ep_flux/math-doc/document/img57.png +0 -0
- data/doc/ep_flux/math-doc/document/img58.png +0 -0
- data/doc/ep_flux/math-doc/document/img59.png +0 -0
- data/doc/ep_flux/math-doc/document/img6.png +0 -0
- data/doc/ep_flux/math-doc/document/img60.png +0 -0
- data/doc/ep_flux/math-doc/document/img61.png +0 -0
- data/doc/ep_flux/math-doc/document/img62.png +0 -0
- data/doc/ep_flux/math-doc/document/img63.png +0 -0
- data/doc/ep_flux/math-doc/document/img64.png +0 -0
- data/doc/ep_flux/math-doc/document/img65.png +0 -0
- data/doc/ep_flux/math-doc/document/img66.png +0 -0
- data/doc/ep_flux/math-doc/document/img67.png +0 -0
- data/doc/ep_flux/math-doc/document/img68.png +0 -0
- data/doc/ep_flux/math-doc/document/img69.png +0 -0
- data/doc/ep_flux/math-doc/document/img7.png +0 -0
- data/doc/ep_flux/math-doc/document/img70.png +0 -0
- data/doc/ep_flux/math-doc/document/img71.png +0 -0
- data/doc/ep_flux/math-doc/document/img72.png +0 -0
- data/doc/ep_flux/math-doc/document/img73.png +0 -0
- data/doc/ep_flux/math-doc/document/img74.png +0 -0
- data/doc/ep_flux/math-doc/document/img75.png +0 -0
- data/doc/ep_flux/math-doc/document/img76.png +0 -0
- data/doc/ep_flux/math-doc/document/img77.png +0 -0
- data/doc/ep_flux/math-doc/document/img78.png +0 -0
- data/doc/ep_flux/math-doc/document/img79.png +0 -0
- data/doc/ep_flux/math-doc/document/img8.png +0 -0
- data/doc/ep_flux/math-doc/document/img80.png +0 -0
- data/doc/ep_flux/math-doc/document/img81.png +0 -0
- data/doc/ep_flux/math-doc/document/img82.png +0 -0
- data/doc/ep_flux/math-doc/document/img83.png +0 -0
- data/doc/ep_flux/math-doc/document/img84.png +0 -0
- data/doc/ep_flux/math-doc/document/img85.png +0 -0
- data/doc/ep_flux/math-doc/document/img86.png +0 -0
- data/doc/ep_flux/math-doc/document/img87.png +0 -0
- data/doc/ep_flux/math-doc/document/img88.png +0 -0
- data/doc/ep_flux/math-doc/document/img89.png +0 -0
- data/doc/ep_flux/math-doc/document/img9.png +0 -0
- data/doc/ep_flux/math-doc/document/img90.png +0 -0
- data/doc/ep_flux/math-doc/document/img91.png +0 -0
- data/doc/ep_flux/math-doc/document/img92.png +0 -0
- data/doc/ep_flux/math-doc/document/img93.png +0 -0
- data/doc/ep_flux/math-doc/document/img94.png +0 -0
- data/doc/ep_flux/math-doc/document/img95.png +0 -0
- data/doc/ep_flux/math-doc/document/img96.png +0 -0
- data/doc/ep_flux/math-doc/document/img97.png +0 -0
- data/doc/ep_flux/math-doc/document/img98.png +0 -0
- data/doc/ep_flux/math-doc/document/img99.png +0 -0
- data/doc/ep_flux/math-doc/document/index.html +0 -101
- data/doc/ep_flux/math-doc/document/internals.pl +0 -258
- data/doc/ep_flux/math-doc/document/labels.pl +0 -265
- data/doc/ep_flux/math-doc/document/next.png +0 -0
- data/doc/ep_flux/math-doc/document/next_g.png +0 -0
- data/doc/ep_flux/math-doc/document/node1.html +0 -104
- data/doc/ep_flux/math-doc/document/node10.html +0 -164
- data/doc/ep_flux/math-doc/document/node11.html +0 -86
- data/doc/ep_flux/math-doc/document/node12.html +0 -166
- data/doc/ep_flux/math-doc/document/node13.html +0 -897
- data/doc/ep_flux/math-doc/document/node14.html +0 -1065
- data/doc/ep_flux/math-doc/document/node15.html +0 -72
- data/doc/ep_flux/math-doc/document/node16.html +0 -81
- data/doc/ep_flux/math-doc/document/node2.html +0 -82
- data/doc/ep_flux/math-doc/document/node3.html +0 -91
- data/doc/ep_flux/math-doc/document/node4.html +0 -149
- data/doc/ep_flux/math-doc/document/node5.html +0 -330
- data/doc/ep_flux/math-doc/document/node6.html +0 -99
- data/doc/ep_flux/math-doc/document/node7.html +0 -98
- data/doc/ep_flux/math-doc/document/node8.html +0 -83
- data/doc/ep_flux/math-doc/document/node9.html +0 -140
- data/doc/ep_flux/math-doc/document/prev.png +0 -0
- data/doc/ep_flux/math-doc/document/prev_g.png +0 -0
- data/doc/ep_flux/math-doc/document/up.png +0 -0
- data/doc/ep_flux/math-doc/document/up_g.png +0 -0
- data/doc/ep_flux/math-doc/document.pdf +0 -0
- data/doc/ep_flux/math-doc/document.tex +0 -2018
- data/doc/gdir.html +0 -412
- data/doc/gdir_client.html +0 -16
- data/doc/gdir_connect_ftp-like.html +0 -61
- data/doc/gdir_server.html +0 -45
- data/doc/ggraph.html +0 -1615
- data/doc/gpcat.html +0 -44
- data/doc/gpcut.html +0 -41
- data/doc/gphys.html +0 -532
- data/doc/gphys_fft.html +0 -324
- data/doc/gphys_grads_io.html +0 -69
- data/doc/gphys_grib_io.html +0 -82
- data/doc/gphys_io.html +0 -120
- data/doc/gphys_io_common.html +0 -18
- data/doc/gphys_netcdf_io.html +0 -283
- data/doc/gplist.html +0 -24
- data/doc/gpmath.html +0 -51
- data/doc/gpmaxmin.html +0 -31
- data/doc/gpprint.html +0 -34
- data/doc/gpview.html +0 -270
- data/doc/grads2nc_with_gphys.html +0 -21
- data/doc/grads_gridded.html +0 -307
- data/doc/grib.html +0 -144
- data/doc/grid.html +0 -212
- data/doc/index.html +0 -133
- data/doc/index.rd +0 -127
- data/doc/netcdf_convention.html +0 -136
- data/doc/unumeric.html +0 -176
- data/doc/update +0 -64
- data/doc/varray.html +0 -299
- data/doc/varraycomposite.html +0 -67
    
        data/lib/numru/dclext.rb
    ADDED
    
    | @@ -0,0 +1,2636 @@ | |
| 1 | 
            +
            require "numru/dcl"
         | 
| 2 | 
            +
            require "numru/misc"
         | 
| 3 | 
            +
            require "numru/dclext_datetime_ax"
         | 
| 4 | 
            +
            require "narray_miss"
         | 
| 5 | 
            +
             | 
| 6 | 
            +
            ############################################################
         | 
| 7 | 
            +
             | 
| 8 | 
            +
            =begin
         | 
| 9 | 
            +
            =module NumRu::DCLExt
         | 
| 10 | 
            +
             | 
| 11 | 
            +
            An extension of RubyDCL.
         | 
| 12 | 
            +
             | 
| 13 | 
            +
            ==Index
         | 
| 14 | 
            +
             | 
| 15 | 
            +
            Original methods
         | 
| 16 | 
            +
              * ((<lon_ax>))
         | 
| 17 | 
            +
                Draw longitude axis. (label format: degrees + 'E' or 'W')
         | 
| 18 | 
            +
              * ((<lat_ax>))
         | 
| 19 | 
            +
                Draw latitude axis. (label format: degrees + 'N' or 'S')
         | 
| 20 | 
            +
              * ((<unit_vect>)) Show the "unit vector", which indicate the vector scaling.
         | 
| 21 | 
            +
              * ((<unit_vect_single>)) Draw a unit vector (only one arrow is drawn).
         | 
| 22 | 
            +
              * ((<set_unit_vect_options>))
         | 
| 23 | 
            +
                Change the default option values for ((<unit_vect>)).
         | 
| 24 | 
            +
              * ((<next_unit_vect_options>))
         | 
| 25 | 
            +
                Set the option values effective only in the next call of ((<unit_vect>))
         | 
| 26 | 
            +
              * ((<flow_vect>)) 2D Vector plot. Unlike (({DCL::ugvect})), scaling are made in term of the physical (or "U") coordinate.
         | 
| 27 | 
            +
              * ((<flow_vect_anyproj>)) flow_vect available in any coordinate projections
         | 
| 28 | 
            +
              * ((<flow_itr5>)) 2D Vector plot on the 2-dim polar coodinate.
         | 
| 29 | 
            +
              * ((<color_bar>)) Color Bar
         | 
| 30 | 
            +
              * ((<set_color_bar_options>))
         | 
| 31 | 
            +
              * ((<legend>)) 
         | 
| 32 | 
            +
                Annotates line/mark type and index (and size if mark).
         | 
| 33 | 
            +
              * ((<quasi_log_levels_z>)) 
         | 
| 34 | 
            +
                Driver of quasi_log_levels with data values
         | 
| 35 | 
            +
              * ((<quasi_log_levels>)) 
         | 
| 36 | 
            +
                Returns approximately log-scaled contour/tone levels.
         | 
| 37 | 
            +
             | 
| 38 | 
            +
            MATH1
         | 
| 39 | 
            +
            * ((<glpack>))
         | 
| 40 | 
            +
              * ((<gl_set_params>))
         | 
| 41 | 
            +
                Calls (({DCL.glpset})) multiple times (for each key and val of (({hash}))).
         | 
| 42 | 
            +
            GRPH1
         | 
| 43 | 
            +
            * ((<sgpack>))
         | 
| 44 | 
            +
              * ((<sg_set_params>))
         | 
| 45 | 
            +
                Calls (({DCL.sgpset})) multiple times (for each key and val of (({hash}))).
         | 
| 46 | 
            +
            * ((<slpack>))
         | 
| 47 | 
            +
              * ((<sl_set_params>))
         | 
| 48 | 
            +
                Calls (({DCL.slpset})) multiple times (for each key and val of (({hash}))).
         | 
| 49 | 
            +
            * ((<swpack>))
         | 
| 50 | 
            +
              * ((<sw_set_params>))
         | 
| 51 | 
            +
                Calls (({DCL.swpset})) multiple times (for each key and val of (({hash}))).
         | 
| 52 | 
            +
            GRPH2
         | 
| 53 | 
            +
            * ((<uzpack>))
         | 
| 54 | 
            +
              * ((<uz_set_params>))
         | 
| 55 | 
            +
                Calls (({DCL.uzpset})) multiple times (for each key and val of (({hash}))).
         | 
| 56 | 
            +
            * ((<ulpack>))
         | 
| 57 | 
            +
              * ((<ul_set_params>))
         | 
| 58 | 
            +
                Calls (({DCL.ulpset})) multiple times (for each key and val of (({hash}))).
         | 
| 59 | 
            +
            * ((<ucpack>))
         | 
| 60 | 
            +
              * ((<uc_set_params>))
         | 
| 61 | 
            +
                Calls (({DCL.ucpset})) multiple times (for each key and val of (({hash}))).
         | 
| 62 | 
            +
            * ((<uupack>))
         | 
| 63 | 
            +
              * ((<uu_set_params>))
         | 
| 64 | 
            +
                Calls (({DCL.uupset})) multiple times (for each key and val of (({hash}))).
         | 
| 65 | 
            +
            * ((<uspack>))
         | 
| 66 | 
            +
              * ((<us_set_params>))
         | 
| 67 | 
            +
                Calls (({DCL.uspset})) multiple times (for each key and val of (({hash}))).
         | 
| 68 | 
            +
            * ((<udpack>))
         | 
| 69 | 
            +
              * ((<ud_set_params>))
         | 
| 70 | 
            +
                Calls (({DCL.udpset})) multiple times (for each key and val of (({hash}))).
         | 
| 71 | 
            +
              * ((<ud_set_linear_levs>))
         | 
| 72 | 
            +
                Set contour levels with a constant interval
         | 
| 73 | 
            +
              * ((<ud_set_contour>))
         | 
| 74 | 
            +
                Set contours of at specified levels.
         | 
| 75 | 
            +
              * ((<ud_add_contour>))
         | 
| 76 | 
            +
                Same as ((<ud_set_contour>)), but does not clear the contour levels that have
         | 
| 77 | 
            +
                been set.
         | 
| 78 | 
            +
            * ((<uepack>))
         | 
| 79 | 
            +
              * ((<ue_set_params>))
         | 
| 80 | 
            +
                Calls (({DCL.uepset})) multiple times (for each key and val of (({hash}))).
         | 
| 81 | 
            +
              * ((<ue_set_linear_levs>))
         | 
| 82 | 
            +
                Set tone levels with a constant interval
         | 
| 83 | 
            +
              * ((<ue_set_tone>))
         | 
| 84 | 
            +
                Set tone levels and patterns.
         | 
| 85 | 
            +
              * ((<ue_add_tone>))
         | 
| 86 | 
            +
                Same as ((<ue_set_tone>)), but does not clear the tone levels that have
         | 
| 87 | 
            +
                been set.
         | 
| 88 | 
            +
            * ((<ugpack>))
         | 
| 89 | 
            +
              * ((<ug_set_params>))
         | 
| 90 | 
            +
                Calls (({DCL.ugpset})) multiple times (for each key and val of (({hash}))).
         | 
| 91 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 92 | 
            +
            * ((<umpack>))
         | 
| 93 | 
            +
              * ((<um_set_params>))
         | 
| 94 | 
            +
                Calls (({DCL.umpset})) multiple times (for each key and val of (({hash}))).
         | 
| 95 | 
            +
             | 
| 96 | 
            +
             | 
| 97 | 
            +
             | 
| 98 | 
            +
            ==Module Functions
         | 
| 99 | 
            +
             | 
| 100 | 
            +
            ===glpack
         | 
| 101 | 
            +
            ---gl_set_params(hash)
         | 
| 102 | 
            +
                Calls (({DCL.glpset})) multiple times (for each key and val of (({hash}))).
         | 
| 103 | 
            +
             | 
| 104 | 
            +
                ARGUMENTS
         | 
| 105 | 
            +
                * hash (Hash) : combinations of parameter names and values for udpset
         | 
| 106 | 
            +
             | 
| 107 | 
            +
                RETURN VALUE
         | 
| 108 | 
            +
                * a Hash containing the parameter names and their old values that were
         | 
| 109 | 
            +
                  replaced.
         | 
| 110 | 
            +
             | 
| 111 | 
            +
                EXAMPLES
         | 
| 112 | 
            +
                * You can modify parameters temporarily as follows.
         | 
| 113 | 
            +
             | 
| 114 | 
            +
                    before = DCLExt.gl_set_params({'lmiss'=>true,'rmiss'=>9999.0})
         | 
| 115 | 
            +
                    ....
         | 
| 116 | 
            +
                    DCLExt.gl_set_params(before)     # reset the change
         | 
| 117 | 
            +
             | 
| 118 | 
            +
            ===sgpack
         | 
| 119 | 
            +
            ---sg_set_params(hash)
         | 
| 120 | 
            +
                Calls (({DCL.sgpset})) multiple times (for each key and val of (({hash}))).
         | 
| 121 | 
            +
             | 
| 122 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 123 | 
            +
             | 
| 124 | 
            +
            ===slpack
         | 
| 125 | 
            +
            ---sl_set_params(hash)
         | 
| 126 | 
            +
                Calls (({DCL.slpset})) multiple times (for each key and val of (({hash}))).
         | 
| 127 | 
            +
             | 
| 128 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 129 | 
            +
             | 
| 130 | 
            +
            ===swpack
         | 
| 131 | 
            +
            ---sw_set_params(hash)
         | 
| 132 | 
            +
                Calls (({DCL.swpset})) multiple times (for each key and val of (({hash}))).
         | 
| 133 | 
            +
             | 
| 134 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 135 | 
            +
             | 
| 136 | 
            +
            ===uzpack
         | 
| 137 | 
            +
            ---uz_set_params(hash)
         | 
| 138 | 
            +
                Calls (({DCL.uzpset})) multiple times (for each key and val of (({hash}))).
         | 
| 139 | 
            +
             | 
| 140 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 141 | 
            +
             | 
| 142 | 
            +
            ===ulpack
         | 
| 143 | 
            +
            ---ul_set_params(hash)
         | 
| 144 | 
            +
                Calls (({DCL.ulpset})) multiple times (for each key and val of (({hash}))).
         | 
| 145 | 
            +
             | 
| 146 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 147 | 
            +
             | 
| 148 | 
            +
            ===ucpack
         | 
| 149 | 
            +
            ---uc_set_params(hash)
         | 
| 150 | 
            +
                Calls (({DCL.ucpset})) multiple times (for each key and val of (({hash}))).
         | 
| 151 | 
            +
             | 
| 152 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 153 | 
            +
             | 
| 154 | 
            +
            ===uupack
         | 
| 155 | 
            +
            ---uu_set_params(hash)
         | 
| 156 | 
            +
                Calls (({DCL.uupset})) multiple times (for each key and val of (({hash}))).
         | 
| 157 | 
            +
             | 
| 158 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 159 | 
            +
             | 
| 160 | 
            +
            ===uspack
         | 
| 161 | 
            +
            ---us_set_params(hash)
         | 
| 162 | 
            +
                Calls (({DCL.uspset})) multiple times (for each key and val of (({hash}))).
         | 
| 163 | 
            +
             | 
| 164 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 165 | 
            +
             | 
| 166 | 
            +
            ===udpack
         | 
| 167 | 
            +
            ---ud_set_params(hash)
         | 
| 168 | 
            +
                Calls (({DCL.udpset})) multiple times (for each key and val of (({hash}))).
         | 
| 169 | 
            +
             | 
| 170 | 
            +
                ARGUMENTS
         | 
| 171 | 
            +
                * hash (Hash) : combinations of parameter names and values for udpset
         | 
| 172 | 
            +
             | 
| 173 | 
            +
                RETURN VALUE
         | 
| 174 | 
            +
                * a Hash containing the parameter names and their old values that were
         | 
| 175 | 
            +
                  replaced.
         | 
| 176 | 
            +
             | 
| 177 | 
            +
                EXAMPLES
         | 
| 178 | 
            +
                * You can modify parameters temporarily as follows.
         | 
| 179 | 
            +
             | 
| 180 | 
            +
                    before = DCLExt.ud_set_params('indxmj'=>4,'lmsg'=>false)
         | 
| 181 | 
            +
                    DCL.udcntz(data)
         | 
| 182 | 
            +
                    DCLExt.ud_set_params(before)     # reset the change
         | 
| 183 | 
            +
             | 
| 184 | 
            +
            ---ud_set_linear_levs(v, options)
         | 
| 185 | 
            +
                Set contour levels with a constant interval
         | 
| 186 | 
            +
             | 
| 187 | 
            +
                ARGUMENTS
         | 
| 188 | 
            +
                * v : Data values to be fed to udcnt[rz]
         | 
| 189 | 
            +
                * options (Hash) : option specification by keys and values. Available
         | 
| 190 | 
            +
                  options are
         | 
| 191 | 
            +
                      name   default value   description
         | 
| 192 | 
            +
                      'min'      nil       minimum contour value (Numeric)
         | 
| 193 | 
            +
                      'max'      nil       maximum contour value (Numeric)
         | 
| 194 | 
            +
                      'nlev'     nil       number of levels (Integer)
         | 
| 195 | 
            +
                      'interval' nil       contour interval (Numeric)
         | 
| 196 | 
            +
                      'nozero'   nil       delete zero contour (true/false)
         | 
| 197 | 
            +
                      'coloring' false     set color contours with ud_coloring (true/false)
         | 
| 198 | 
            +
                      'clr_min'  13        (if coloring) minimum color id (Integer)
         | 
| 199 | 
            +
                      'clr_max'  99       (if coloring) maximum color id (Integer)
         | 
| 200 | 
            +
                  Here, (({interval})) has a higher precedence over (({nlev})).
         | 
| 201 | 
            +
                  Since all the default values are nil, only those explicitly specified
         | 
| 202 | 
            +
                  are interpreted. If no option is provided, the levels generated will
         | 
| 203 | 
            +
                  be the default ones set by udcnt[rz] without any level specification.
         | 
| 204 | 
            +
             | 
| 205 | 
            +
            ---ud_set_contour(levels,index=nil,line_type=nil,label=nil,label_height=nil)
         | 
| 206 | 
            +
                Set contours of at specified levels.
         | 
| 207 | 
            +
             | 
| 208 | 
            +
                Normally you do not have to specify (({label})) and (({label_height})).
         | 
| 209 | 
            +
             | 
| 210 | 
            +
                It calls DCL.udsclv for each level. So the arguments are basically
         | 
| 211 | 
            +
                the same as DCL.udsclv, but only levels are mandatory here.
         | 
| 212 | 
            +
             | 
| 213 | 
            +
                ARGUMENTS
         | 
| 214 | 
            +
                * levels (Array, NArray, or Numeric) : contour levels to be set.
         | 
| 215 | 
            +
                  If Numeric, a single level is set.
         | 
| 216 | 
            +
                * index (Array of integers, Integer, or nil) :
         | 
| 217 | 
            +
                  index(es) of the contours. If it is an Array and its length is
         | 
| 218 | 
            +
                  shorter than that of (({levels})), the same Array is repeated (so
         | 
| 219 | 
            +
                  for instance [1,1,3] is interpreted as [1,1,3,1,1,3,1,1,3,...]).
         | 
| 220 | 
            +
                  If it is a single Integer, all the contour will have the same index.
         | 
| 221 | 
            +
                 If nil, the value of 'indxmn' is used.
         | 
| 222 | 
            +
                * line_type (Array of integers, Integer, or nil) :
         | 
| 223 | 
            +
                  line type(s) of the contours. If it is an Array and its length is
         | 
| 224 | 
            +
                  shorter than that of (({levels})), the same Array is repeated.
         | 
| 225 | 
            +
                  the length must agree with that of (({levels})).
         | 
| 226 | 
            +
                  If it is a single Integer, all the contour will have the same type.
         | 
| 227 | 
            +
                  If nil, set to be 1.
         | 
| 228 | 
            +
                * label (Array of String, String, true, false, nil) :
         | 
| 229 | 
            +
                  Label(s) of the contours. If it is an Array and its length is
         | 
| 230 | 
            +
                  shorter than that of (({levels})), the same Array is repeated.
         | 
| 231 | 
            +
                  the length must agree with that of (({levels})).
         | 
| 232 | 
            +
                  If  it is a single String, all the contour will have the same label.
         | 
| 233 | 
            +
                  If true, all the contours will have the labels representing the levels.
         | 
| 234 | 
            +
                  If false, no label will be drawn (set to "").
         | 
| 235 | 
            +
                  If nil, same as true for the contours whose index is equal to "INDXMJ",
         | 
| 236 | 
            +
                  and same as false otherwise.
         | 
| 237 | 
            +
                * label_height (Array of Numeric, Numeric, or nil) :
         | 
| 238 | 
            +
                  Heigh of Labels. Normally you do not have to use this.
         | 
| 239 | 
            +
                  If it is an Array and its length is
         | 
| 240 | 
            +
                  shorter than that of (({levels})), the same Array is repeated.
         | 
| 241 | 
            +
                  If nil, the default value ("RSIZEL") is used for non-empty labels.
         | 
| 242 | 
            +
                  If a single Numeric, the same value is used for all the contours.
         | 
| 243 | 
            +
                  Note that it is recommended to not to use this parameter but
         | 
| 244 | 
            +
                  use DCL.udpset('RZISEL'. label_height), since a positive value
         | 
| 245 | 
            +
                  here always means to draw labels even when the label is empty.
         | 
| 246 | 
            +
             | 
| 247 | 
            +
                RETURN VALUE
         | 
| 248 | 
            +
                * nil
         | 
| 249 | 
            +
             | 
| 250 | 
            +
            ---ud_add_contour(levels,index=nil,line_type=nil,label=nil,label_height=nil)
         | 
| 251 | 
            +
                Same as ((<ud_set_contour>)), but does not clear the contour levels that have
         | 
| 252 | 
            +
                been set.
         | 
| 253 | 
            +
             | 
| 254 | 
            +
            ===uepack
         | 
| 255 | 
            +
            ---ue_set_params(hash)
         | 
| 256 | 
            +
                Calls (({DCL.uepset})) multiple times (for each key and val of (({hash}))).
         | 
| 257 | 
            +
             | 
| 258 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 259 | 
            +
             | 
| 260 | 
            +
            ---ue_set_linear_levs(v, options)
         | 
| 261 | 
            +
                Set tone levels with a constant interval
         | 
| 262 | 
            +
             | 
| 263 | 
            +
                ARGUMENTS
         | 
| 264 | 
            +
                * v : Data values to be fed to udcnt[rz]
         | 
| 265 | 
            +
                * options (Hash) : option specification by keys and values. Available
         | 
| 266 | 
            +
                  options are
         | 
| 267 | 
            +
                      name   default value   description
         | 
| 268 | 
            +
                      'min'      nil         minimum tone level (Numeric)
         | 
| 269 | 
            +
                      'max'      nil         maximum tone level (Numeric)
         | 
| 270 | 
            +
                      'nlev'     nil         number of levels (Integer)
         | 
| 271 | 
            +
                      'interval' nil         tone-level interval (Numeric)
         | 
| 272 | 
            +
                  Here, (({interval})) has a higher precedence over (({nlev})).
         | 
| 273 | 
            +
                  Since all the default values are nil, only those explicitly specified
         | 
| 274 | 
            +
                  are interpreted. If no option is provided, the levels generated will
         | 
| 275 | 
            +
                  be the default ones set by udcnt[rz] without any level specification.
         | 
| 276 | 
            +
             | 
| 277 | 
            +
            ---ue_set_tone(levels, patterns)
         | 
| 278 | 
            +
                Set tone levels and patterns.
         | 
| 279 | 
            +
             | 
| 280 | 
            +
                patterns are set between levels as follows:
         | 
| 281 | 
            +
             | 
| 282 | 
            +
                 when (levels.length == patterns.length+1)
         | 
| 283 | 
            +
             | 
| 284 | 
            +
                   levels[0]  |  levels[1]  |  levels[2]  ...  |  levels[-2]  |  levels[-1]
         | 
| 285 | 
            +
                          patterns[0]   patterns[1]   ...  patterns[-2]   patterns[-1]
         | 
| 286 | 
            +
             | 
| 287 | 
            +
                 when (levels.length == patterns.length)
         | 
| 288 | 
            +
             | 
| 289 | 
            +
                   levels[0]  |  levels[1]  |  levels[2]  ...  |  levels[-1]  |  +infty
         | 
| 290 | 
            +
                          patterns[0]   patterns[1]   ...  patterns[-2]   patterns[-1]
         | 
| 291 | 
            +
             | 
| 292 | 
            +
                 when (levels.length == patterns.length-1)
         | 
| 293 | 
            +
             | 
| 294 | 
            +
                   -infty  |  levels[0]  |  levels[1]  ...  |  levels[-1]  |  +infty
         | 
| 295 | 
            +
                       patterns[0]   patterns[1]   ...  patterns[-2]   patterns[-1]
         | 
| 296 | 
            +
             | 
| 297 | 
            +
                 else
         | 
| 298 | 
            +
                   error (exception raised)
         | 
| 299 | 
            +
             | 
| 300 | 
            +
                ARGUMENTS
         | 
| 301 | 
            +
                * levels (Array or NArray of Numeric) : tone levels. Its length must be
         | 
| 302 | 
            +
                  either 1 larger than, equal to, or 1 smaller than the length of patterns
         | 
| 303 | 
            +
                * patterns (Array or NArray of Numeric) : tone patterns
         | 
| 304 | 
            +
             | 
| 305 | 
            +
                RETURN VALUE
         | 
| 306 | 
            +
                * nil
         | 
| 307 | 
            +
             | 
| 308 | 
            +
            ---ue_add_tone(levels, patterns)
         | 
| 309 | 
            +
                Same as ((<ue_set_tone>)), but does not clear the tone levels that have
         | 
| 310 | 
            +
                been set.
         | 
| 311 | 
            +
             | 
| 312 | 
            +
            ===ugpack
         | 
| 313 | 
            +
            ---ug_set_params(hash)
         | 
| 314 | 
            +
                Calls (({DCL.ugpset})) multiple times (for each key and val of (({hash}))).
         | 
| 315 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 316 | 
            +
             | 
| 317 | 
            +
            ===umpack
         | 
| 318 | 
            +
            ---um_set_params(hash)
         | 
| 319 | 
            +
                Calls (({DCL.umpset})) multiple times (for each key and val of (({hash}))).
         | 
| 320 | 
            +
             | 
| 321 | 
            +
                See ((<gl_set_params>)) for usage.
         | 
| 322 | 
            +
             | 
| 323 | 
            +
            ==Original methods:
         | 
| 324 | 
            +
             | 
| 325 | 
            +
            ===Longitude/Latitude Axes
         | 
| 326 | 
            +
            ---lon_ax( options=nil )
         | 
| 327 | 
            +
             | 
| 328 | 
            +
                Draw longitude axis. (label format: degrees + 'E' or 'W')
         | 
| 329 | 
            +
             | 
| 330 | 
            +
                ARGUMENTS
         | 
| 331 | 
            +
                * options (Hash) : options to change the default behavior if specified.
         | 
| 332 | 
            +
                  It is a Hash with option names (String) as keys and their values.
         | 
| 333 | 
            +
                  Options are interpreted by a NumRu::Misc::KeywordOptAutoHelp,
         | 
| 334 | 
            +
                  so you can shorten the keys (by omitting tails) as long as it is
         | 
| 335 | 
            +
                  unambiguous.
         | 
| 336 | 
            +
                   option name   default value   # description:
         | 
| 337 | 
            +
                   "yax"         false   # true => draw y-axis, false => draw x-axis
         | 
| 338 | 
            +
                   "cside"       nil     # "b", "t", "l", "r",
         | 
| 339 | 
            +
                                         # nil (=>left/bottom), or false (=>right/top)
         | 
| 340 | 
            +
                   "dtick1"      nil     # Interval of small tickmark
         | 
| 341 | 
            +
                                         #             (if nil, internally determined)
         | 
| 342 | 
            +
                   "dtick2"      nil     # Interval of large tickmark with labels
         | 
| 343 | 
            +
                                         #             (if nil, internally determined)
         | 
| 344 | 
            +
             | 
| 345 | 
            +
            ---lat_ax( options=nil )
         | 
| 346 | 
            +
             | 
| 347 | 
            +
                Draw latitude axis. (label format: degrees + 'N' or 'S')
         | 
| 348 | 
            +
             | 
| 349 | 
            +
                ARGUMENTS
         | 
| 350 | 
            +
                * options (Hash) : options to change the default behavior if specified.
         | 
| 351 | 
            +
                  It is a Hash with option names (String) as keys and their values.
         | 
| 352 | 
            +
                  Options are interpreted by a NumRu::Misc::KeywordOptAutoHelp,
         | 
| 353 | 
            +
                  so you can shorten the keys (by omitting tails) as long as it is
         | 
| 354 | 
            +
                  unambiguous.
         | 
| 355 | 
            +
                   option name   default value   # description:
         | 
| 356 | 
            +
                   "xax"         false   # true => draw x-axis, false => draw y-axis
         | 
| 357 | 
            +
                   "cside"       nil     # "b", "t", "l", "r",
         | 
| 358 | 
            +
                                         # nil (=>left/bottom), or false (=>right/top)
         | 
| 359 | 
            +
                   "dtick1"      nil     # Interval of small tickmark
         | 
| 360 | 
            +
                                         #             (if nil, internally determined)
         | 
| 361 | 
            +
                   "dtick2"      nil     # Interval of large tickmark with labels
         | 
| 362 | 
            +
                                         #             (if nil, internally determined)
         | 
| 363 | 
            +
             | 
| 364 | 
            +
            ===Vectors
         | 
| 365 | 
            +
            ---unit_vect( vxfxratio, vyfyratio, fxunit=nil, fyunit=nil, options=nil )
         | 
| 366 | 
            +
             | 
| 367 | 
            +
                Show the "unit vector", which indicate the vector scaling.
         | 
| 368 | 
            +
             | 
| 369 | 
            +
                ARGUMENTS
         | 
| 370 | 
            +
                * vxfxratio (Float) : (V cood length)/(actual length) in x
         | 
| 371 | 
            +
                * vyfyratio (Float) : (V cood length)/(actual length) in y
         | 
| 372 | 
            +
                * fxunit (Float) : If specified, x unit vect len
         | 
| 373 | 
            +
                * fyunit (Float) : If specified, y unit vect len
         | 
| 374 | 
            +
                * options (Hash) : options to change the default behavior if specified.
         | 
| 375 | 
            +
                  It is a Hash with option names (String) as keys and their values.
         | 
| 376 | 
            +
                  Options are interpreted by a NumRu::Misc::KeywordOptAutoHelp,
         | 
| 377 | 
            +
                  so you can shorten the keys (by omitting tails) as long as it is
         | 
| 378 | 
            +
                  unambiguous.
         | 
| 379 | 
            +
                   option name   default value   # description:
         | 
| 380 | 
            +
                   "vxunit"      0.05    # x unit vect len in V coord. Used only when
         | 
| 381 | 
            +
                                         # fxunit is omitted (default)
         | 
| 382 | 
            +
                   "vyunit"      0.05    # y unit vect len in V coord. Used only when
         | 
| 383 | 
            +
                                         # fyunit is omitted (default)
         | 
| 384 | 
            +
                   "vxuloc"      nil     # Starting x position of unit vect
         | 
| 385 | 
            +
                   "vyuloc"      nil     # Starting y position of unit vect
         | 
| 386 | 
            +
                   "vxuoff"      0.05    # Specify vxuloc by offset from right-bottom
         | 
| 387 | 
            +
                                         # corner
         | 
| 388 | 
            +
                   "vyuoff"      0.0     # Specify vyuloc by offset from right-bottom
         | 
| 389 | 
            +
                                         # corner
         | 
| 390 | 
            +
                   "inplace"     true    # Whether to print labels right by the unit
         | 
| 391 | 
            +
                                         # vector (true) or below the x axis (false)
         | 
| 392 | 
            +
                   "rsizet"      nil     # Label size(default taken from uz-parameter
         | 
| 393 | 
            +
                                         # 'rsizel1')
         | 
| 394 | 
            +
                   "index"       3       #  Line index of the unit vector
         | 
| 395 | 
            +
                   "help"        false   # show help message if true
         | 
| 396 | 
            +
                   "vertical"    true    # (used only in unit_vect_single) the unit vector
         | 
| 397 | 
            +
                                         # is directed upward if true, to the right if not.
         | 
| 398 | 
            +
             | 
| 399 | 
            +
            ---unit_vect_single(vfratio, flen, options=nil )
         | 
| 400 | 
            +
                Draw a unit vector (only one arrow is drawn). Suitable to called after ((<flow_vect_anyproj>)).
         | 
| 401 | 
            +
             | 
| 402 | 
            +
                ARGUMENTS
         | 
| 403 | 
            +
                * vfratio (Numeric) : see ((<flow_vect_anyproj>)).
         | 
| 404 | 
            +
                * flen (Numeric) : length of the unit vector
         | 
| 405 | 
            +
                * options (Hash) : see ((<unit_vect>)).
         | 
| 406 | 
            +
             | 
| 407 | 
            +
            ---set_unit_vect_options(options)
         | 
| 408 | 
            +
                Change the default option values for ((<unit_vect>)).
         | 
| 409 | 
            +
             | 
| 410 | 
            +
            ---next_unit_vect_options(options)
         | 
| 411 | 
            +
                Set the option values effective only in the next call of ((<unit_vect>))
         | 
| 412 | 
            +
             | 
| 413 | 
            +
            ---flow_vect( fx, fy, factor=1.0, xintv=1, yintv=1)
         | 
| 414 | 
            +
             | 
| 415 | 
            +
                2D Vector plot. Unlike (({DCL::ugvect})), scaling are made in term of the physical (or "U") coordinate.
         | 
| 416 | 
            +
             | 
| 417 | 
            +
                This method is meant to substitute (({DCL::ugvect})). The scaling
         | 
| 418 | 
            +
                is made in terms of the U coordinate. This method is suitable to
         | 
| 419 | 
            +
                show vectors such as velocity, since the arrow direction represets
         | 
| 420 | 
            +
                the direction in the U coordinate. Also, one can re-scale the
         | 
| 421 | 
            +
                vector length easily by using the argument (({factor})).
         | 
| 422 | 
            +
             | 
| 423 | 
            +
                Currently, this method is not compatible with map projection,
         | 
| 424 | 
            +
                since it calls (({DCL::ugvect})) internally.
         | 
| 425 | 
            +
             | 
| 426 | 
            +
                ARGUMENTS
         | 
| 427 | 
            +
                * fx, fy (2D NArray or Array) : the vector field.
         | 
| 428 | 
            +
                * factor (Integer) : factor to change the arrow length.
         | 
| 429 | 
            +
                  By default, arrows are scaled so that the longest one
         | 
| 430 | 
            +
                  match the grid interval.
         | 
| 431 | 
            +
                * xintv, yintv (Interger) : interval to thin out (({fx})) and (({fy})),
         | 
| 432 | 
            +
                  respectively. Useful if the grid points are too many.
         | 
| 433 | 
            +
             | 
| 434 | 
            +
            ---flow_vect_anyproj(fx, fy, xg, yg, factor=1.0, xintv=1, yintv=1, distvect_map=true, vfratio=nil)
         | 
| 435 | 
            +
             | 
| 436 | 
            +
                flow_vect that can be used under any of the projections supported by DCL.
         | 
| 437 | 
            +
                Arrows drawn by this method have lengths proportional to sqrt(fx**2+fy**2),
         | 
| 438 | 
            +
                and their directions are properly directed locally (consistent with the
         | 
| 439 | 
            +
                local coordinate). A special treatment
         | 
| 440 | 
            +
                is made for map projections if distvect_map==true (see below). Singular 
         | 
| 441 | 
            +
                points of the projection is heuristically handled (see the source code
         | 
| 442 | 
            +
                for details).
         | 
| 443 | 
            +
             | 
| 444 | 
            +
                ARGUMENTS
         | 
| 445 | 
            +
                * fx, fy [2D NArray or NArrayMiss] : the vector field.
         | 
| 446 | 
            +
                * xg, yg [1D (or 2D) NArray] : the grid points
         | 
| 447 | 
            +
                * factor (Integer) : factor to change the arrow length.
         | 
| 448 | 
            +
                  By default, arrows are scaled so that the longest one
         | 
| 449 | 
            +
                  matches the typical grid interval.
         | 
| 450 | 
            +
                * xintv, yintv (Integer) : interval to thin out (({fx})) and (({fy})),
         | 
| 451 | 
            +
                  respectively. Useful if the grid points are too many.
         | 
| 452 | 
            +
                * distvect_map [true/false] : (effective only for map projections)
         | 
| 453 | 
            +
                  by default (true) it is assumed that the vector (fx,fy) is based 
         | 
| 454 | 
            +
                  on lengths (such as wind velocities in m/s,
         | 
| 455 | 
            +
                  and fluxes in which wind velocities are incorporated [q*u, q*v]);
         | 
| 456 | 
            +
                  set it to false if the vector is based on angles
         | 
| 457 | 
            +
                  (such as the time derivatives of longitude and latitude).
         | 
| 458 | 
            +
                  When true, a directional correction is made to match the scaling of
         | 
| 459 | 
            +
                  DCL's window, which is based on angles (longitude and latitude).
         | 
| 460 | 
            +
                * vfratio [nil or Numeric] : if Numeric, specifies the ratio
         | 
| 461 | 
            +
                  between the lengths of vectors in the V coordinate and the actual
         | 
| 462 | 
            +
                  length (sqrt(fx**2+fy**2)). Good to unify the scaling over multiple
         | 
| 463 | 
            +
                  plots
         | 
| 464 | 
            +
             | 
| 465 | 
            +
                RETURN VALUE
         | 
| 466 | 
            +
                * [ vfratio, flenmax ] : 
         | 
| 467 | 
            +
                 * vfratio : see above
         | 
| 468 | 
            +
                 * flenmax : maximum of sqrt(fx**2+fy**2)
         | 
| 469 | 
            +
             | 
| 470 | 
            +
            ---flow_itr5( fx, fy, factor=1.0, unit_vect=false )
         | 
| 471 | 
            +
             | 
| 472 | 
            +
                2D Vector plot on the polar coodinate.
         | 
| 473 | 
            +
             | 
| 474 | 
            +
                This method just perform rotatation of the vector in U-coordinate
         | 
| 475 | 
            +
                to N-coordinate and passed to DCL.ugvect.
         | 
| 476 | 
            +
             | 
| 477 | 
            +
                ARGUMENTS
         | 
| 478 | 
            +
                * fx, fy (2D GPhys) : the vector field.
         | 
| 479 | 
            +
                * factor (Integer)  : factor for scaling in ugvect. When it equals 1,
         | 
| 480 | 
            +
                  vector field will be scaled in DCL.ugvect automatically.
         | 
| 481 | 
            +
                * unit_vect()       : Show the unit vector
         | 
| 482 | 
            +
             | 
| 483 | 
            +
            ===Color bars
         | 
| 484 | 
            +
            ---set_color_bar_options(options)
         | 
| 485 | 
            +
                To set options of ((<color_bar>)) effective in the rest.
         | 
| 486 | 
            +
             | 
| 487 | 
            +
            ---color_bar(options=nil)
         | 
| 488 | 
            +
                * Descroption:
         | 
| 489 | 
            +
                  Draws color bars
         | 
| 490 | 
            +
             | 
| 491 | 
            +
                * Example
         | 
| 492 | 
            +
                  Here is the simplest case, where no argument is given to color_bar.
         | 
| 493 | 
            +
             | 
| 494 | 
            +
                    DCL.uetone(hoge)
         | 
| 495 | 
            +
                    DCL.usdaxs
         | 
| 496 | 
            +
                    ...
         | 
| 497 | 
            +
                    DCL.color_bar
         | 
| 498 | 
            +
             | 
| 499 | 
            +
                  This draws a color bar by using the levels and tone patterns(colors)
         | 
| 500 | 
            +
                  set previously. There are many parameters you can set manually,
         | 
| 501 | 
            +
                  as introduced below:
         | 
| 502 | 
            +
             | 
| 503 | 
            +
                * Description of options
         | 
| 504 | 
            +
                   option name   default value   # description:
         | 
| 505 | 
            +
                   "levels"      nil     # tone levels (if omitted, latest ones are used)
         | 
| 506 | 
            +
                   "patterns"    nil     # tone patterns (~colors) (if omitted, latest
         | 
| 507 | 
            +
                                         # ones are used)
         | 
| 508 | 
            +
                   "voff"        nil     # how far is the bar from the viewport in the V
         | 
| 509 | 
            +
                                         # coordinate
         | 
| 510 | 
            +
                   "vcent"       nil     # center position of the bar in the V coordinate
         | 
| 511 | 
            +
                                         # (VX or VY)
         | 
| 512 | 
            +
                   "vlength"     0.3     # bar length in the V coordinate
         | 
| 513 | 
            +
                   "vwidth"      0.02    # bar width in the V coordinate
         | 
| 514 | 
            +
                   "inffact"     2.25    # factor to change the length of triangle on the
         | 
| 515 | 
            +
                                         # side for infinity (relative to 'vwidth')
         | 
| 516 | 
            +
                   "landscape"   false   # if true, horizonlly long (along x axes)
         | 
| 517 | 
            +
                   "portrait"    true    # if true, vertically long (along y axes)
         | 
| 518 | 
            +
                   "top"         false   # place the bar at the top (effective if
         | 
| 519 | 
            +
                                         # landscape)
         | 
| 520 | 
            +
                   "left"        false   # place the bar in the left (effective if
         | 
| 521 | 
            +
                                         # portrait)
         | 
| 522 | 
            +
                   "units"       nil     # units of the axis of the color bar
         | 
| 523 | 
            +
                   "units_voff"  0.0     # offset value for units from the default position
         | 
| 524 | 
            +
                                         # in the V coordinate (only for 'units' != nil)
         | 
| 525 | 
            +
                   "title"       nil     # title of the color bar
         | 
| 526 | 
            +
                   "title_voff"  0.0     # offset value for title from the default position
         | 
| 527 | 
            +
                                         # in the V coordinate (only for 'title' != nil)
         | 
| 528 | 
            +
                   "tickintv"    1       # 0,1,2,3,.. to specify how frequently the
         | 
| 529 | 
            +
                                         # dividing tick lines are drawn (0: no tick lines,
         | 
| 530 | 
            +
                                         # 1: every time, 2: ever other:,...)
         | 
| 531 | 
            +
                   "labelintv"   nil     # 0,1,2,3,.. to specify how frequently labels are
         | 
| 532 | 
            +
                                         # drawn (0: no labels, 1: every time, 2: ever
         | 
| 533 | 
            +
                                         # other:,... default: internally determined)
         | 
| 534 | 
            +
                   "labels_ud"   nil     # user-defined labels for replacing the default
         | 
| 535 | 
            +
                                         # labels (Array of String)
         | 
| 536 | 
            +
                   "charfact"    0.9     # factor to change the label/units/title character
         | 
| 537 | 
            +
                                         # size (relative to 'rsizel1')
         | 
| 538 | 
            +
                   "log"         false   # set the color bar scale to logarithmic
         | 
| 539 | 
            +
                   "constwidth"  false   # if true, each color is drawn with the same width
         | 
| 540 | 
            +
                   "index"       nil     # line index of tick lines and bar frame
         | 
| 541 | 
            +
                   "charindex"   nil     # line index of labels, units, and title
         | 
| 542 | 
            +
                   "chval_fmt"   nil     # string to specify the DCL.chval format for
         | 
| 543 | 
            +
                                         # labeling
         | 
| 544 | 
            +
                   "help"        false   # show help message if true
         | 
| 545 | 
            +
             | 
| 546 | 
            +
            ===Others
         | 
| 547 | 
            +
            ---legend(str, type, index, line=false, size=nil, vx=nil, dx=nil, vy=nil, first=true, mark_size=nil)
         | 
| 548 | 
            +
             | 
| 549 | 
            +
            Annotates line/mark type and index (and size if mark).
         | 
| 550 | 
            +
            By default it is shown in the right margin of the viewport.
         | 
| 551 | 
            +
                
         | 
| 552 | 
            +
            * str is a String to show
         | 
| 553 | 
            +
            * line: true->line ; false->mark
         | 
| 554 | 
            +
            * vx: vx of the left-hand point of legend line (or mark position).
         | 
| 555 | 
            +
                * nil : internally determined
         | 
| 556 | 
            +
                * Float && > 0 : set explicitly
         | 
| 557 | 
            +
                * Float && < 0 : move it relatively to the left from the default
         | 
| 558 | 
            +
            * dx: length of the legend line (not used if mark).
         | 
| 559 | 
            +
                * nil : internally determined
         | 
| 560 | 
            +
                * Float && > 0 : set explicitly
         | 
| 561 | 
            +
            * vy: vy of the legend (not used if !first -- see below).
         | 
| 562 | 
            +
                * nil : internally determined
         | 
| 563 | 
            +
                * Float && > 0 : set explicitly
         | 
| 564 | 
            +
                * Float && < 0 : move it relatively lower from the default
         | 
| 565 | 
            +
            * first : if false, vy is moved lower relatively from the previous vy.
         | 
| 566 | 
            +
            * mark_size : size of the mark. if nil, size is used.
         | 
| 567 | 
            +
             | 
| 568 | 
            +
            ---quasi_log_levels_z(vals, nlev=nil, max=nil, min=nil, cycle=1)
         | 
| 569 | 
            +
             | 
| 570 | 
            +
            Driver of quasi_log_levels with data values
         | 
| 571 | 
            +
             | 
| 572 | 
            +
            ---quasi_log_levels(lev0, lev1, cycle=1)
         | 
| 573 | 
            +
             | 
| 574 | 
            +
            Returns approximately log-scaled contour/tone levels as well as
         | 
| 575 | 
            +
            major/minor flags for contours. No DCL call is made in here.
         | 
| 576 | 
            +
             | 
| 577 | 
            +
            * cycle (Integer; 1, or 2 or 3) : number of level in one-order.
         | 
| 578 | 
            +
              e.g. 1,10,100,.. for cycle==1; 1,3,10,30,.. for cycle==2;
         | 
| 579 | 
            +
              1,2,5,10,20,50,.. for cycle==3
         | 
| 580 | 
            +
            * lev0, lev1 (Float) : levels are set between this two params
         | 
| 581 | 
            +
              * if lev0 & lev1 > 0 : positive only
         | 
| 582 | 
            +
              * if lev0 & lev1 < 0 : negative only
         | 
| 583 | 
            +
              * if lev0 * lev1 < 0 : both positive and negative
         | 
| 584 | 
            +
                (usig +-[lev0.abs,lev1.abs])
         | 
| 585 | 
            +
            RETURN VALUE:
         | 
| 586 | 
            +
            * [ levels, mjmn ]
         | 
| 587 | 
            +
             | 
| 588 | 
            +
            =end
         | 
| 589 | 
            +
            ############################################################
         | 
| 590 | 
            +
             | 
| 591 | 
            +
            module NumRu
         | 
| 592 | 
            +
             | 
| 593 | 
            +
              module DCLExt
         | 
| 594 | 
            +
                # to be included in the RubyDCL distribution
         | 
| 595 | 
            +
             | 
| 596 | 
            +
                module_function
         | 
| 597 | 
            +
             | 
| 598 | 
            +
                #<<< for many packages >>>
         | 
| 599 | 
            +
             | 
| 600 | 
            +
                %w!gl sg sl sw uz ul uc uu us ud ue ug um!.each do |pkg|
         | 
| 601 | 
            +
                  eval <<-EOS, nil, __FILE__, __LINE__+1
         | 
| 602 | 
            +
                    def #{pkg}_set_params(hash)
         | 
| 603 | 
            +
                      before = Hash.new
         | 
| 604 | 
            +
                      hash.each{|k,v|
         | 
| 605 | 
            +
                        before[k]=DCL.#{pkg}pget(k)
         | 
| 606 | 
            +
                        if(v.is_a? String) then
         | 
| 607 | 
            +
                          DCL.#{pkg}cset(k,v)
         | 
| 608 | 
            +
                        else
         | 
| 609 | 
            +
                          DCL.#{pkg}pset(k,v)
         | 
| 610 | 
            +
                        end
         | 
| 611 | 
            +
                      }
         | 
| 612 | 
            +
                      before
         | 
| 613 | 
            +
                    end
         | 
| 614 | 
            +
                  EOS
         | 
| 615 | 
            +
                end
         | 
| 616 | 
            +
             | 
| 617 | 
            +
                #<<< module data >>>
         | 
| 618 | 
            +
             | 
| 619 | 
            +
                @@empty_hash = Hash.new
         | 
| 620 | 
            +
             | 
| 621 | 
            +
                #<<< udpack >>>
         | 
| 622 | 
            +
             | 
| 623 | 
            +
                def ud_coloring(clr_min=13, clr_max=99)
         | 
| 624 | 
            +
                  # change the colors of existing contours to make a gradation
         | 
| 625 | 
            +
                  # (rainbow colors with the default color map).
         | 
| 626 | 
            +
                  nlev = DCL.udqcln
         | 
| 627 | 
            +
                  cont_params = Array.new
         | 
| 628 | 
            +
                  for i in 1..nlev
         | 
| 629 | 
            +
                    cont_params.push( DCL.udqclv(i) )   # => [zlev,indx,ityp,clv,hl]
         | 
| 630 | 
            +
                  end
         | 
| 631 | 
            +
                  DCL.udiclv     # clear the contours
         | 
| 632 | 
            +
             | 
| 633 | 
            +
                  colors = clr_min +
         | 
| 634 | 
            +
                           NArray.int(nlev).indgen! * (clr_max-clr_min) / nlev
         | 
| 635 | 
            +
             | 
| 636 | 
            +
                  cont_params.sort!
         | 
| 637 | 
            +
                  for i in 0...nlev
         | 
| 638 | 
            +
                    cont_params[i][1] += colors[i]*10   # indx += colors[i]*10
         | 
| 639 | 
            +
                    DCL.udsclv(*cont_params[i])
         | 
| 640 | 
            +
                  end
         | 
| 641 | 
            +
                end
         | 
| 642 | 
            +
             | 
| 643 | 
            +
                def ud_set_linear_levs(v, options=nil)
         | 
| 644 | 
            +
                  #Accepted options
         | 
| 645 | 
            +
                  #  name        default  description
         | 
| 646 | 
            +
                  #  'min'       nil      minimum contour value (Numeric)
         | 
| 647 | 
            +
                  #  'max'       nil      maximum contour value (Numeric)
         | 
| 648 | 
            +
                  #  'nlev'      nil      number of levels (Integer)
         | 
| 649 | 
            +
                  #  'interval'  nil      contour interval (Numeric)
         | 
| 650 | 
            +
                  #  'nozero'    false    delete zero contour (true/false)
         | 
| 651 | 
            +
                  #  'coloring'  false    set color contours with ud_coloring (true/false)
         | 
| 652 | 
            +
                  #  'clr_min'   13       (if coloring) minimum color  number for the
         | 
| 653 | 
            +
                  #                       maximum data values (Integer)
         | 
| 654 | 
            +
                  #  'clr_max'   99      (if coloring) maximum color number for the
         | 
| 655 | 
            +
                  #                       maximum data values (Integer)
         | 
| 656 | 
            +
                  options = @@empty_hash if !options
         | 
| 657 | 
            +
                  raise TypeError, "options must be a Hash" if !options.is_a?(Hash)
         | 
| 658 | 
            +
                  min = options['min']
         | 
| 659 | 
            +
                  max = options['max']
         | 
| 660 | 
            +
                  nlev = options['nlev']
         | 
| 661 | 
            +
                  interval = options['interval']
         | 
| 662 | 
            +
                  nozero = options['nozero']
         | 
| 663 | 
            +
                  if interval
         | 
| 664 | 
            +
                    dx = interval
         | 
| 665 | 
            +
                  elsif nlev
         | 
| 666 | 
            +
                    dx = -nlev
         | 
| 667 | 
            +
                  else
         | 
| 668 | 
            +
                    dx = 0
         | 
| 669 | 
            +
                  end
         | 
| 670 | 
            +
                  if min || max
         | 
| 671 | 
            +
                    min = v.min if !min
         | 
| 672 | 
            +
                    max = v.max if !max
         | 
| 673 | 
            +
                    DCL.udgcla(min, max, dx)
         | 
| 674 | 
            +
                  else
         | 
| 675 | 
            +
                    DCL.udgclb(v, dx)
         | 
| 676 | 
            +
                  end
         | 
| 677 | 
            +
                  if nozero
         | 
| 678 | 
            +
                    DCL.uddclv(0.0)
         | 
| 679 | 
            +
                  end
         | 
| 680 | 
            +
                  if options['coloring']
         | 
| 681 | 
            +
                    clr_min = ( options['clr_min'] || 13 )
         | 
| 682 | 
            +
                    clr_max = ( options['clr_max'] || 99 )
         | 
| 683 | 
            +
                    ud_coloring( clr_min, clr_max )
         | 
| 684 | 
            +
                  end
         | 
| 685 | 
            +
                end
         | 
| 686 | 
            +
             | 
| 687 | 
            +
                def ud_set_contour(*args)
         | 
| 688 | 
            +
                  DCL.udiclv
         | 
| 689 | 
            +
                  ud_add_contour(*args)
         | 
| 690 | 
            +
                end
         | 
| 691 | 
            +
             | 
| 692 | 
            +
                def ud_add_contour(levels,index=nil,line_type=nil,label=nil,label_height=nil)
         | 
| 693 | 
            +
             | 
| 694 | 
            +
                  # < check levels >
         | 
| 695 | 
            +
                  case levels
         | 
| 696 | 
            +
                  when Array, NArray
         | 
| 697 | 
            +
                    # This is expected. Nothing to do.
         | 
| 698 | 
            +
                  when Numric
         | 
| 699 | 
            +
                    levels = [levels]
         | 
| 700 | 
            +
                  else
         | 
| 701 | 
            +
                    raise ArgumentError, "invalid level specification (#{levels})"
         | 
| 702 | 
            +
                  end
         | 
| 703 | 
            +
             | 
| 704 | 
            +
                  nlev = levels.length
         | 
| 705 | 
            +
             | 
| 706 | 
            +
                  # < index >
         | 
| 707 | 
            +
                  index = index.to_a if index.is_a?(NArray)
         | 
| 708 | 
            +
                  case index
         | 
| 709 | 
            +
                  when Array
         | 
| 710 | 
            +
                    raise ArgumentError, "index is an empty array" if index.length == 0
         | 
| 711 | 
            +
                    while (index.length < nlev )
         | 
| 712 | 
            +
                      index += index
         | 
| 713 | 
            +
                    end
         | 
| 714 | 
            +
                  when Numeric
         | 
| 715 | 
            +
                    index = [index]*nlev
         | 
| 716 | 
            +
                  when nil
         | 
| 717 | 
            +
                    index = [DCL.udpget('indxmn')]*nlev
         | 
| 718 | 
            +
                  else
         | 
| 719 | 
            +
                    raise ArgumentError, "unsupported index type (#{index.class})"
         | 
| 720 | 
            +
                  end
         | 
| 721 | 
            +
             | 
| 722 | 
            +
                  # < line_type >
         | 
| 723 | 
            +
                  line_type = line_type.to_a if line_type.is_a?(NArray)
         | 
| 724 | 
            +
                  case line_type
         | 
| 725 | 
            +
                  when Array
         | 
| 726 | 
            +
                    raise ArgumentError, "line_type is an empty array" if line_type.length == 0
         | 
| 727 | 
            +
                    while (line_type.length < nlev )
         | 
| 728 | 
            +
                      line_type += line_type
         | 
| 729 | 
            +
                    end
         | 
| 730 | 
            +
                  when Numeric
         | 
| 731 | 
            +
                    line_type = [line_type]*nlev
         | 
| 732 | 
            +
                  when nil
         | 
| 733 | 
            +
                    line_type = [1]*nlev
         | 
| 734 | 
            +
                  else
         | 
| 735 | 
            +
                    raise ArgumentError, "unsupported index type (#{index.class})"
         | 
| 736 | 
            +
                  end
         | 
| 737 | 
            +
             | 
| 738 | 
            +
                  # < label >
         | 
| 739 | 
            +
                  label = label.to_a if label.is_a?(NArray)
         | 
| 740 | 
            +
                  case label
         | 
| 741 | 
            +
                  when Array
         | 
| 742 | 
            +
                    raise ArgumentError, "label is an empty array" if label.length == 0
         | 
| 743 | 
            +
                    while (label.length < nlev )
         | 
| 744 | 
            +
                      label += label
         | 
| 745 | 
            +
                    end
         | 
| 746 | 
            +
                  when String
         | 
| 747 | 
            +
                    label = [label]*nlev
         | 
| 748 | 
            +
                  when false
         | 
| 749 | 
            +
                    label = [""]*nlev
         | 
| 750 | 
            +
                  when true
         | 
| 751 | 
            +
                    label = (0...nlev).collect{|i|
         | 
| 752 | 
            +
                        DCL.udlabl(levels[i])
         | 
| 753 | 
            +
                    }
         | 
| 754 | 
            +
                  when nil
         | 
| 755 | 
            +
                    indxmj = DCL.udpget('indxmj')
         | 
| 756 | 
            +
                    label = (0...nlev).collect{|i|
         | 
| 757 | 
            +
                      if index[i]==indxmj
         | 
| 758 | 
            +
                        DCL.udlabl(levels[i])
         | 
| 759 | 
            +
                      else
         | 
| 760 | 
            +
                        ""
         | 
| 761 | 
            +
                      end
         | 
| 762 | 
            +
                    }
         | 
| 763 | 
            +
                  else
         | 
| 764 | 
            +
                    raise ArgumentError, "unsupported index type (#{index.class})"
         | 
| 765 | 
            +
                  end
         | 
| 766 | 
            +
             | 
| 767 | 
            +
                  # < label_height >
         | 
| 768 | 
            +
                  label_height = label_height.to_a if label_height.is_a?(NArray)
         | 
| 769 | 
            +
                  case label_height
         | 
| 770 | 
            +
                  when Array
         | 
| 771 | 
            +
                    raise ArgumentError, "label_height is an empty array" if label_height.length == 0
         | 
| 772 | 
            +
                    while (label_height.length < nlev )
         | 
| 773 | 
            +
                      label_height += label_height
         | 
| 774 | 
            +
                    end
         | 
| 775 | 
            +
                  when Numeric
         | 
| 776 | 
            +
                    label_height = [label_height]*nlev
         | 
| 777 | 
            +
                  when nil
         | 
| 778 | 
            +
                    label_height = label.collect{|lv| lv=="" ? 0.0 : DCL.udpget('rsizel')}
         | 
| 779 | 
            +
                  else
         | 
| 780 | 
            +
                    raise ArgumentError, "unsupported index type (#{index.class})"
         | 
| 781 | 
            +
                  end
         | 
| 782 | 
            +
             | 
| 783 | 
            +
                  # < set levels >
         | 
| 784 | 
            +
             | 
| 785 | 
            +
                  for i in 0...nlev
         | 
| 786 | 
            +
                    DCL.udsclv(levels[i],index[i],line_type[i],label[i],label_height[i])
         | 
| 787 | 
            +
                  end
         | 
| 788 | 
            +
                  nil
         | 
| 789 | 
            +
                end
         | 
| 790 | 
            +
             | 
| 791 | 
            +
                #<<< uepack >>>
         | 
| 792 | 
            +
             | 
| 793 | 
            +
                def ue_set_linear_levs(v, options=nil)
         | 
| 794 | 
            +
                  #  'min'       nil      minimum tone level (Numeric)
         | 
| 795 | 
            +
                  #  'max'       nil      maximum tone level (Numeric)
         | 
| 796 | 
            +
                  #  'nlev'      nil      number of levels (Integer)
         | 
| 797 | 
            +
                  #  'interval'  nil      tone-level interval (Numeric)
         | 
| 798 | 
            +
                  options = @@empty_hash if !options
         | 
| 799 | 
            +
                  raise TypeError, "options must be a Hash" if !options.is_a?(Hash)
         | 
| 800 | 
            +
                  min = options['min']
         | 
| 801 | 
            +
                  max = options['max']
         | 
| 802 | 
            +
                  nlev = options['nlev']
         | 
| 803 | 
            +
                  interval = options['interval']
         | 
| 804 | 
            +
                  if interval
         | 
| 805 | 
            +
                    dx = interval
         | 
| 806 | 
            +
                  elsif nlev
         | 
| 807 | 
            +
                    dx = -nlev
         | 
| 808 | 
            +
                  else
         | 
| 809 | 
            +
                    dx = 0
         | 
| 810 | 
            +
                  end
         | 
| 811 | 
            +
                  if min || max
         | 
| 812 | 
            +
                    min = v.min if !min
         | 
| 813 | 
            +
                    max = v.max if !max
         | 
| 814 | 
            +
                    DCL.uegtla(min, max, dx)
         | 
| 815 | 
            +
                  else
         | 
| 816 | 
            +
                    v = v.reshape(v.length,1) if v.rank==1
         | 
| 817 | 
            +
                    DCL.uegtlb(v, dx)
         | 
| 818 | 
            +
                  end
         | 
| 819 | 
            +
                end
         | 
| 820 | 
            +
             | 
| 821 | 
            +
                def ue_set_tone(levels, patterns)
         | 
| 822 | 
            +
                  DCL.ueitlv
         | 
| 823 | 
            +
                  ue_add_tone(levels, patterns)
         | 
| 824 | 
            +
                end
         | 
| 825 | 
            +
             | 
| 826 | 
            +
                def ue_add_tone(levels, patterns)
         | 
| 827 | 
            +
             | 
| 828 | 
            +
                  # < check types >
         | 
| 829 | 
            +
             | 
| 830 | 
            +
                  if !levels.is_a?(Array) && !levels.is_a?(NArray)
         | 
| 831 | 
            +
                    raise TypeError, "levels: Array or NArray expected (#{levels.inspect})"
         | 
| 832 | 
            +
                  end
         | 
| 833 | 
            +
                  if !patterns.is_a?(Array) && !patterns.is_a?(NArray)
         | 
| 834 | 
            +
                    raise TypeError, "patterns: Array or NArray expected (#{patterns.inspect})"
         | 
| 835 | 
            +
                  end
         | 
| 836 | 
            +
             | 
| 837 | 
            +
                  # < set levels >
         | 
| 838 | 
            +
             | 
| 839 | 
            +
                  nlev = levels.length
         | 
| 840 | 
            +
                  npat = patterns.length
         | 
| 841 | 
            +
             | 
| 842 | 
            +
                  case (nlev - npat)
         | 
| 843 | 
            +
                  when 1
         | 
| 844 | 
            +
                    for i in 0...nlev-1
         | 
| 845 | 
            +
                      DCL.uestlv(levels[i],levels[i+1],patterns[i])
         | 
| 846 | 
            +
                    end
         | 
| 847 | 
            +
                  when 0
         | 
| 848 | 
            +
                    for i in 0...nlev-1
         | 
| 849 | 
            +
                      DCL.uestlv(levels[i],levels[i+1],patterns[i])
         | 
| 850 | 
            +
                    end
         | 
| 851 | 
            +
                    DCL.uestlv(levels[-1],DCL.glpget('rmiss'),patterns[-1])
         | 
| 852 | 
            +
                  when -1
         | 
| 853 | 
            +
                    DCL.uestlv(DCL.glpget('rmiss'),levels[0],patterns[0])
         | 
| 854 | 
            +
                    for i in 1...nlev
         | 
| 855 | 
            +
                      DCL.uestlv(levels[i-1],levels[i],patterns[i])
         | 
| 856 | 
            +
                    end
         | 
| 857 | 
            +
                    DCL.uestlv(levels[-1],DCL.glpget('rmiss'),patterns[-1])
         | 
| 858 | 
            +
                  else
         | 
| 859 | 
            +
                    raise ArgumentError,
         | 
| 860 | 
            +
                      "lengths of levels(#{nlev}) and patterns(#{npat}) are inconsistent"
         | 
| 861 | 
            +
                  end
         | 
| 862 | 
            +
                  nil
         | 
| 863 | 
            +
                end
         | 
| 864 | 
            +
             | 
| 865 | 
            +
                ############################################################
         | 
| 866 | 
            +
                # RELATIVELY INDEPENDENT OF DCL SUBLIBRARIES
         | 
| 867 | 
            +
                ############################################################
         | 
| 868 | 
            +
             | 
| 869 | 
            +
                # <<< longitude/latitude axes package >>>
         | 
| 870 | 
            +
             | 
| 871 | 
            +
                @@lon_ax_options = Misc::KeywordOptAutoHelp.new(
         | 
| 872 | 
            +
                  ['yax', false, 'true => y-axis, false => x-axis'],
         | 
| 873 | 
            +
                  ['cside', nil, '"b", "t", "l", "r", nil (=>left/bottom), or false (=>right/top)'],
         | 
| 874 | 
            +
                  ['dtick1', nil, 'Interval of small tickmark (if nil, internally determined)'],
         | 
| 875 | 
            +
                  ['dtick2', nil, 'Interval of large tickmark with labels (if nil, internally determined)']
         | 
| 876 | 
            +
                )
         | 
| 877 | 
            +
             | 
| 878 | 
            +
                def lon_ax(options=nil)
         | 
| 879 | 
            +
                  opt = @@lon_ax_options.interpret(options)
         | 
| 880 | 
            +
             | 
| 881 | 
            +
                  yax = opt['yax']
         | 
| 882 | 
            +
                  xax = !yax
         | 
| 883 | 
            +
                  if xax
         | 
| 884 | 
            +
                    xy='x'
         | 
| 885 | 
            +
                  else
         | 
| 886 | 
            +
                    xy='y'
         | 
| 887 | 
            +
                  end
         | 
| 888 | 
            +
             | 
| 889 | 
            +
                  if opt['cside']
         | 
| 890 | 
            +
                    cside = opt['cside']
         | 
| 891 | 
            +
                  elsif opt['cside'].nil?
         | 
| 892 | 
            +
                    if xax
         | 
| 893 | 
            +
                      cside='b'
         | 
| 894 | 
            +
                    else
         | 
| 895 | 
            +
                      cside='l'
         | 
| 896 | 
            +
                    end
         | 
| 897 | 
            +
                  else
         | 
| 898 | 
            +
                    if xax
         | 
| 899 | 
            +
                      cside='t'
         | 
| 900 | 
            +
                    else
         | 
| 901 | 
            +
                      cside='r'
         | 
| 902 | 
            +
                    end
         | 
| 903 | 
            +
                  end
         | 
| 904 | 
            +
             | 
| 905 | 
            +
                  vxmin, vxmax, vymin, vymax = DCL.sgqvpt
         | 
| 906 | 
            +
                  uxmin, uxmax, uymin, uymax = DCL.sgqwnd
         | 
| 907 | 
            +
                  if xax
         | 
| 908 | 
            +
                    vmin, vmax = [vxmin,vxmax].min, [vxmin,vxmax].max
         | 
| 909 | 
            +
                    umin, umax = [uxmin,uxmax].min, [uxmin,uxmax].max
         | 
| 910 | 
            +
                  else
         | 
| 911 | 
            +
                    vmin, vmax = [vymin,vymax].min, [vymin,vymax].max
         | 
| 912 | 
            +
                    umin, umax = [uymin,uymax].min, [uymin,uymax].max
         | 
| 913 | 
            +
                  end
         | 
| 914 | 
            +
             | 
| 915 | 
            +
                  # get dtick1 & dtick2
         | 
| 916 | 
            +
                  dtick1 = opt['dtick1']
         | 
| 917 | 
            +
                  dtick2 = opt['dtick2']
         | 
| 918 | 
            +
                  unless dtick1 && dtick2
         | 
| 919 | 
            +
                    irota = DCL.uzpget("irotl#{xy}#{cside}")
         | 
| 920 | 
            +
                    irota += 1 if yax
         | 
| 921 | 
            +
                    mode = irota.modulo(2)
         | 
| 922 | 
            +
                    DCL.ususcu(xy.capitalize,umin,umax,vmin,vmax,mode)
         | 
| 923 | 
            +
                    dtick1 = DCL.uspget("d#{xy}t") unless dtick1
         | 
| 924 | 
            +
                    dtick2 = DCL.uspget("d#{xy}l") unless dtick2
         | 
| 925 | 
            +
                  end
         | 
| 926 | 
            +
             | 
| 927 | 
            +
                  lepsl = DCL.glpget('lepsl')
         | 
| 928 | 
            +
                  repsl = DCL.glpget('repsl')
         | 
| 929 | 
            +
                  DCL.glpset('lepsl',true)
         | 
| 930 | 
            +
             | 
| 931 | 
            +
                  # generate numbers for small tickmarks
         | 
| 932 | 
            +
                  nn = 0
         | 
| 933 | 
            +
                  rx = DCL.irle(umin/dtick1)*dtick1
         | 
| 934 | 
            +
                  if DCL.lreq(umin,rx)
         | 
| 935 | 
            +
                    x = rx
         | 
| 936 | 
            +
                  else
         | 
| 937 | 
            +
                    x = rx + dtick1
         | 
| 938 | 
            +
                  end
         | 
| 939 | 
            +
                  u1 = []
         | 
| 940 | 
            +
                  while DCL.lrle(x,umax)
         | 
| 941 | 
            +
                    if x.abs < dtick1*repsl*nn
         | 
| 942 | 
            +
                      x = 0.0
         | 
| 943 | 
            +
                    end
         | 
| 944 | 
            +
                    u1[nn] = x
         | 
| 945 | 
            +
                    nn = nn + 1
         | 
| 946 | 
            +
                    x = x + dtick1
         | 
| 947 | 
            +
                  end
         | 
| 948 | 
            +
             | 
| 949 | 
            +
                  # generate numbers for large tickmarks and labels
         | 
| 950 | 
            +
                  nn = 0
         | 
| 951 | 
            +
                  rx = DCL.irle(umin/dtick2)*dtick2
         | 
| 952 | 
            +
                  if DCL.lreq(umin,rx)
         | 
| 953 | 
            +
                    x = rx
         | 
| 954 | 
            +
                  else
         | 
| 955 | 
            +
                    x = rx + dtick2
         | 
| 956 | 
            +
                  end
         | 
| 957 | 
            +
                  u2 = []
         | 
| 958 | 
            +
                  while DCL.lrle(x,umax)
         | 
| 959 | 
            +
                    if x.abs < dtick2*repsl*nn
         | 
| 960 | 
            +
                      x = 0
         | 
| 961 | 
            +
                    end
         | 
| 962 | 
            +
                    u2[nn] = x
         | 
| 963 | 
            +
                    nn = nn + 1
         | 
| 964 | 
            +
                    x = x + dtick2
         | 
| 965 | 
            +
                  end
         | 
| 966 | 
            +
             | 
| 967 | 
            +
                  # generate labels
         | 
| 968 | 
            +
                  c2 = NArray.to_na(u2)
         | 
| 969 | 
            +
                  c2[c2.gt(180)] -= 360.0
         | 
| 970 | 
            +
                  c2[c2.lt(-180)] += 360.0
         | 
| 971 | 
            +
                  c2[c2.eq(-180)] = 180.0
         | 
| 972 | 
            +
                  c2 = c2.to_a.collect do |c|
         | 
| 973 | 
            +
                    if c == 0 || c == 180
         | 
| 974 | 
            +
                      c.to_i.to_s
         | 
| 975 | 
            +
                    elsif c > 0
         | 
| 976 | 
            +
                      c.to_i.to_s + 'E'
         | 
| 977 | 
            +
                    else
         | 
| 978 | 
            +
                      c.abs.to_i.to_s + 'W'
         | 
| 979 | 
            +
                    end
         | 
| 980 | 
            +
                  end
         | 
| 981 | 
            +
                  nc = c2.collect{|c| c.size}.max
         | 
| 982 | 
            +
             | 
| 983 | 
            +
                  # call DCL.u[xy]axlb
         | 
| 984 | 
            +
                  if xax
         | 
| 985 | 
            +
                   DCL.uxaxlb(cside,u1,u2,c2,nc)
         | 
| 986 | 
            +
                  else
         | 
| 987 | 
            +
                   DCL.uyaxlb(cside,u1,u2,c2,nc)
         | 
| 988 | 
            +
                  end
         | 
| 989 | 
            +
                end
         | 
| 990 | 
            +
             | 
| 991 | 
            +
                @@lat_ax_options = Misc::KeywordOptAutoHelp.new(
         | 
| 992 | 
            +
                  ['xax', false, 'true => x-axis, false => y-axis'],
         | 
| 993 | 
            +
                  ['cside', nil, '"b", "t", "l", "r", nil (=>left/bottom), or false (=>right/top)'],
         | 
| 994 | 
            +
                  ['dtick1', nil, 'Interval of small tickmark (if nil, internally determined)'],
         | 
| 995 | 
            +
                  ['dtick2', nil, 'Interval of large tickmark with labels (if nil, internally determined)']
         | 
| 996 | 
            +
                )
         | 
| 997 | 
            +
             | 
| 998 | 
            +
                def lat_ax(options=nil)
         | 
| 999 | 
            +
                  opt = @@lat_ax_options.interpret(options)
         | 
| 1000 | 
            +
             | 
| 1001 | 
            +
                  xax = opt['xax']
         | 
| 1002 | 
            +
                  yax = !xax
         | 
| 1003 | 
            +
                  if xax
         | 
| 1004 | 
            +
                    xy='x'
         | 
| 1005 | 
            +
                  else
         | 
| 1006 | 
            +
                    xy='y'
         | 
| 1007 | 
            +
                  end
         | 
| 1008 | 
            +
             | 
| 1009 | 
            +
                  if opt['cside']
         | 
| 1010 | 
            +
                    cside = opt['cside']
         | 
| 1011 | 
            +
                  elsif opt['cside'].nil?
         | 
| 1012 | 
            +
                    if xax
         | 
| 1013 | 
            +
                      cside='b'
         | 
| 1014 | 
            +
                    else
         | 
| 1015 | 
            +
                      cside='l'
         | 
| 1016 | 
            +
                    end
         | 
| 1017 | 
            +
                  else
         | 
| 1018 | 
            +
                    if xax
         | 
| 1019 | 
            +
                      cside='t'
         | 
| 1020 | 
            +
                    else
         | 
| 1021 | 
            +
                      cside='r'
         | 
| 1022 | 
            +
                    end
         | 
| 1023 | 
            +
                  end
         | 
| 1024 | 
            +
             | 
| 1025 | 
            +
                  vxmin, vxmax, vymin, vymax = DCL.sgqvpt
         | 
| 1026 | 
            +
                  uxmin, uxmax, uymin, uymax = DCL.sgqwnd
         | 
| 1027 | 
            +
                  if xax
         | 
| 1028 | 
            +
                    vmin, vmax = [vxmin,vxmax].min, [vxmin,vxmax].max
         | 
| 1029 | 
            +
                    umin, umax = [uxmin,uxmax].min, [uxmin,uxmax].max
         | 
| 1030 | 
            +
                  else
         | 
| 1031 | 
            +
                    vmin, vmax = [vymin,vymax].min, [vymin,vymax].max
         | 
| 1032 | 
            +
                    umin, umax = [uymin,uymax].min, [uymin,uymax].max
         | 
| 1033 | 
            +
                  end
         | 
| 1034 | 
            +
             | 
| 1035 | 
            +
                  # get dtick1 & dtick2
         | 
| 1036 | 
            +
                  dtick1 = opt['dtick1']
         | 
| 1037 | 
            +
                  dtick2 = opt['dtick2']
         | 
| 1038 | 
            +
                  unless dtick1 && dtick2
         | 
| 1039 | 
            +
                    irota = DCL.uzpget("irotl#{xy}#{cside}")
         | 
| 1040 | 
            +
                    irota += 1 if yax
         | 
| 1041 | 
            +
                    mode = irota.modulo(2)
         | 
| 1042 | 
            +
                    DCL.ususcu(xy.capitalize,umin,umax,vmin,vmax,mode)
         | 
| 1043 | 
            +
                    dtick1 = DCL.uspget("d#{xy}t") unless dtick1
         | 
| 1044 | 
            +
                    dtick2 = DCL.uspget("d#{xy}l") unless dtick2
         | 
| 1045 | 
            +
                  end
         | 
| 1046 | 
            +
             | 
| 1047 | 
            +
                  lepsl = DCL.glpget('lepsl')
         | 
| 1048 | 
            +
                  repsl = DCL.glpget('repsl')
         | 
| 1049 | 
            +
                  DCL.glpset('lepsl',true)
         | 
| 1050 | 
            +
             | 
| 1051 | 
            +
                  # generate numbers for small tickmarks
         | 
| 1052 | 
            +
                  nn = 0
         | 
| 1053 | 
            +
                  rx = DCL.irle(umin/dtick1)*dtick1
         | 
| 1054 | 
            +
                  if DCL.lreq(umin,rx)
         | 
| 1055 | 
            +
                    x = rx
         | 
| 1056 | 
            +
                  else
         | 
| 1057 | 
            +
                    x = rx + dtick1
         | 
| 1058 | 
            +
                  end
         | 
| 1059 | 
            +
                  u1 = []
         | 
| 1060 | 
            +
                  while DCL.lrle(x,umax)
         | 
| 1061 | 
            +
                    if x.abs < dtick1*repsl*nn
         | 
| 1062 | 
            +
                      x = 0.0
         | 
| 1063 | 
            +
                    end
         | 
| 1064 | 
            +
                    u1[nn] = x
         | 
| 1065 | 
            +
                    nn = nn + 1
         | 
| 1066 | 
            +
                    x = x + dtick1
         | 
| 1067 | 
            +
                  end
         | 
| 1068 | 
            +
             | 
| 1069 | 
            +
                  # generate numbers for large tickmarks and labels
         | 
| 1070 | 
            +
                  nn = 0
         | 
| 1071 | 
            +
                  rx = DCL.irle(umin/dtick2)*dtick2
         | 
| 1072 | 
            +
                  if DCL.lreq(umin,rx)
         | 
| 1073 | 
            +
                    x = rx
         | 
| 1074 | 
            +
                  else
         | 
| 1075 | 
            +
                    x = rx + dtick2
         | 
| 1076 | 
            +
                  end
         | 
| 1077 | 
            +
                  u2 = []
         | 
| 1078 | 
            +
                  while DCL.lrle(x,umax)
         | 
| 1079 | 
            +
                    if x.abs < dtick2*repsl*nn
         | 
| 1080 | 
            +
                      x = 0
         | 
| 1081 | 
            +
                    end
         | 
| 1082 | 
            +
                    u2[nn] = x
         | 
| 1083 | 
            +
                    nn = nn + 1
         | 
| 1084 | 
            +
                    x = x + dtick2
         | 
| 1085 | 
            +
                  end
         | 
| 1086 | 
            +
             | 
| 1087 | 
            +
                  # generate labels
         | 
| 1088 | 
            +
                  c2 = NArray.to_na(u2)
         | 
| 1089 | 
            +
                  c2 = c2.to_a.collect do |c|
         | 
| 1090 | 
            +
                    if c == 0
         | 
| 1091 | 
            +
                      'EQ'
         | 
| 1092 | 
            +
                    elsif c > 0
         | 
| 1093 | 
            +
                      c.to_i.to_s + 'N'
         | 
| 1094 | 
            +
                    else
         | 
| 1095 | 
            +
                      c.abs.to_i.to_s + 'S'
         | 
| 1096 | 
            +
                    end
         | 
| 1097 | 
            +
                  end
         | 
| 1098 | 
            +
                  nc = c2.collect{|c| c.size}.max
         | 
| 1099 | 
            +
             | 
| 1100 | 
            +
                  # call DCL.u[xy]axlb
         | 
| 1101 | 
            +
                  if xax
         | 
| 1102 | 
            +
                    DCL.uxaxlb(cside,u1,u2,c2,nc)
         | 
| 1103 | 
            +
                  else
         | 
| 1104 | 
            +
                    DCL.uyaxlb(cside,u1,u2,c2,nc)
         | 
| 1105 | 
            +
                  end
         | 
| 1106 | 
            +
                end
         | 
| 1107 | 
            +
             | 
| 1108 | 
            +
                # <<< flow vector package >>>
         | 
| 1109 | 
            +
             | 
| 1110 | 
            +
                def __truncate(float, order=2)
         | 
| 1111 | 
            +
                  # truncate (round) a floating number with the number digits
         | 
| 1112 | 
            +
                  # specified by "order".
         | 
| 1113 | 
            +
                  # e.g., if order=3, -0.012345 => -0.0123;  6.6666 => 6.67
         | 
| 1114 | 
            +
                  exponent = 10**(-Math::log10(float.abs).floor+order-1)
         | 
| 1115 | 
            +
                  (float * exponent).round.to_f/exponent
         | 
| 1116 | 
            +
                end
         | 
| 1117 | 
            +
             | 
| 1118 | 
            +
                @@unit_vect_options = Misc::KeywordOptAutoHelp.new(
         | 
| 1119 | 
            +
                  ['vxunit', 0.05, "x unit vect len in V coord. Used only when fxunit is omitted (default)"],
         | 
| 1120 | 
            +
                  ['vyunit', 0.05, "y unit vect len in V coord. Used only when fyunit is omitted (default)"],
         | 
| 1121 | 
            +
                  ['vxuloc', nil, "Starting x position of unit vect"],
         | 
| 1122 | 
            +
                  ['vyuloc', nil, "Starting y position of unit vect"],
         | 
| 1123 | 
            +
                  ['vxuoff', 0.05, "Specify vxuloc by offset from right-bottom corner"],
         | 
| 1124 | 
            +
                  ['vyuoff', 0.0, "Specify vyuloc by offset from right-bottom corner"],
         | 
| 1125 | 
            +
                  ['inplace',true, "Whether to print labels right by the unit vector (true) or below the x axis (false)"],
         | 
| 1126 | 
            +
                  ['rsizet', nil, "Label size(default taken from uz-parameter 'rsizel1')"],
         | 
| 1127 | 
            +
                  ['index',  3," Line index of the unit vector"],
         | 
| 1128 | 
            +
                  ['vertical', true,"(used only in unit_vect_single) the unit vector is directed upward if true, to the right if not."]
         | 
| 1129 | 
            +
                )
         | 
| 1130 | 
            +
             | 
| 1131 | 
            +
                def set_unit_vect_options(options)
         | 
| 1132 | 
            +
                  @@unit_vect_options.set(options)
         | 
| 1133 | 
            +
                end
         | 
| 1134 | 
            +
             | 
| 1135 | 
            +
                @@next_unit_vect_options = nil
         | 
| 1136 | 
            +
                def next_unit_vect_options(options)
         | 
| 1137 | 
            +
                  if options.is_a?(Hash)
         | 
| 1138 | 
            +
                    @@next_unit_vect_options = options
         | 
| 1139 | 
            +
                  else
         | 
| 1140 | 
            +
                    raise TypeError,"Hash expected"
         | 
| 1141 | 
            +
                  end
         | 
| 1142 | 
            +
                  nil
         | 
| 1143 | 
            +
                end
         | 
| 1144 | 
            +
             | 
| 1145 | 
            +
                def unit_vect( vxfxratio,   # (V cood length)/(actual length) in x
         | 
| 1146 | 
            +
                               vyfyratio,   # (V cood length)/(actual length) in y
         | 
| 1147 | 
            +
                               fxunit=nil,  # If specified, x unit vect len
         | 
| 1148 | 
            +
                               fyunit=nil,  # If specified, y unit vect len
         | 
| 1149 | 
            +
                               options=nil )
         | 
| 1150 | 
            +
                  #< options >
         | 
| 1151 | 
            +
                  if @@next_unit_vect_options
         | 
| 1152 | 
            +
                    options = ( options ? @@next_unit_vect_options.update(options) :
         | 
| 1153 | 
            +
                                          @@next_unit_vect_options )
         | 
| 1154 | 
            +
                    @@next_unit_vect_options = nil
         | 
| 1155 | 
            +
                  end
         | 
| 1156 | 
            +
                  opt = @@unit_vect_options.interpret(options)
         | 
| 1157 | 
            +
                  vxunit = opt['vxunit']
         | 
| 1158 | 
            +
                  vyunit = opt['vyunit']
         | 
| 1159 | 
            +
                  vxuloc = opt['vxuloc']
         | 
| 1160 | 
            +
                  vyuloc = opt['vyuloc']
         | 
| 1161 | 
            +
                  rsizet = opt['rsizet']
         | 
| 1162 | 
            +
                  index = opt['index']
         | 
| 1163 | 
            +
             | 
| 1164 | 
            +
                  #< unit vector >
         | 
| 1165 | 
            +
                  if fxunit
         | 
| 1166 | 
            +
                    vxunit = vxfxratio * fxunit
         | 
| 1167 | 
            +
                  else
         | 
| 1168 | 
            +
                    fxunit = vxunit / vxfxratio
         | 
| 1169 | 
            +
                  end
         | 
| 1170 | 
            +
                  if fyunit
         | 
| 1171 | 
            +
                    vyunit = vyfyratio * fyunit
         | 
| 1172 | 
            +
                  else
         | 
| 1173 | 
            +
                    fyunit = vyunit / vyfyratio
         | 
| 1174 | 
            +
                  end
         | 
| 1175 | 
            +
                  fxunit = __truncate( (uxusv=fxunit) )
         | 
| 1176 | 
            +
                  fyunit = __truncate( (uyusv=fyunit) )
         | 
| 1177 | 
            +
                  vxunit = vxunit * (fxunit/uxusv)
         | 
| 1178 | 
            +
                  vyunit = vyunit * (fyunit/uyusv)
         | 
| 1179 | 
            +
                  if !(vxuloc && vyuloc)
         | 
| 1180 | 
            +
                    vx0,vx1,vy0,vy1 = DCL.sgqvpt
         | 
| 1181 | 
            +
                    vxuloc = vx1 + opt['vxuoff'] if !vxuloc
         | 
| 1182 | 
            +
                    vyuloc = vy0 + opt['vyuoff'] if !vyuloc
         | 
| 1183 | 
            +
                  end
         | 
| 1184 | 
            +
                  DCL.sglazv( vxuloc, vyuloc,  vxuloc+vxunit, vyuloc,        1, index )
         | 
| 1185 | 
            +
                  DCL.sglazv( vxuloc, vyuloc,  vxuloc,        vyuloc+vyunit, 1, index )
         | 
| 1186 | 
            +
             | 
| 1187 | 
            +
                  #< labelling >
         | 
| 1188 | 
            +
                  sfxunit = sprintf("%.2g",fxunit)
         | 
| 1189 | 
            +
                  sfyunit = sprintf("%.2g",fyunit)
         | 
| 1190 | 
            +
                  rsizet = DCL.uzpget('rsizel1') if !rsizet
         | 
| 1191 | 
            +
                  if opt['inplace']
         | 
| 1192 | 
            +
                    DCL.sgtxzv(vxuloc, vyuloc-1.2*rsizet,
         | 
| 1193 | 
            +
                               sfxunit, rsizet, 0, -1, index)
         | 
| 1194 | 
            +
                    DCL.sgtxzv(vxuloc+1.2*rsizet, vyuloc+0.5*rsizet,
         | 
| 1195 | 
            +
                               sfyunit, rsizet, 90, -1, index)
         | 
| 1196 | 
            +
                  else
         | 
| 1197 | 
            +
                    msg= "UNIT VECTOR X:#{sfxunit} Y:#{sfyunit}"
         | 
| 1198 | 
            +
                    before = uz_set_params({'rsizec1'=>rsizet})
         | 
| 1199 | 
            +
                    DCL.uxsttl('b',' ',0.0)
         | 
| 1200 | 
            +
                    DCL.uxsttl('b',msg,0.0)
         | 
| 1201 | 
            +
                    uz_set_params(before)
         | 
| 1202 | 
            +
                  end
         | 
| 1203 | 
            +
                end
         | 
| 1204 | 
            +
             | 
| 1205 | 
            +
                def unit_vect_single(vfratio, flen, options=nil )
         | 
| 1206 | 
            +
                  #< options >
         | 
| 1207 | 
            +
                  if @@next_unit_vect_options
         | 
| 1208 | 
            +
                    options = ( options ? @@next_unit_vect_options.update(options) :
         | 
| 1209 | 
            +
                                          @@next_unit_vect_options )
         | 
| 1210 | 
            +
                    @@next_unit_vect_options = nil
         | 
| 1211 | 
            +
                  end
         | 
| 1212 | 
            +
                  opt = @@unit_vect_options.interpret(options)
         | 
| 1213 | 
            +
                  vxuloc = opt['vxuloc']
         | 
| 1214 | 
            +
                  vyuloc = opt['vyuloc']
         | 
| 1215 | 
            +
                  rsizet = opt['rsizet'] || DCL.uzpget('rsizel1')
         | 
| 1216 | 
            +
                  index = opt['index']
         | 
| 1217 | 
            +
                  vertical = opt['vertical']
         | 
| 1218 | 
            +
             | 
| 1219 | 
            +
                  #< show the unit vector and the label >
         | 
| 1220 | 
            +
             | 
| 1221 | 
            +
                  if !(vxuloc && vyuloc)
         | 
| 1222 | 
            +
                    vx0,vx1,vy0,vy1 = DCL.sgqvpt
         | 
| 1223 | 
            +
                    vxuloc = vx1 + opt['vxuoff'] if !vxuloc
         | 
| 1224 | 
            +
                    vyuloc = vy0 + opt['vyuoff'] if !vyuloc
         | 
| 1225 | 
            +
                  end
         | 
| 1226 | 
            +
                  vlen = vfratio * flen
         | 
| 1227 | 
            +
                  label = DCL.chval("B",flen)
         | 
| 1228 | 
            +
             | 
| 1229 | 
            +
                  lclip_bk = DCL::sglget("lclip")
         | 
| 1230 | 
            +
                  DCL::sglset("lclip", false)
         | 
| 1231 | 
            +
                  if vertical
         | 
| 1232 | 
            +
                    DCL.sglazv( vxuloc, vyuloc,  vxuloc,      vyuloc+vlen, 1, index )
         | 
| 1233 | 
            +
                    DCL.sgtxzv( vxuloc+1.2*rsizet, vyuloc+0.4*vlen,
         | 
| 1234 | 
            +
                                label, rsizet, 90, 0, index)
         | 
| 1235 | 
            +
                  else
         | 
| 1236 | 
            +
                    DCL.sglazv( vxuloc, vyuloc,  vxuloc+vlen, vyuloc,        1, index )
         | 
| 1237 | 
            +
                    DCL.sgtxzv( vxuloc+0.4*vlen, vyuloc-1.2*rsizet,
         | 
| 1238 | 
            +
                                label, rsizet, 0, 0, index)
         | 
| 1239 | 
            +
                  end
         | 
| 1240 | 
            +
                  DCL::sglset("lclip", lclip_bk)
         | 
| 1241 | 
            +
                  nil
         | 
| 1242 | 
            +
                end
         | 
| 1243 | 
            +
             | 
| 1244 | 
            +
                def flow_vect( fx, fy, factor=1.0, xintv=1, yintv=1,
         | 
| 1245 | 
            +
                               vxfxratio=nil, vyfyratio=nil)
         | 
| 1246 | 
            +
                  raise ArgumentError,"Expect 2D arrays" if fx.rank != 2 || fy.rank != 2
         | 
| 1247 | 
            +
                  raise ArgumentError,"fx.shape != fy.shape" if fx.shape != fy.shape
         | 
| 1248 | 
            +
                  raise ArgumentError,"xintv must be a positive integer" if xintv < 0
         | 
| 1249 | 
            +
                  raise ArgumentError,"yintv must be a positive integer" if yintv < 0
         | 
| 1250 | 
            +
                  nx, ny = fx.shape
         | 
| 1251 | 
            +
                  if xintv >= 2
         | 
| 1252 | 
            +
                    idx = NArray.int(nx/xintv).indgen!*xintv  # [0,xintv,2*xintv,..]
         | 
| 1253 | 
            +
                    fx = fx[idx, true]
         | 
| 1254 | 
            +
                    fy = fy[idx, true]
         | 
| 1255 | 
            +
                  end
         | 
| 1256 | 
            +
                  if yintv >= 2
         | 
| 1257 | 
            +
                    idx = NArray.int(ny/yintv).indgen!*yintv  # [0,yintv,2*yintv,..]
         | 
| 1258 | 
            +
                    fx = fx[true, idx]
         | 
| 1259 | 
            +
                    fy = fy[true, idx]
         | 
| 1260 | 
            +
                  end
         | 
| 1261 | 
            +
                  nx, ny = fx.shape  # again, because of xintv & yintv
         | 
| 1262 | 
            +
                  vx0,vx1,vy0,vy1 = DCL.sgqvpt
         | 
| 1263 | 
            +
                  wnd = DCL.sgqwnd
         | 
| 1264 | 
            +
                  if wnd.include?(DCL.glrget('rundef'))
         | 
| 1265 | 
            +
                    ux0,ux1,uy0,uy1 = DCL.sgqtxy
         | 
| 1266 | 
            +
                  else
         | 
| 1267 | 
            +
                    ux0,ux1,uy0,uy1 = wnd
         | 
| 1268 | 
            +
                  end
         | 
| 1269 | 
            +
                  dvx = (vx1-vx0)/nx
         | 
| 1270 | 
            +
                  dvy = (vy1-vy0)/ny
         | 
| 1271 | 
            +
                  ax = (vx1-vx0)/(ux1-ux0)   # factor to convert from U to V coordinate
         | 
| 1272 | 
            +
                  ay = (vy1-vy0)/(uy1-uy0)   # factor to convert from U to V coordinate
         | 
| 1273 | 
            +
                  fxmx = fx.abs.max
         | 
| 1274 | 
            +
                  fymx = fy.abs.max
         | 
| 1275 | 
            +
                  raise "fx has no data or all zero" if fxmx == 0
         | 
| 1276 | 
            +
                  raise "fy has no data or all zero" if fymx == 0
         | 
| 1277 | 
            +
                  cn = [ dvx/(ax*fxmx),  dvy/(ay*fymx) ].min  # normarization constant
         | 
| 1278 | 
            +
                  vxfxratio = factor*cn*ax if !vxfxratio
         | 
| 1279 | 
            +
                  vyfyratio = factor*cn*ay if !vyfyratio
         | 
| 1280 | 
            +
                  before = ug_set_params( {'LNRMAL'=>false, 'LMSG'=>false,
         | 
| 1281 | 
            +
                                           'XFACT1'=>1.0, 'YFACT1'=>1.0} )
         | 
| 1282 | 
            +
                  DCL.ugvect( vxfxratio*fx, vyfyratio*fy )
         | 
| 1283 | 
            +
                  ug_set_params( before )
         | 
| 1284 | 
            +
                  unit_vect_info = [ vxfxratio, vyfyratio, fxmx, fymx ]
         | 
| 1285 | 
            +
                  return unit_vect_info
         | 
| 1286 | 
            +
                end
         | 
| 1287 | 
            +
             | 
| 1288 | 
            +
                def flow_vect_anyproj(fx, fy, xg, yg,  
         | 
| 1289 | 
            +
                                      factor=1.0, xintv=1, yintv=1, 
         | 
| 1290 | 
            +
                                      distvect_map=true, vfratio=nil, polar_thinning=nil)
         | 
| 1291 | 
            +
             | 
| 1292 | 
            +
                  #< parameters to handle singularity of the projection  >
         | 
| 1293 | 
            +
             | 
| 1294 | 
            +
                  ddv = 0.3e-3  # Initial value for viewport sampling to find directions.
         | 
| 1295 | 
            +
                                # This parameter is modified below if the round off error
         | 
| 1296 | 
            +
                                # may be severe.
         | 
| 1297 | 
            +
                  eps = 0.05  # Allowed maximum inconsistency in two sampling results
         | 
| 1298 | 
            +
                  acc = 1e7   # order of mantissa of sfloat
         | 
| 1299 | 
            +
                  epsbk = 3e-6  # factor to judge whether a grid point is on the backside
         | 
| 1300 | 
            +
                                # when the projection is multi-valued as map projections
         | 
| 1301 | 
            +
             | 
| 1302 | 
            +
                  #< preparation >
         | 
| 1303 | 
            +
             | 
| 1304 | 
            +
                  raise ArgumentError,"Expect 2D arrays" if fx.rank != 2 || fy.rank != 2
         | 
| 1305 | 
            +
                  raise ArgumentError,"fx.shape != fy.shape" if fx.shape != fy.shape
         | 
| 1306 | 
            +
                  raise ArgumentError,"xintv must be a positive integer" if xintv < 0
         | 
| 1307 | 
            +
                  raise ArgumentError,"yintv must be a positive integer" if yintv < 0
         | 
| 1308 | 
            +
                  nx, ny = fx.shape
         | 
| 1309 | 
            +
                  if xg.rank == 1
         | 
| 1310 | 
            +
                    raise ArgumentError,"len of xg (#{xg.length}) != #{nx}" if xg.length!=nx
         | 
| 1311 | 
            +
                  else
         | 
| 1312 | 
            +
                    raise ArgumentError,"xg.shape != shape of data" if xg.shape != fx.shape
         | 
| 1313 | 
            +
                  end
         | 
| 1314 | 
            +
                  if yg.rank == 1
         | 
| 1315 | 
            +
                    raise ArgumentError,"len of yg (#{yg.length}) != #{ny}" if yg.length!=ny
         | 
| 1316 | 
            +
                  else
         | 
| 1317 | 
            +
                    raise ArgumentError,"yg.shape != shape of data" if yg.shape != fx.shape
         | 
| 1318 | 
            +
                  end
         | 
| 1319 | 
            +
                  if xintv >= 2
         | 
| 1320 | 
            +
                    idx = NArray.int(nx/xintv).indgen!*xintv  # [0,xintv,2*xintv,..]
         | 
| 1321 | 
            +
                    fx = fx[idx, true]
         | 
| 1322 | 
            +
                    fy = fy[idx, true]
         | 
| 1323 | 
            +
                    xg = xg[idx, false]
         | 
| 1324 | 
            +
                  end
         | 
| 1325 | 
            +
                  if yintv >= 2
         | 
| 1326 | 
            +
                    idx = NArray.int(ny/yintv).indgen!*yintv  # [0,yintv,2*yintv,..]
         | 
| 1327 | 
            +
                    fx = fx[true, idx]
         | 
| 1328 | 
            +
                    fy = fy[true, idx]
         | 
| 1329 | 
            +
                    yg = yg[false,idx]
         | 
| 1330 | 
            +
                  end
         | 
| 1331 | 
            +
                  nx, ny = fx.shape  # again, because of xintv & yintv
         | 
| 1332 | 
            +
             | 
| 1333 | 
            +
                  #< read DCL parameters >
         | 
| 1334 | 
            +
             | 
| 1335 | 
            +
                  index  = DCL.ugpget('index')
         | 
| 1336 | 
            +
                  rsizem = DCL.ugpget('rsizem')
         | 
| 1337 | 
            +
                  itype2 = DCL.ugpget('itype2')
         | 
| 1338 | 
            +
                  lmissp = DCL.ugpget('lmissp')
         | 
| 1339 | 
            +
                  lmiss  = DCL.glpget('lmiss')
         | 
| 1340 | 
            +
                  rmiss  = DCL.glpget('rmiss')
         | 
| 1341 | 
            +
             | 
| 1342 | 
            +
                  #< Missing value treatment >
         | 
| 1343 | 
            +
                  # -- needed to later caluculate flenmax properly
         | 
| 1344 | 
            +
             | 
| 1345 | 
            +
                  if lmiss
         | 
| 1346 | 
            +
                    fx = NArrayMiss.to_nam(fx, fx.ne(rmiss)) if fx.is_a?(NArray)
         | 
| 1347 | 
            +
                    fy = NArrayMiss.to_nam(fy, fy.ne(rmiss)) if fy.is_a?(NArray)
         | 
| 1348 | 
            +
                  end
         | 
| 1349 | 
            +
             | 
| 1350 | 
            +
                  #< DCL scales >
         | 
| 1351 | 
            +
             | 
| 1352 | 
            +
                  wnd = DCL.sgqwnd
         | 
| 1353 | 
            +
                  if wnd.include?(DCL.glrget('rundef'))
         | 
| 1354 | 
            +
                    ux0,ux1,uy0,uy1 = DCL.sgqtxy
         | 
| 1355 | 
            +
                  else
         | 
| 1356 | 
            +
                    ux0,ux1,uy0,uy1 = wnd
         | 
| 1357 | 
            +
                  end
         | 
| 1358 | 
            +
                  flen = Misc::EMath.sqrt( fx*fx + fy*fy )
         | 
| 1359 | 
            +
                  flenmax = flen.max
         | 
| 1360 | 
            +
                  if !vfratio
         | 
| 1361 | 
            +
                    vx0,vx1,vy0,vy1 = DCL.sgqvpt
         | 
| 1362 | 
            +
                    dvf = Math::sqrt( (vx1-vx0)*(vy1-vy0)/nx/ny )
         | 
| 1363 | 
            +
                    vfratio = factor * dvf / flenmax  # factor to get arrow length in V crd
         | 
| 1364 | 
            +
                  end 
         | 
| 1365 | 
            +
             | 
| 1366 | 
            +
                  #< parameter modification if needed >
         | 
| 1367 | 
            +
                  r = [ [ux0.abs, ux1.abs].min / (ux0-ux1).abs, 
         | 
| 1368 | 
            +
                        [uy0.abs, uy1.abs].min / (uy0-uy1).abs ].max
         | 
| 1369 | 
            +
                  e = acc*ddv*eps
         | 
| 1370 | 
            +
                  if ( r > e )
         | 
| 1371 | 
            +
                    # ddv is too small for the current window, so the round off error 
         | 
| 1372 | 
            +
                    # may be severer. --> increase it up to a prescribed limit.
         | 
| 1373 | 
            +
                    ddv = [ r/e*ddv, 0.1 ].min
         | 
| 1374 | 
            +
                  end
         | 
| 1375 | 
            +
             | 
| 1376 | 
            +
                  #< handling of distance-based vectors under map projection >
         | 
| 1377 | 
            +
             | 
| 1378 | 
            +
                  itr = DCL::sgqtrn
         | 
| 1379 | 
            +
                  map_proj = ( itr >= 10 and itr <= 40 )
         | 
| 1380 | 
            +
                  if map_proj and distvect_map
         | 
| 1381 | 
            +
                    cosphi = Misc::EMath.cos( yg * (Math::PI/180.0) )
         | 
| 1382 | 
            +
                    umodi = true
         | 
| 1383 | 
            +
                  else
         | 
| 1384 | 
            +
                    umodi = false
         | 
| 1385 | 
            +
                  end
         | 
| 1386 | 
            +
             | 
| 1387 | 
            +
                  #< vector drawing >
         | 
| 1388 | 
            +
             | 
| 1389 | 
            +
                  if map_proj
         | 
| 1390 | 
            +
                    uodr = 360.0   # order of domain size in U coordinate
         | 
| 1391 | 
            +
                  else
         | 
| 1392 | 
            +
                    uodr = [xg.max, -xg.min, yg.max, -yg.min].max
         | 
| 1393 | 
            +
                  end
         | 
| 1394 | 
            +
                  dbk = epsbk*uodr
         | 
| 1395 | 
            +
             | 
| 1396 | 
            +
                  u = NMatrix.float(2,2)   # NMatrix's index: [column,row]
         | 
| 1397 | 
            +
                  ap = NMatrix.float(2,2)
         | 
| 1398 | 
            +
                  an = NMatrix.float(2,2)
         | 
| 1399 | 
            +
                  for j in 0...ny
         | 
| 1400 | 
            +
                    if polar_thinning && xg.rank==1 && yg.rank==1
         | 
| 1401 | 
            +
                      j1 = [j+1,ny-1].min
         | 
| 1402 | 
            +
                      dy=(yg[j1]-yg[j1-1]).abs
         | 
| 1403 | 
            +
                      dx = (xg[1]-xg[0]).abs * cos(yg[j]/180*Math::PI)
         | 
| 1404 | 
            +
                      xstep = [ (dy / dx * polar_thinning).round, 1 ].max
         | 
| 1405 | 
            +
                    else
         | 
| 1406 | 
            +
                      xstep = 1
         | 
| 1407 | 
            +
                    end
         | 
| 1408 | 
            +
                    (0...nx).step(xstep) do |i|
         | 
| 1409 | 
            +
                      x = ( xg.rank==1 ? xg[i] : xg[i,j] )
         | 
| 1410 | 
            +
                      y = ( yg.rank==1 ? yg[j] : yg[i,j] )
         | 
| 1411 | 
            +
                      if ( ( fx.is_a?(NArrayMiss) && !fx.valid?(i,j) ) ||
         | 
| 1412 | 
            +
                           ( fy.is_a?(NArrayMiss) && !fy.valid?(i,j) ) )
         | 
| 1413 | 
            +
                        DCL.sgpmzu([x],[y],itype2,index,rsizem) if lmissp
         | 
| 1414 | 
            +
                        next
         | 
| 1415 | 
            +
                      end
         | 
| 1416 | 
            +
                      vx0, vy0 = DCL.stftrf(x, y) 
         | 
| 1417 | 
            +
                      xrev, yrev = DCL.stitrf(vx0, vy0)
         | 
| 1418 | 
            +
                      xdif = (xrev-x).abs
         | 
| 1419 | 
            +
                      ydif = (yrev-y).abs
         | 
| 1420 | 
            +
                      xdif = 360.0-xdif if map_proj && xdif > 359.0
         | 
| 1421 | 
            +
                      if xdif > dbk || ydif > dbk
         | 
| 1422 | 
            +
                        next   # Not plotted, because the current point is on the backside
         | 
| 1423 | 
            +
                      end
         | 
| 1424 | 
            +
                      if umodi
         | 
| 1425 | 
            +
                        cos = ( cosphi.rank==1 ? cosphi[j] : cosphi[i,j] )
         | 
| 1426 | 
            +
                      end
         | 
| 1427 | 
            +
                      um = NMatrix[ [x,x], [y,y] ]
         | 
| 1428 | 
            +
                      u[0,0],u[0,1] = DCL.stitrf(vx0+ddv, vy0)
         | 
| 1429 | 
            +
                      u[1,0],u[1,1] = DCL.stitrf(vx0, vy0+ddv)
         | 
| 1430 | 
            +
                      ap = u - um 
         | 
| 1431 | 
            +
                      (ap[true,0] >=  180.0).where.to_a.each{|i| ap[i,0] -= 360.0}
         | 
| 1432 | 
            +
                      (ap[true,0] <= -180.0).where.to_a.each{|i| ap[i,0] += 360.0}
         | 
| 1433 | 
            +
                      u[0,0],u[0,1] = DCL.stitrf(vx0-ddv, vy0)
         | 
| 1434 | 
            +
                      u[1,0],u[1,1] = DCL.stitrf(vx0, vy0-ddv)
         | 
| 1435 | 
            +
                      an = um - u
         | 
| 1436 | 
            +
                      (an[true,0] >=  180.0).where.to_a.each{|i| an[i,0] -= 360.0}
         | 
| 1437 | 
            +
                      (an[true,0] <= -180.0).where.to_a.each{|i| an[i,0] += 360.0}
         | 
| 1438 | 
            +
                      if umodi
         | 
| 1439 | 
            +
                        ap[0,0] *= cos
         | 
| 1440 | 
            +
                        ap[1,0] *= cos
         | 
| 1441 | 
            +
                        an[0,0] *= cos
         | 
| 1442 | 
            +
                        an[1,0] *= cos
         | 
| 1443 | 
            +
                      end
         | 
| 1444 | 
            +
                      f = NVector[ fx[i,j],fy[i,j] ]
         | 
| 1445 | 
            +
                      vfp = nil
         | 
| 1446 | 
            +
                      begin
         | 
| 1447 | 
            +
                        aip = ap.inverse
         | 
| 1448 | 
            +
                        vfp = aip * f
         | 
| 1449 | 
            +
                      rescue
         | 
| 1450 | 
            +
                      end
         | 
| 1451 | 
            +
                      vfn = nil
         | 
| 1452 | 
            +
                      begin
         | 
| 1453 | 
            +
                        ain = an.inverse
         | 
| 1454 | 
            +
                        vfn = ain * f
         | 
| 1455 | 
            +
                      rescue
         | 
| 1456 | 
            +
                      end
         | 
| 1457 | 
            +
                      if vfp && vfn
         | 
| 1458 | 
            +
                        vf = (vfp+vfn)/2
         | 
| 1459 | 
            +
                        err = (vfp - vfn).abs.max / vf.abs.max
         | 
| 1460 | 
            +
                        vn = vf * ( vfratio*flen[i,j] / Math.sqrt(vf[0]**2+vf[1]**2) )
         | 
| 1461 | 
            +
                        if err>=eps  
         | 
| 1462 | 
            +
                          DCL.sgpmzv([vx0],[vy0],itype2,index,rsizem) if lmissp
         | 
| 1463 | 
            +
                        elsif vn[0].nan? || vn[1].nan?
         | 
| 1464 | 
            +
                          DCL.sgpmzv([vx0],[vy0],itype2,index,rsizem)
         | 
| 1465 | 
            +
                        else
         | 
| 1466 | 
            +
                          DCL.sglazv(vx0, vy0, vx0+vn[0], vy0+vn[1], 1, index) 
         | 
| 1467 | 
            +
                        end
         | 
| 1468 | 
            +
                      end
         | 
| 1469 | 
            +
                    end
         | 
| 1470 | 
            +
                  end
         | 
| 1471 | 
            +
                  [ vfratio, flenmax ]
         | 
| 1472 | 
            +
                end
         | 
| 1473 | 
            +
             | 
| 1474 | 
            +
                
         | 
| 1475 | 
            +
             | 
| 1476 | 
            +
                def flow_itr5( gpx, gpy, factor=1.0, unit_vect=false )
         | 
| 1477 | 
            +
                  raise ArgumentError,"Expect 2D arrays" if gpx.rank != 2 || gpy.rank != 2
         | 
| 1478 | 
            +
                  raise ArgumentError,"gpx.shape != gpy.shape" if gpx.shape != gpy.shape
         | 
| 1479 | 
            +
             | 
| 1480 | 
            +
                  raise "Transform. No. should be 5" if DCL.sgpget('itr') != 5
         | 
| 1481 | 
            +
             | 
| 1482 | 
            +
                  theta = gpx.coord(1) / 180 * Math::PI
         | 
| 1483 | 
            +
                  theta = theta.reshape(1,theta.shape[0])
         | 
| 1484 | 
            +
             | 
| 1485 | 
            +
                  vx = gpx * theta.cos - gpy * theta.sin   # UC component -> VC
         | 
| 1486 | 
            +
                  vy = gpx * theta.sin + gpy * theta.cos   # UC component -> VC
         | 
| 1487 | 
            +
             | 
| 1488 | 
            +
                  DCL.sglset('LCLIP',false)
         | 
| 1489 | 
            +
                  before1 = DCLExt.ug_set_params(
         | 
| 1490 | 
            +
                               {'LUNIT'=>true, 'LUMSG'=>true} ) if unit_vect
         | 
| 1491 | 
            +
                  before2 = DCLExt.ug_set_params(
         | 
| 1492 | 
            +
                               {'LNRMAL'=>false,
         | 
| 1493 | 
            +
                                'XFACT1'=>factor, 'YFACT1'=>factor} ) if factor != 1.0
         | 
| 1494 | 
            +
                  DCL.ugvect( vx.val, vy.val )
         | 
| 1495 | 
            +
             | 
| 1496 | 
            +
                  if unit_vect
         | 
| 1497 | 
            +
                    uxunit = sprintf("%.2g",DCL.ugrget('UXUNIT'))
         | 
| 1498 | 
            +
                    uyunit = sprintf("%.2g",DCL.ugrget('UXUNIT'))
         | 
| 1499 | 
            +
                    vxuloc = DCL.ugrget('VXULOC')
         | 
| 1500 | 
            +
                    vyuloc = DCL.ugrget('VYULOC')
         | 
| 1501 | 
            +
                    rsize  = DCL.ugrget('RSIZET')
         | 
| 1502 | 
            +
                    dv = rsize
         | 
| 1503 | 
            +
                    DCL.sgtxzv(vxuloc, vyuloc-dv, uxunit, rsize,  0, -1, 3 )
         | 
| 1504 | 
            +
                    DCL.sgtxzv(vxuloc-dv, vyuloc, uyunit, rsize, 90, -1, 3 )
         | 
| 1505 | 
            +
                  end
         | 
| 1506 | 
            +
             | 
| 1507 | 
            +
                  ug_set_params( before2 ) if factor != 1.0
         | 
| 1508 | 
            +
                  ug_set_params( before1 ) if unit_vect
         | 
| 1509 | 
            +
                end
         | 
| 1510 | 
            +
             | 
| 1511 | 
            +
                ######################################
         | 
| 1512 | 
            +
             | 
| 1513 | 
            +
                # <<< color bar >>>
         | 
| 1514 | 
            +
             | 
| 1515 | 
            +
                @@color_bar_options =  Misc::KeywordOptAutoHelp.new(
         | 
| 1516 | 
            +
                  ["levels",  nil, "tone levels (if omitted, latest ones are used)"],
         | 
| 1517 | 
            +
                  ["patterns", nil, "tone patterns (~colors) (if omitted, latest ones are used)"],
         | 
| 1518 | 
            +
                  ["voff", nil, "how far is the bar from the viewport in the V coordinate"],
         | 
| 1519 | 
            +
                  ["vcent",nil, "center position of the bar in the V coordinate (VX or VY)"],
         | 
| 1520 | 
            +
                  ["vlength", 0.3, "bar length in the V coordinate"],
         | 
| 1521 | 
            +
                  ["vwidth", 0.02, "bar width in the V coordinate"],
         | 
| 1522 | 
            +
                  ["inffact", 2.25, "factor to change the length of triangle on the side for infinity (relative to 'vwidth')"],
         | 
| 1523 | 
            +
                  ["landscape", false, "if true, horizonlly long (along x axes)"],
         | 
| 1524 | 
            +
                  ["portrait", true, "if true, vertically long (along y axes)"],
         | 
| 1525 | 
            +
                  ["top",  false, "place the bar at the top (effective if landscape)"],
         | 
| 1526 | 
            +
                  ["left", false, "place the bar in the left (effective if portrait)"],
         | 
| 1527 | 
            +
                  ["units", nil, "units of the axis of the color bar"],
         | 
| 1528 | 
            +
                  ["units_voff", 0.0, "offset value for units from the default position in the V coordinate (only for 'units' != nil)"],
         | 
| 1529 | 
            +
                  ["title", nil, "title of the color bar"],
         | 
| 1530 | 
            +
                  ["title_voff", 0.0, "offset value for title from the default position in the V coordinate (only for 'title' != nil)"],
         | 
| 1531 | 
            +
                  ["tickintv", 1, "0,1,2,3,.. to specify how frequently the dividing tick lines are drawn (0: no tick lines, 1: every time, 2: ever other:,...)"],
         | 
| 1532 | 
            +
                  ["labelintv", nil, "0,1,2,3,.. to specify how frequently labels are drawn (0: no labels, 1: every time, 2: ever other:,... default: internally determined)"],
         | 
| 1533 | 
            +
                  ["labels_ud", nil, "user-defined labels for replacing the default labels (Array of String)"],
         | 
| 1534 | 
            +
                  ["charfact", 0.9, "factor to change the label/units/title character size (relative to 'rsizel1')"],
         | 
| 1535 | 
            +
                  ["log", false, "set the color bar scale to logarithmic"],
         | 
| 1536 | 
            +
                  ["constwidth", false, "if true, each color is drawn with the same width"],
         | 
| 1537 | 
            +
                  ["index", nil, "index of tick lines and bar frame"],
         | 
| 1538 | 
            +
                  ["charindex", nil, "index of labels, units, and title"],
         | 
| 1539 | 
            +
                  ["chval_fmt", nil, "string to specify the DCL.chval format for labeling"]
         | 
| 1540 | 
            +
                )
         | 
| 1541 | 
            +
             | 
| 1542 | 
            +
                def set_color_bar_options(options)
         | 
| 1543 | 
            +
                  @@color_bar_options.set(options)
         | 
| 1544 | 
            +
                end
         | 
| 1545 | 
            +
             | 
| 1546 | 
            +
                def log10_safe(val)
         | 
| 1547 | 
            +
                  begin
         | 
| 1548 | 
            +
                    Math::log10(val)
         | 
| 1549 | 
            +
                  rescue Errno::ERANGE
         | 
| 1550 | 
            +
                    nil
         | 
| 1551 | 
            +
                  end
         | 
| 1552 | 
            +
                end
         | 
| 1553 | 
            +
             | 
| 1554 | 
            +
                def log10_or_0(val)
         | 
| 1555 | 
            +
                  log10_safe(val) || 0
         | 
| 1556 | 
            +
                end
         | 
| 1557 | 
            +
             | 
| 1558 | 
            +
                def level_chval_fmt(max,min,dx)
         | 
| 1559 | 
            +
                  # returns a format for DCL.chval suitable for color-ba labels
         | 
| 1560 | 
            +
                  dxabs = dx.abs
         | 
| 1561 | 
            +
                  eps = 1e-4 * dxabs
         | 
| 1562 | 
            +
                  order = log10_or_0(dxabs).floor
         | 
| 1563 | 
            +
                  if ( (dxabs+eps*0.1) % 10**order < eps )
         | 
| 1564 | 
            +
                    # 1 keta
         | 
| 1565 | 
            +
                    least_order = order
         | 
| 1566 | 
            +
                  else
         | 
| 1567 | 
            +
                    # >=2 keta --> limit to 2 keta
         | 
| 1568 | 
            +
                    least_order = order - 1
         | 
| 1569 | 
            +
                  end
         | 
| 1570 | 
            +
                  ng = log10_or_0([max.abs,min.abs,eps].max).floor - least_order + 1
         | 
| 1571 | 
            +
                  if ng <= 3
         | 
| 1572 | 
            +
                    fmt = 'b'
         | 
| 1573 | 
            +
                  else
         | 
| 1574 | 
            +
                    n = log10_or_0([max.abs,min.abs].max).floor
         | 
| 1575 | 
            +
                    nn = log10_or_0([max.abs,min.abs].min).floor
         | 
| 1576 | 
            +
                    if least_order >= 0 and nn >= 0
         | 
| 1577 | 
            +
                      ifg = 'i'
         | 
| 1578 | 
            +
                    elsif 0 <= n and n <= 4
         | 
| 1579 | 
            +
                      ifg = 'f'
         | 
| 1580 | 
            +
                    else
         | 
| 1581 | 
            +
                      ifg = 'g'
         | 
| 1582 | 
            +
                    end
         | 
| 1583 | 
            +
                    case(ifg)
         | 
| 1584 | 
            +
                    when 'i'
         | 
| 1585 | 
            +
                      fmt = '(i15)'
         | 
| 1586 | 
            +
                    when 'g'
         | 
| 1587 | 
            +
                      ng = log10_or_0([max.abs,min.abs,eps].max).floor - least_order + 1
         | 
| 1588 | 
            +
                      ng = [ ng, 2 ].max
         | 
| 1589 | 
            +
                      fmt = "(g15.#{ng})"
         | 
| 1590 | 
            +
                    when 'f'
         | 
| 1591 | 
            +
                      nf = [ -least_order, 0].max
         | 
| 1592 | 
            +
                      fmt = "(f15.#{nf})"
         | 
| 1593 | 
            +
                    end
         | 
| 1594 | 
            +
                  end
         | 
| 1595 | 
            +
                  fmt
         | 
| 1596 | 
            +
                end
         | 
| 1597 | 
            +
             | 
| 1598 | 
            +
                def sprintf_level(x,max,min,dx)
         | 
| 1599 | 
            +
                  # format a float for color-bar labels.
         | 
| 1600 | 
            +
                  # like DCL.hval('b',x) but changes according to dx
         | 
| 1601 | 
            +
                  if x==0
         | 
| 1602 | 
            +
                    fg = 'f'
         | 
| 1603 | 
            +
                  else
         | 
| 1604 | 
            +
                    n = log10_or_0(x.abs).floor
         | 
| 1605 | 
            +
                    if 0 <= n and n <= 4
         | 
| 1606 | 
            +
                      fg = 'f'
         | 
| 1607 | 
            +
                    else
         | 
| 1608 | 
            +
                      fg = 'g'
         | 
| 1609 | 
            +
                    end
         | 
| 1610 | 
            +
                  end
         | 
| 1611 | 
            +
                  eps = 1e-6
         | 
| 1612 | 
            +
                  if ( dx.abs % 10**log10_or_0(dx.abs) < eps )
         | 
| 1613 | 
            +
                    # 1 keta
         | 
| 1614 | 
            +
                    least_order = log10_or_0(dx.abs).floor
         | 
| 1615 | 
            +
                  else
         | 
| 1616 | 
            +
                    # >=2 keta --> limit to 2 keta
         | 
| 1617 | 
            +
                    least_order = log10_or_0(dx.abs).floor - 1
         | 
| 1618 | 
            +
                  end
         | 
| 1619 | 
            +
                  if fg == 'g'
         | 
| 1620 | 
            +
                    ng = log10_or_0([max.abs,min.abs,eps].max).floor - least_order + 1
         | 
| 1621 | 
            +
                    ng = [ ng, 2 ].max
         | 
| 1622 | 
            +
                    fmt = "%.#{ng}g"
         | 
| 1623 | 
            +
                  else
         | 
| 1624 | 
            +
                    nf = [ -least_order, 0].max
         | 
| 1625 | 
            +
                    fmt = "%.#{nf}f"
         | 
| 1626 | 
            +
                  end
         | 
| 1627 | 
            +
                  sprintf(fmt,x).sub(/\.0*$/,'')
         | 
| 1628 | 
            +
                end
         | 
| 1629 | 
            +
             | 
| 1630 | 
            +
                def color_bar(options=nil)
         | 
| 1631 | 
            +
             | 
| 1632 | 
            +
                  # < set parameters >
         | 
| 1633 | 
            +
                  opt = @@color_bar_options.interpret(options)
         | 
| 1634 | 
            +
                  lsetx = DCL.uwqgxz
         | 
| 1635 | 
            +
                  lsety = DCL.uwqgyz
         | 
| 1636 | 
            +
             | 
| 1637 | 
            +
                  rmiss = DCL.glrget('rmiss')
         | 
| 1638 | 
            +
             | 
| 1639 | 
            +
                  levels = opt['levels']
         | 
| 1640 | 
            +
                  patterns = opt['patterns']
         | 
| 1641 | 
            +
             | 
| 1642 | 
            +
                  if (levels.nil? && !patterns.nil?) || (!levels.nil? && patterns.nil?)
         | 
| 1643 | 
            +
                    raise "levels and patterns must be set at same time\n"
         | 
| 1644 | 
            +
                  end
         | 
| 1645 | 
            +
             | 
| 1646 | 
            +
                  landscape = opt["landscape"] || !opt["portrait"]
         | 
| 1647 | 
            +
                  portrait  = ! landscape
         | 
| 1648 | 
            +
             | 
| 1649 | 
            +
                  if !levels.nil?
         | 
| 1650 | 
            +
                    ue_set_tone(levels,patterns)
         | 
| 1651 | 
            +
                  end
         | 
| 1652 | 
            +
             | 
| 1653 | 
            +
                  labels_ud = opt["labels_ud"]
         | 
| 1654 | 
            +
                  if !labels_ud.nil?
         | 
| 1655 | 
            +
                    if labels_ud.class != Array
         | 
| 1656 | 
            +
                      raise ArgumentError,"'labels_ud' must be an Array of String"
         | 
| 1657 | 
            +
                    elsif labels_ud.size == 0
         | 
| 1658 | 
            +
                      raise ArgumentError,"'labels_ud' must be an Array of String"
         | 
| 1659 | 
            +
                    else
         | 
| 1660 | 
            +
                      labels_ud.each do |lbl_ud|
         | 
| 1661 | 
            +
                        if lbl_ud.class != String
         | 
| 1662 | 
            +
                          raise ArgumentError,"'labels_ud' must be an Array of String"
         | 
| 1663 | 
            +
                        end
         | 
| 1664 | 
            +
                      end
         | 
| 1665 | 
            +
                    end
         | 
| 1666 | 
            +
                  end
         | 
| 1667 | 
            +
             | 
| 1668 | 
            +
                  if opt["index"]
         | 
| 1669 | 
            +
                    index = opt["index"]
         | 
| 1670 | 
            +
                    index = 1 if index <= 0
         | 
| 1671 | 
            +
                  else
         | 
| 1672 | 
            +
                    index = DCL::uziget("indext2")
         | 
| 1673 | 
            +
                  end
         | 
| 1674 | 
            +
                  indext1_bk = DCL::uziget("indext1")
         | 
| 1675 | 
            +
                  indext2_bk = DCL::uziget("indext2")
         | 
| 1676 | 
            +
                  DCL::uziset("indext1",index)
         | 
| 1677 | 
            +
                  DCL::uziset("indext2",index)
         | 
| 1678 | 
            +
             | 
| 1679 | 
            +
                  if opt["charindex"]
         | 
| 1680 | 
            +
                    charindex = opt["charindex"]
         | 
| 1681 | 
            +
                    charindex = 1 if charindex <= 0
         | 
| 1682 | 
            +
                  else
         | 
| 1683 | 
            +
                    charindex = DCL::uziget("indexl1")
         | 
| 1684 | 
            +
                  end
         | 
| 1685 | 
            +
                  indexl1_bk = DCL::uziget("indexl1")
         | 
| 1686 | 
            +
                  DCL::uziset("indexl1",charindex)
         | 
| 1687 | 
            +
             | 
| 1688 | 
            +
                  charfact = opt["charfact"]
         | 
| 1689 | 
            +
                  rsizel1_bk = DCL::uzrget("rsizel1")
         | 
| 1690 | 
            +
                  DCL::uzrset("rsizel1",charfact*rsizel1_bk)
         | 
| 1691 | 
            +
             | 
| 1692 | 
            +
                  nton = DCL::ueqntl
         | 
| 1693 | 
            +
                  if nton==0
         | 
| 1694 | 
            +
                    raise "no tone patern was set\n"
         | 
| 1695 | 
            +
                  end
         | 
| 1696 | 
            +
                  lev1 = Array.new
         | 
| 1697 | 
            +
                  lev2 = Array.new
         | 
| 1698 | 
            +
                  patterns = Array.new if !opt['patterns']
         | 
| 1699 | 
            +
                  for n in 0..nton-1
         | 
| 1700 | 
            +
                    tlev1,tlev2,ipat = DCL::ueqtlv(n+1)
         | 
| 1701 | 
            +
                    lev1.push(tlev1)
         | 
| 1702 | 
            +
                    lev2.push(tlev2)
         | 
| 1703 | 
            +
                    patterns.push(ipat) if !opt['patterns']
         | 
| 1704 | 
            +
                  end
         | 
| 1705 | 
            +
             | 
| 1706 | 
            +
                  #levels = lev1+lev2
         | 
| 1707 | 
            +
                  #levels = levels.uniq.sort
         | 
| 1708 | 
            +
                  #levels.delete(rmiss)
         | 
| 1709 | 
            +
                  #if levels.ne(levels.sort).any?
         | 
| 1710 | 
            +
                  #  raise "levels is not in order\n"
         | 
| 1711 | 
            +
                  #end
         | 
| 1712 | 
            +
             | 
| 1713 | 
            +
                  levels = lev1.push(lev2[-1]) if !levels
         | 
| 1714 | 
            +
                  levels = NArray.to_na(levels) if levels.is_a?(Array)
         | 
| 1715 | 
            +
                  patterns = NArray.to_na(patterns) if patterns.is_a?(Array)
         | 
| 1716 | 
            +
             | 
| 1717 | 
            +
                  vx1, vx2, vy1, vy2 = DCL.sgqvpt
         | 
| 1718 | 
            +
             | 
| 1719 | 
            +
                  if opt['log']
         | 
| 1720 | 
            +
                    lv = levels[levels.ne(rmiss).where]
         | 
| 1721 | 
            +
                    if lv.length >= 4 && lv[0]*lv[-1]<0
         | 
| 1722 | 
            +
                      iturn = 0
         | 
| 1723 | 
            +
                      for i in 0...levels.length
         | 
| 1724 | 
            +
                        if levels[i] != rmiss
         | 
| 1725 | 
            +
                          if levels[i]*lv[0] < 0
         | 
| 1726 | 
            +
                            iturn = i
         | 
| 1727 | 
            +
                            break
         | 
| 1728 | 
            +
                          end
         | 
| 1729 | 
            +
                        end
         | 
| 1730 | 
            +
                      end
         | 
| 1731 | 
            +
                      opt['vlength'] /= 2
         | 
| 1732 | 
            +
                      vc0 = opt['vcent'] || ( portrait && (vy1+vy2)/2) || (vx1+vx2)/2
         | 
| 1733 | 
            +
             | 
| 1734 | 
            +
                      opt["voff"] ||=
         | 
| 1735 | 
            +
                            DCL.uzrget('pad1')*DCL::uzrget("rsizec2") +
         | 
| 1736 | 
            +
                           ( portrait ? DCL.uzrget('roffyr') : - DCL.uzrget('roffxb') )
         | 
| 1737 | 
            +
             | 
| 1738 | 
            +
                      vsep2 = 0.02
         | 
| 1739 | 
            +
             | 
| 1740 | 
            +
                      opt['levels']   = levels[0..iturn-1]
         | 
| 1741 | 
            +
                      opt['patterns'] = patterns[0..iturn-2]
         | 
| 1742 | 
            +
                      opt['vcent'] = vc0 - opt['vlength']/2 - vsep2
         | 
| 1743 | 
            +
                      units = opt['units']
         | 
| 1744 | 
            +
                      opt['units'] = nil
         | 
| 1745 | 
            +
                      color_bar(opt)
         | 
| 1746 | 
            +
             | 
| 1747 | 
            +
                      opt['levels']   = levels[iturn..-1]
         | 
| 1748 | 
            +
                      opt['patterns'] = patterns[iturn..-1]
         | 
| 1749 | 
            +
                      opt['vcent'] = vc0 + opt['vlength']/2 + vsep2
         | 
| 1750 | 
            +
                      opt['units'] = units
         | 
| 1751 | 
            +
                      color_bar(opt)
         | 
| 1752 | 
            +
             | 
| 1753 | 
            +
                      # fill between the two bars
         | 
| 1754 | 
            +
                      if portrait
         | 
| 1755 | 
            +
                        x1 = vx2 + opt["voff"]
         | 
| 1756 | 
            +
                        x2 = x1 + opt['vwidth']
         | 
| 1757 | 
            +
                        y1 = vc0 - vsep2
         | 
| 1758 | 
            +
                        y2 = vc0 + vsep2
         | 
| 1759 | 
            +
                      else
         | 
| 1760 | 
            +
                        x1 = vc0 - vsep2
         | 
| 1761 | 
            +
                        x2 = vc0 + vsep2
         | 
| 1762 | 
            +
                        y1 = vy1 - opt["voff"]
         | 
| 1763 | 
            +
                        y2 = y1 - opt['vwidth']
         | 
| 1764 | 
            +
                      end
         | 
| 1765 | 
            +
                      bk = DCLExt.sg_set_params({'lclip'=>false})
         | 
| 1766 | 
            +
                      DCL.sgtnzv([x1,x2,x2,x1],[y1,y1,y2,y2],patterns[iturn-1])
         | 
| 1767 | 
            +
                      DCL.sgplzv([x1,x2,x2,x1,x1],[y1,y1,y2,y2,y1],1,3)
         | 
| 1768 | 
            +
                      DCLExt.sg_set_params(bk)
         | 
| 1769 | 
            +
                      return
         | 
| 1770 | 
            +
                    end
         | 
| 1771 | 
            +
                  end
         | 
| 1772 | 
            +
             | 
| 1773 | 
            +
                  if levels.length <= 1
         | 
| 1774 | 
            +
                    $stderr.print( "WARNING #{__FILE__}:#{__LINE__}: # of levels <= 1. No color bar is drawn." )
         | 
| 1775 | 
            +
                    return
         | 
| 1776 | 
            +
                  end
         | 
| 1777 | 
            +
             | 
| 1778 | 
            +
                  # BACKUP CURRENT PARAMETERS
         | 
| 1779 | 
            +
                  itrsv = DCL::sgqtrn
         | 
| 1780 | 
            +
                  if itrsv <= 4
         | 
| 1781 | 
            +
                    ux1sv, ux2sv, uy1sv, uy2sv = DCL.sgqwnd
         | 
| 1782 | 
            +
                  elsif itrsv <= 9
         | 
| 1783 | 
            +
                    simfacsv, vxoffsv, vyoffsv = DCL.sgqsim
         | 
| 1784 | 
            +
                  else
         | 
| 1785 | 
            +
                    ux1sv, ux2sv, uy1sv, uy2sv = DCL.sgqwnd
         | 
| 1786 | 
            +
                    simfacsv, vxoffsv, vyoffsv = DCL.sgqsim
         | 
| 1787 | 
            +
                    #plxsv, plysv, plrotsv = DCL.sgqmpl()
         | 
| 1788 | 
            +
                    plxsv, plysv, plrotsv = DCL.umqcnt
         | 
| 1789 | 
            +
                    lglobesv = DCL::umpget('lglobe')
         | 
| 1790 | 
            +
                    grstxysv = %w(txmin txmax tymin tymax).map{|key| DCL::sgrget(key)}
         | 
| 1791 | 
            +
                  end
         | 
| 1792 | 
            +
                  # END OF BACKUP
         | 
| 1793 | 
            +
             | 
| 1794 | 
            +
                  vwidth = opt["vwidth"]
         | 
| 1795 | 
            +
                  vlength = opt["vlength"]
         | 
| 1796 | 
            +
             | 
| 1797 | 
            +
                  if portrait
         | 
| 1798 | 
            +
                    if !opt["left"]
         | 
| 1799 | 
            +
                      # left
         | 
| 1800 | 
            +
                      voff =  opt["voff"] ||
         | 
| 1801 | 
            +
                          DCL.uzrget('roffyr') + DCL.uzrget('pad1')*DCL::uzrget("rsizec2")
         | 
| 1802 | 
            +
                      vxmin = vx2 + voff
         | 
| 1803 | 
            +
                      vxmax = vx2 + voff + vwidth
         | 
| 1804 | 
            +
                    else
         | 
| 1805 | 
            +
                      # right
         | 
| 1806 | 
            +
                      voff =  opt["voff"] ? -opt["voff"] : \
         | 
| 1807 | 
            +
                          DCL.uzrget('roffyl') - DCL.uzrget('pad1')*DCL::uzrget("rsizec2")
         | 
| 1808 | 
            +
                      vxmax = vx1 + voff
         | 
| 1809 | 
            +
                      vxmin = vx1 + voff - vwidth
         | 
| 1810 | 
            +
                    end
         | 
| 1811 | 
            +
                    vymin =( opt["vcent"] ? opt["vcent"]-vlength/2 : vy1 )
         | 
| 1812 | 
            +
                    vymax =( opt["vcent"] ? opt["vcent"]+vlength/2 : vy1+vlength )
         | 
| 1813 | 
            +
                  else  ## landscape ##
         | 
| 1814 | 
            +
                    vxmin =( opt["vcent"] ? opt["vcent"]-vlength/2 : (vx1+vx2)/2-vlength/2 )
         | 
| 1815 | 
            +
                    vxmax =( opt["vcent"] ? opt["vcent"]+vlength/2 : (vx1+vx2)/2+vlength/2 )
         | 
| 1816 | 
            +
                    if opt["top"]
         | 
| 1817 | 
            +
                      # top
         | 
| 1818 | 
            +
                      voff =  opt["voff"] ||
         | 
| 1819 | 
            +
                           DCL.uzrget('roffxt') + DCL.uzrget('pad1')*DCL::uzrget("rsizec2")
         | 
| 1820 | 
            +
                      vymin = vy2 + voff
         | 
| 1821 | 
            +
                      vymax = vy2 + voff + vwidth
         | 
| 1822 | 
            +
                    else
         | 
| 1823 | 
            +
                      # bottom
         | 
| 1824 | 
            +
                      voff =  opt["voff"] ? -opt["voff"] : \
         | 
| 1825 | 
            +
                           DCL.uzrget('roffxb') - DCL.uzrget('pad1')*DCL::uzrget("rsizec2")
         | 
| 1826 | 
            +
                      vymax = vy1 + voff
         | 
| 1827 | 
            +
                      vymin = vy1 + voff - vwidth
         | 
| 1828 | 
            +
                    end
         | 
| 1829 | 
            +
                  end
         | 
| 1830 | 
            +
             | 
| 1831 | 
            +
                  min = levels[levels.ne(rmiss).where].min
         | 
| 1832 | 
            +
                  max = levels[levels.ne(rmiss).where].max
         | 
| 1833 | 
            +
                  if levels[0] == rmiss
         | 
| 1834 | 
            +
                    inf0 = true
         | 
| 1835 | 
            +
                    dummy1,dummy2,ipat0 = DCL::ueqtlv(1)
         | 
| 1836 | 
            +
                    return if levels.length==2
         | 
| 1837 | 
            +
                  else
         | 
| 1838 | 
            +
                    inf0 = false
         | 
| 1839 | 
            +
                  end
         | 
| 1840 | 
            +
                  if levels[-1] == rmiss
         | 
| 1841 | 
            +
                    inf1 = true
         | 
| 1842 | 
            +
                    dummy1,dummy2,ipat1 = DCL::ueqtlv(nton)
         | 
| 1843 | 
            +
                    return if levels.length==2
         | 
| 1844 | 
            +
                  else
         | 
| 1845 | 
            +
                    inf1 = false
         | 
| 1846 | 
            +
                  end
         | 
| 1847 | 
            +
             | 
| 1848 | 
            +
                  # < paint color tones >
         | 
| 1849 | 
            +
             | 
| 1850 | 
            +
                  lclip_bk = DCL::sglget("lclip")
         | 
| 1851 | 
            +
                  DCL::sglset("lclip", false)
         | 
| 1852 | 
            +
             | 
| 1853 | 
            +
                  inffact = opt["inffact"]
         | 
| 1854 | 
            +
                  if opt["constwidth"]
         | 
| 1855 | 
            +
             | 
| 1856 | 
            +
                    if inf0
         | 
| 1857 | 
            +
                      levels = levels[1..-1]
         | 
| 1858 | 
            +
                      patterns = patterns[1..-1]
         | 
| 1859 | 
            +
                    end
         | 
| 1860 | 
            +
                    if inf1
         | 
| 1861 | 
            +
                      levels = levels[0..-2]
         | 
| 1862 | 
            +
                      patterns = patterns[0..-2]
         | 
| 1863 | 
            +
                    end
         | 
| 1864 | 
            +
                    nlev = levels.length
         | 
| 1865 | 
            +
                    npat = patterns.length
         | 
| 1866 | 
            +
             | 
| 1867 | 
            +
                    if portrait
         | 
| 1868 | 
            +
                      vy = (NArray.sfloat(npat+1).indgen!)*(vymax-vymin)/npat + vymin
         | 
| 1869 | 
            +
             | 
| 1870 | 
            +
                      # paint color tones for infinity (with drawing frame)
         | 
| 1871 | 
            +
                      if inf0
         | 
| 1872 | 
            +
                        vy3 = [vymin, vymin-vwidth*inffact, vymin]
         | 
| 1873 | 
            +
                        vx3 = [vxmax, (vxmax+vxmin)/2, vxmin]
         | 
| 1874 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat0)
         | 
| 1875 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1876 | 
            +
                      end
         | 
| 1877 | 
            +
                      if inf1
         | 
| 1878 | 
            +
                        vy3 = [vymax, vymax+vwidth*inffact, vymax]
         | 
| 1879 | 
            +
                        vx3 = [vxmax, (vxmax+vxmin)/2, vxmin]
         | 
| 1880 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat1)
         | 
| 1881 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1882 | 
            +
                      end
         | 
| 1883 | 
            +
             | 
| 1884 | 
            +
                      # paint color tones for each range (with drawing long-side frame)
         | 
| 1885 | 
            +
                      for i in 0..npat-1
         | 
| 1886 | 
            +
                        DCL::sgtnzv([vxmin,vxmax,vxmax,vxmin],[vy[i],vy[i],vy[i+1],vy[i+1]],patterns[i])
         | 
| 1887 | 
            +
                        DCL::sgplzv([vxmin,vxmin],[vy[i],vy[i+1]],1,index)
         | 
| 1888 | 
            +
                        DCL::sgplzv([vxmax,vxmax],[vy[i],vy[i+1]],1,index)
         | 
| 1889 | 
            +
                      end
         | 
| 1890 | 
            +
             | 
| 1891 | 
            +
                    else ## landscape ##
         | 
| 1892 | 
            +
                      vx = (NArray.sfloat(npat+1).indgen!)*(vxmax-vxmin)/npat + vxmin
         | 
| 1893 | 
            +
             | 
| 1894 | 
            +
                      # paint color tones for infinity (with drawing frame)
         | 
| 1895 | 
            +
                      if inf0
         | 
| 1896 | 
            +
                        vx3 = [vxmin, vxmin-vwidth*inffact, vxmin]
         | 
| 1897 | 
            +
                        vy3 = [vymax, (vymax+vymin)/2, vymin]
         | 
| 1898 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat0)
         | 
| 1899 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1900 | 
            +
                      end
         | 
| 1901 | 
            +
                      if inf1
         | 
| 1902 | 
            +
                        vx3 = [vxmax, vxmax+vwidth*inffact, vxmax]
         | 
| 1903 | 
            +
                        vy3 = [vymax, (vymax+vymin)/2, vymin]
         | 
| 1904 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat1)
         | 
| 1905 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1906 | 
            +
                      end
         | 
| 1907 | 
            +
             | 
| 1908 | 
            +
                      # paint color tones for each range (with drawing long-side frame)
         | 
| 1909 | 
            +
                      for i in 0..npat-1
         | 
| 1910 | 
            +
                        DCL::sgtnzv([vx[i],vx[i],vx[i+1],vx[i+1]],[vymin,vymax,vymax,vymin],patterns[i])
         | 
| 1911 | 
            +
                        DCL::sgplzv([vx[i],vx[i+1]],[vymin,vymin],1,index)
         | 
| 1912 | 
            +
                        DCL::sgplzv([vx[i],vx[i+1]],[vymax,vymax],1,index)
         | 
| 1913 | 
            +
                      end
         | 
| 1914 | 
            +
                    end
         | 
| 1915 | 
            +
             | 
| 1916 | 
            +
                  else  ### opt["constwidth"] == false ###
         | 
| 1917 | 
            +
             | 
| 1918 | 
            +
                    # paint color tones for infinity (with drawing frame)
         | 
| 1919 | 
            +
                    if portrait
         | 
| 1920 | 
            +
                      if inf0
         | 
| 1921 | 
            +
                        vy3 = [vymin, vymin-vwidth*inffact, vymin]
         | 
| 1922 | 
            +
                        vx3 = [vxmax, (vxmax+vxmin)/2, vxmin]
         | 
| 1923 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat0)
         | 
| 1924 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1925 | 
            +
                      end
         | 
| 1926 | 
            +
                      if inf1
         | 
| 1927 | 
            +
                        vy3 = [vymax, vymax+vwidth*inffact, vymax]
         | 
| 1928 | 
            +
                        vx3 = [vxmax, (vxmax+vxmin)/2, vxmin]
         | 
| 1929 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat1)
         | 
| 1930 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1931 | 
            +
                      end
         | 
| 1932 | 
            +
                    else ## landscape ##
         | 
| 1933 | 
            +
                      if inf0
         | 
| 1934 | 
            +
                        vx3 = [vxmin, vxmin-vwidth*inffact, vxmin]
         | 
| 1935 | 
            +
                        vy3 = [vymax, (vymax+vymin)/2, vymin]
         | 
| 1936 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat0)
         | 
| 1937 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1938 | 
            +
                      end
         | 
| 1939 | 
            +
                      if inf1
         | 
| 1940 | 
            +
                        vx3 = [vxmax, vxmax+vwidth*inffact, vxmax]
         | 
| 1941 | 
            +
                        vy3 = [vymax, (vymax+vymin)/2, vymin]
         | 
| 1942 | 
            +
                        DCL.sgtnzv(vx3,vy3,ipat1)
         | 
| 1943 | 
            +
                        DCL.sgplzv(vx3,vy3,1,index)
         | 
| 1944 | 
            +
                      end
         | 
| 1945 | 
            +
                    end
         | 
| 1946 | 
            +
             | 
| 1947 | 
            +
                    # paint color tones for each range
         | 
| 1948 | 
            +
                    nbar = 100
         | 
| 1949 | 
            +
                    bar = NArray.float(nbar,2)
         | 
| 1950 | 
            +
                    for i in 0..nbar-1
         | 
| 1951 | 
            +
                      bar[i,true] = min + (max-min).to_f/(nbar-1)*i
         | 
| 1952 | 
            +
                    end
         | 
| 1953 | 
            +
             | 
| 1954 | 
            +
                    xb = DCL::uzlget("labelxb")
         | 
| 1955 | 
            +
                    yl = DCL::uzlget("labelyl")
         | 
| 1956 | 
            +
                    if portrait
         | 
| 1957 | 
            +
                      xmin = 0.0
         | 
| 1958 | 
            +
                      xmax = 1.0
         | 
| 1959 | 
            +
                      ymin = min
         | 
| 1960 | 
            +
                      ymax = max
         | 
| 1961 | 
            +
                      DCL::uzlset("labelxb",false)
         | 
| 1962 | 
            +
                      DCL::uzlset("labelyl",true)
         | 
| 1963 | 
            +
                      bar = bar.transpose(-1,0)
         | 
| 1964 | 
            +
                      DCL::uwsgxa([0,1])
         | 
| 1965 | 
            +
                      DCL::uwsgya(bar[0,true])
         | 
| 1966 | 
            +
                    else
         | 
| 1967 | 
            +
                      xmin = min
         | 
| 1968 | 
            +
                      xmax = max
         | 
| 1969 | 
            +
                      ymin = 0.0
         | 
| 1970 | 
            +
                      ymax = 1.0
         | 
| 1971 | 
            +
                      DCL::uzlset("labelxb",true)
         | 
| 1972 | 
            +
                      DCL::uzlset("labelyl",false)
         | 
| 1973 | 
            +
                      DCL::uwsgxa(bar[true,0])
         | 
| 1974 | 
            +
                      DCL::uwsgya([0,1])
         | 
| 1975 | 
            +
                    end
         | 
| 1976 | 
            +
             | 
| 1977 | 
            +
                    type = 1
         | 
| 1978 | 
            +
                    if opt["log"]
         | 
| 1979 | 
            +
                      type +=1
         | 
| 1980 | 
            +
                      type +=1 if !portrait
         | 
| 1981 | 
            +
                    end
         | 
| 1982 | 
            +
             | 
| 1983 | 
            +
                    DCL::grfig
         | 
| 1984 | 
            +
                    DCL::grsvpt(vxmin,vxmax,vymin,vymax)
         | 
| 1985 | 
            +
                    DCL::grswnd(xmin,xmax,ymin,ymax)
         | 
| 1986 | 
            +
                    DCL::grstrn(type)
         | 
| 1987 | 
            +
                    DCL::grstrf
         | 
| 1988 | 
            +
             | 
| 1989 | 
            +
                    DCL::uetone(bar)
         | 
| 1990 | 
            +
                    DCL.uwsgxz(false)
         | 
| 1991 | 
            +
                    DCL.uwsgyz(false)
         | 
| 1992 | 
            +
             | 
| 1993 | 
            +
                  end
         | 
| 1994 | 
            +
             | 
| 1995 | 
            +
                  # < set ticking and labeling levels >
         | 
| 1996 | 
            +
             | 
| 1997 | 
            +
                  if opt["labelintv"]
         | 
| 1998 | 
            +
                    labelintv = opt["labelintv"]
         | 
| 1999 | 
            +
                  else
         | 
| 2000 | 
            +
                    ntn = nton
         | 
| 2001 | 
            +
                    ntn -= 1 if inf0
         | 
| 2002 | 
            +
                    ntn -= 1 if inf1
         | 
| 2003 | 
            +
                    if portrait
         | 
| 2004 | 
            +
                      labelintv = (ntn-1) / 9  + 1
         | 
| 2005 | 
            +
                    else
         | 
| 2006 | 
            +
                      labelintv = (ntn-1) / 5  + 1
         | 
| 2007 | 
            +
                    end
         | 
| 2008 | 
            +
                  end
         | 
| 2009 | 
            +
                  if labelintv <= 0
         | 
| 2010 | 
            +
                    no_label = true
         | 
| 2011 | 
            +
                    labelintv = 1
         | 
| 2012 | 
            +
                  else
         | 
| 2013 | 
            +
                    no_label = false
         | 
| 2014 | 
            +
                  end
         | 
| 2015 | 
            +
             | 
| 2016 | 
            +
                  tickintv = opt["tickintv"]
         | 
| 2017 | 
            +
                  if tickintv <= 0
         | 
| 2018 | 
            +
                    no_tick = true
         | 
| 2019 | 
            +
                    tickintv = labelintv
         | 
| 2020 | 
            +
                  else
         | 
| 2021 | 
            +
                    no_tick = false
         | 
| 2022 | 
            +
                  end
         | 
| 2023 | 
            +
             | 
| 2024 | 
            +
                  eps = 1e-5
         | 
| 2025 | 
            +
                  dummy = -9.9e-38
         | 
| 2026 | 
            +
                  dz = dzp = dzc = dummy
         | 
| 2027 | 
            +
                  idu = Array.new
         | 
| 2028 | 
            +
                  (1...levels.length).each do |i|
         | 
| 2029 | 
            +
                    dzc = (levels[i] - levels[i-1]).abs
         | 
| 2030 | 
            +
                    if (dzc-dzp).abs <= eps * [dzc.abs,dzp.abs].max
         | 
| 2031 | 
            +
                      dz = dzc  # set dz if two consecutive inrements are the same
         | 
| 2032 | 
            +
                      idu.push( i-1 )
         | 
| 2033 | 
            +
                    end
         | 
| 2034 | 
            +
                    dzp = (levels[i] - levels[i-1]).abs
         | 
| 2035 | 
            +
                  end
         | 
| 2036 | 
            +
                  if idu.length > 0
         | 
| 2037 | 
            +
                    idumin = idu.min - 1
         | 
| 2038 | 
            +
                    idumax = idu.max + 1
         | 
| 2039 | 
            +
                  else
         | 
| 2040 | 
            +
                    idumin = 0
         | 
| 2041 | 
            +
                    idumax = levels.length-1
         | 
| 2042 | 
            +
                  end
         | 
| 2043 | 
            +
                  if dz != dummy
         | 
| 2044 | 
            +
            #        if idumin == 1 and levels[0] != rmiss
         | 
| 2045 | 
            +
            #          # to correct non-uniform intv at the beginning
         | 
| 2046 | 
            +
            #          levels[0] = levels[1] - dz
         | 
| 2047 | 
            +
            #          idumin = 0
         | 
| 2048 | 
            +
            #          min = levels[0]
         | 
| 2049 | 
            +
            #        end
         | 
| 2050 | 
            +
            #        if idumax == levels.length-2 and levels[-1] != rmiss
         | 
| 2051 | 
            +
            #          # to correct non-uniform intv at the end
         | 
| 2052 | 
            +
            #          levels[-1] = levels[-2] + dz
         | 
| 2053 | 
            +
            #          idumax = levels.length-1
         | 
| 2054 | 
            +
            #          max = levels[-1]
         | 
| 2055 | 
            +
            #        end
         | 
| 2056 | 
            +
                    # use the algorithm used in DCL.udgcla
         | 
| 2057 | 
            +
                    offs_tick = ( (-levels[idumin]/dz).round % tickintv + idumin ) % tickintv
         | 
| 2058 | 
            +
                    offs_label = ( (-levels[idumin]/dz).round % labelintv + idumin ) % labelintv
         | 
| 2059 | 
            +
                  else
         | 
| 2060 | 
            +
                    md = 0
         | 
| 2061 | 
            +
                    if ( (idx=levels.eq(0.0).where).length > 0 )
         | 
| 2062 | 
            +
                      md = idx[0] % labelintv
         | 
| 2063 | 
            +
                    else
         | 
| 2064 | 
            +
                      a = levels[0...([labelintv,levels.length].min)]
         | 
| 2065 | 
            +
                      b = a * 10**( -NMath.log10(a.abs).floor.min )
         | 
| 2066 | 
            +
                      (0...b.length).each{|i| md=i if (b[i].round-b[i]).abs < 1e-5 }
         | 
| 2067 | 
            +
                    end
         | 
| 2068 | 
            +
                    offs_tick = (md % tickintv)
         | 
| 2069 | 
            +
                    offs_label = md
         | 
| 2070 | 
            +
                  end
         | 
| 2071 | 
            +
             | 
| 2072 | 
            +
                  if levels.length >= 4
         | 
| 2073 | 
            +
                    lvmx = levels[1..-2].max
         | 
| 2074 | 
            +
                    lvmn = levels[1..-2].min
         | 
| 2075 | 
            +
                    dlv = (lvmx-lvmn) / (levels.length-3)
         | 
| 2076 | 
            +
                  elsif levels.length == 3 or levels.length == 2
         | 
| 2077 | 
            +
                    lvmn = lvmx = dlv = levels[1]
         | 
| 2078 | 
            +
                  else
         | 
| 2079 | 
            +
                    lvmn = lvmx = dlv = levels[0]
         | 
| 2080 | 
            +
                  end
         | 
| 2081 | 
            +
             | 
| 2082 | 
            +
                  # < draw units, title, labels, and tick lines>
         | 
| 2083 | 
            +
             | 
| 2084 | 
            +
                  if opt["constwidth"]
         | 
| 2085 | 
            +
             | 
| 2086 | 
            +
                    if !no_label && labels_ud
         | 
| 2087 | 
            +
                      ilbl = 0
         | 
| 2088 | 
            +
                      for i in 0..nlev-1
         | 
| 2089 | 
            +
                        if (i % labelintv) == offs_label
         | 
| 2090 | 
            +
                          ilbl += 1
         | 
| 2091 | 
            +
                        end
         | 
| 2092 | 
            +
                      end
         | 
| 2093 | 
            +
                      if labels_ud.size != ilbl
         | 
| 2094 | 
            +
                        raise ArgumentError, "'labels_ud' must be an Array of length==#{ilbl} in this case"
         | 
| 2095 | 
            +
                      end
         | 
| 2096 | 
            +
                    end
         | 
| 2097 | 
            +
             | 
| 2098 | 
            +
                    if portrait
         | 
| 2099 | 
            +
             | 
| 2100 | 
            +
                      if voff > 0
         | 
| 2101 | 
            +
                        cent = -1
         | 
| 2102 | 
            +
                        vxlabel = vxmax+DCL::uzrget('pad1')*DCL::uzrget('rsizel1')
         | 
| 2103 | 
            +
                        # title
         | 
| 2104 | 
            +
                        DCL::sgtxzr(vxmin-(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), (vymin+vymax)/2.0+opt['title_voff'], opt['title'], DCL::uzrget('rsizel1'), 90, 0, charindex) if opt['title']
         | 
| 2105 | 
            +
                        # units
         | 
| 2106 | 
            +
                        DCL::sgtxzr(vxmax+DCL::uzrget('pad1')*DCL::uzrget('rsizel1'), vymax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], opt['units'], DCL::uzrget('rsizel1'), 0, -1, charindex) if opt['units']
         | 
| 2107 | 
            +
                      else
         | 
| 2108 | 
            +
                        cent = 1
         | 
| 2109 | 
            +
                        vxlabel = vxmin-DCL::uzrget('pad1')*DCL::uzrget('rsizel1')
         | 
| 2110 | 
            +
                        # title
         | 
| 2111 | 
            +
                        DCL::sgtxzr(vxmax+(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), (vymin+vymax)/2.0-opt['title_voff'], opt['title'], DCL::uzrget('rsizel1'), -90, 0, charindex) if opt['title']
         | 
| 2112 | 
            +
                        # units
         | 
| 2113 | 
            +
                        DCL::sgtxzr(vxmin-DCL::uzrget('pad1')*DCL::uzrget('rsizel1'), vymax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], opt['units'], DCL::uzrget('rsizel1'), 0, 1, charindex) if opt['units']
         | 
| 2114 | 
            +
                      end
         | 
| 2115 | 
            +
             | 
| 2116 | 
            +
                      ilbl_ud = 0
         | 
| 2117 | 
            +
                      for i in 0..nlev-1
         | 
| 2118 | 
            +
                        # labels
         | 
| 2119 | 
            +
                        if !no_label && (i % labelintv) == offs_label
         | 
| 2120 | 
            +
                          if labels_ud
         | 
| 2121 | 
            +
                            char = labels_ud[ilbl_ud]
         | 
| 2122 | 
            +
                            DCL::sgtxzr(vxlabel,vy[i],char,DCL::uzrget('rsizel1'),0,cent,charindex)
         | 
| 2123 | 
            +
                            ilbl_ud += 1
         | 
| 2124 | 
            +
                          else
         | 
| 2125 | 
            +
                            begin
         | 
| 2126 | 
            +
                              if(opt['chval_fmt'])
         | 
| 2127 | 
            +
                                char = DCL::chval(opt['chval_fmt'],levels[i])
         | 
| 2128 | 
            +
                              else
         | 
| 2129 | 
            +
                                char = sprintf_level(levels[i],lvmx,lvmn,dlv)
         | 
| 2130 | 
            +
                              end
         | 
| 2131 | 
            +
                              DCL::sgtxzr(vxlabel,vy[i],char,DCL::uzrget('rsizel1'),0,cent,charindex)
         | 
| 2132 | 
            +
                            rescue
         | 
| 2133 | 
            +
                              DCL::sgtxzr(vxlabel,vy[i],levels[i].to_s,DCL::uzrget('rsizel1'),0,cent,charindex)
         | 
| 2134 | 
            +
                            end
         | 
| 2135 | 
            +
                          end
         | 
| 2136 | 
            +
                        end
         | 
| 2137 | 
            +
                        # tick lines and short-side frame
         | 
| 2138 | 
            +
                        if (!no_tick && (i % tickintv) == offs_tick) || (!inf0 && i == 0) || (!inf1 && i == nlev-1)
         | 
| 2139 | 
            +
                          DCL::sgplzv([vxmin,vxmax],[vy[i],vy[i]],1,index)
         | 
| 2140 | 
            +
                        end
         | 
| 2141 | 
            +
                      end
         | 
| 2142 | 
            +
             | 
| 2143 | 
            +
                    else  ## landscape ##
         | 
| 2144 | 
            +
                      if voff > 0
         | 
| 2145 | 
            +
                        vylabel = vymax+(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1')
         | 
| 2146 | 
            +
                        # title
         | 
| 2147 | 
            +
                        DCL::sgtxzr((vxmin+vxmax)/2.0+opt['title_voff'], vymin-(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['title'], DCL::uzrget('rsizel1'), 0, 0, charindex) if opt['title']
         | 
| 2148 | 
            +
                        # units
         | 
| 2149 | 
            +
                        DCL::sgtxzr(vxmax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], vymax+(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['units'], DCL::uzrget('rsizel1'), 0, -1, charindex) if opt['units']
         | 
| 2150 | 
            +
                      else
         | 
| 2151 | 
            +
                        vylabel = vymin-(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1')
         | 
| 2152 | 
            +
                        # title
         | 
| 2153 | 
            +
                        DCL::sgtxzr((vxmin+vxmax)/2.0+opt['title_voff'], vymax+(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['title'], DCL::uzrget('rsizel1'), 0, 0, charindex) if opt['title']
         | 
| 2154 | 
            +
                        # units
         | 
| 2155 | 
            +
                        DCL::sgtxzr(vxmax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], vymin-(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['units'], DCL::uzrget('rsizel1'), 0, -1, charindex) if opt['units']
         | 
| 2156 | 
            +
                      end
         | 
| 2157 | 
            +
             | 
| 2158 | 
            +
                      ilbl_ud = 0
         | 
| 2159 | 
            +
                      for i in 0..nlev-1
         | 
| 2160 | 
            +
                        # labels
         | 
| 2161 | 
            +
                        if !no_label && (i % labelintv) == offs_label
         | 
| 2162 | 
            +
                          if labels_ud
         | 
| 2163 | 
            +
                            char = labels_ud[ilbl_ud]
         | 
| 2164 | 
            +
                            DCL::sgtxzr(vx[i],vylabel,char,DCL::uzrget('rsizel1'),0,0,charindex)
         | 
| 2165 | 
            +
                            ilbl_ud += 1
         | 
| 2166 | 
            +
                          else
         | 
| 2167 | 
            +
                            begin
         | 
| 2168 | 
            +
                              if(opt['chval_fmt'])
         | 
| 2169 | 
            +
                                char = DCL::chval(opt['chval_fmt'],levels[i])
         | 
| 2170 | 
            +
                              else
         | 
| 2171 | 
            +
                                char = sprintf_level(levels[i],lvmx,lvmn,dlv)
         | 
| 2172 | 
            +
                              end
         | 
| 2173 | 
            +
                              DCL::sgtxzr(vx[i],vylabel,char,DCL::uzrget('rsizel1'),0,0,charindex)
         | 
| 2174 | 
            +
                            rescue
         | 
| 2175 | 
            +
                              DCL::sgtxzr(vx[i],vylabel,levels[i].to_s,DCL::uzrget('rsizel1'),0,0,charindex)
         | 
| 2176 | 
            +
                            end
         | 
| 2177 | 
            +
                          end
         | 
| 2178 | 
            +
                        end
         | 
| 2179 | 
            +
                        # tick lines and short-side frame
         | 
| 2180 | 
            +
                        if (!no_tick && (i % tickintv) == offs_tick) || (!inf0 && i == 0) || (!inf1 && i == nlev-1)
         | 
| 2181 | 
            +
                          DCL::sgplzv([vx[i],vx[i]],[vymin,vymax],1,index)
         | 
| 2182 | 
            +
                        end
         | 
| 2183 | 
            +
                      end
         | 
| 2184 | 
            +
                    end
         | 
| 2185 | 
            +
             | 
| 2186 | 
            +
                  else  ### opt["constwidth"] == false ###
         | 
| 2187 | 
            +
             | 
| 2188 | 
            +
                    inner_bk = DCL::uziget('inner')
         | 
| 2189 | 
            +
                    uz_set_params('inner'=>1)
         | 
| 2190 | 
            +
             | 
| 2191 | 
            +
                    tick1 = Array.new
         | 
| 2192 | 
            +
                    tick2 = Array.new
         | 
| 2193 | 
            +
                    for i in 0..levels.length-1
         | 
| 2194 | 
            +
            #          if i>=idumin && i<=idumax && levels[i]!=rmiss
         | 
| 2195 | 
            +
                      if levels[i]!=rmiss
         | 
| 2196 | 
            +
                        tick1.push(levels[i]) if (i % tickintv) == offs_tick
         | 
| 2197 | 
            +
                        tick2.push(levels[i]) if (i % labelintv) == offs_label
         | 
| 2198 | 
            +
                      end
         | 
| 2199 | 
            +
                    end
         | 
| 2200 | 
            +
             | 
| 2201 | 
            +
                    if portrait
         | 
| 2202 | 
            +
             | 
| 2203 | 
            +
                      if voff > 0
         | 
| 2204 | 
            +
                        before = uz_set_params('labelyl'=>false,'labelyr'=>true,'icentyr'=>-1.0)
         | 
| 2205 | 
            +
                      else
         | 
| 2206 | 
            +
                        before = uz_set_params('labelyl'=>true,'labelyr'=>false,'icentyl'=>1.0)
         | 
| 2207 | 
            +
                      end
         | 
| 2208 | 
            +
             | 
| 2209 | 
            +
                      # draw frame, tick lines, and labels
         | 
| 2210 | 
            +
                      cfmt_bk = DCL::uyqfmt
         | 
| 2211 | 
            +
                      if opt["log"]
         | 
| 2212 | 
            +
                        fmt = opt['chval_fmt'] || "b"
         | 
| 2213 | 
            +
                      else
         | 
| 2214 | 
            +
                        fmt = opt['chval_fmt'] || level_chval_fmt(lvmx,lvmn,dlv)
         | 
| 2215 | 
            +
                      end
         | 
| 2216 | 
            +
                      DCL::uysfmt(fmt)
         | 
| 2217 | 
            +
             | 
| 2218 | 
            +
                      rsizet1_bk = DCL::uzrget("rsizet1")
         | 
| 2219 | 
            +
                      rsizet2_bk = DCL::uzrget("rsizet2")
         | 
| 2220 | 
            +
                      uz_set_params('rsizet1'=>vwidth,'rsizet2'=>0.0)
         | 
| 2221 | 
            +
                      if no_label
         | 
| 2222 | 
            +
                        nl_labelxt = DCL::uzlget('labelxt')
         | 
| 2223 | 
            +
                        nl_labelxb = DCL::uzlget('labelxb')
         | 
| 2224 | 
            +
                        nl_labelyl = DCL::uzlget('labelyl')
         | 
| 2225 | 
            +
                        nl_labelyr = DCL::uzlget('labelyr')
         | 
| 2226 | 
            +
                        uz_set_params('labelxt'=>false,'labelxb'=>false,'labelyl'=>false,'labelyr'=>false)
         | 
| 2227 | 
            +
                      end
         | 
| 2228 | 
            +
                      if no_tick
         | 
| 2229 | 
            +
                        nt_rsizet1 = DCL::uzrget('rsizet1')
         | 
| 2230 | 
            +
                        DCL::uzrset("rsizet1",0.0)
         | 
| 2231 | 
            +
                      end
         | 
| 2232 | 
            +
             | 
| 2233 | 
            +
                      if labels_ud
         | 
| 2234 | 
            +
                        if labels_ud.size != tick2.size
         | 
| 2235 | 
            +
                          raise ArgumentError, "'labels_ud' must be an Array of length==#{tick2.size} in this case"
         | 
| 2236 | 
            +
                        end
         | 
| 2237 | 
            +
                        nc = labels_ud.collect{|c| c.size}.max
         | 
| 2238 | 
            +
                        DCL::uyaxlb("l",tick1,tick2,labels_ud,nc)
         | 
| 2239 | 
            +
                        DCL::uyaxlb("r",tick1,tick2,labels_ud,nc)
         | 
| 2240 | 
            +
                      else
         | 
| 2241 | 
            +
                        DCL::uyaxnm("l",tick1,tick2)
         | 
| 2242 | 
            +
                        DCL::uyaxnm("r",tick1,tick2)
         | 
| 2243 | 
            +
                      end
         | 
| 2244 | 
            +
                      DCL::uxaxdv("b",1,index) if !inf0
         | 
| 2245 | 
            +
                      DCL::uxaxdv("t",1,index) if !inf1
         | 
| 2246 | 
            +
             | 
| 2247 | 
            +
                      if no_tick
         | 
| 2248 | 
            +
                        DCL::uzrset("rsizet1",nt_rsizet1)
         | 
| 2249 | 
            +
                      end
         | 
| 2250 | 
            +
                      if no_label
         | 
| 2251 | 
            +
                        uz_set_params('labelxt'=>nl_labelxt,'labelxb'=>nl_labelxb,'labelyl'=>nl_labelyl,'labelyr'=>nl_labelyr)
         | 
| 2252 | 
            +
                      end
         | 
| 2253 | 
            +
                      DCL::uzrset("rsizet1",rsizet1_bk)
         | 
| 2254 | 
            +
                      DCL::uzrset("rsizet2",rsizet2_bk)
         | 
| 2255 | 
            +
             | 
| 2256 | 
            +
                      DCL::uysfmt(cfmt_bk)
         | 
| 2257 | 
            +
             | 
| 2258 | 
            +
                      if voff > 0
         | 
| 2259 | 
            +
                        # title
         | 
| 2260 | 
            +
                        DCL::sgtxzr(vxmin-(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), (vymin+vymax)/2.0+opt['title_voff'], opt['title'], DCL::uzrget('rsizel1'), 90, 0, charindex) if opt["title"]
         | 
| 2261 | 
            +
                        # units
         | 
| 2262 | 
            +
                        DCL::sgtxzr(vxmax+DCL::uzrget('pad1')*DCL::uzrget('rsizel1'), vymax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], opt['units'], DCL::uzrget('rsizel1'), 0, -1, charindex) if opt['units']
         | 
| 2263 | 
            +
                      else
         | 
| 2264 | 
            +
                        # title
         | 
| 2265 | 
            +
                        DCL::sgtxzr(vxmax+(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), (vymin+vymax)/2.0-opt['title_voff'], opt['title'], DCL::uzrget('rsizel1'), -90, 0, charindex) if opt["title"]
         | 
| 2266 | 
            +
                        # units
         | 
| 2267 | 
            +
                        DCL::sgtxzr(vxmin-DCL::uzrget('pad1')*DCL::uzrget('rsizel1'), vymax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], opt['units'], DCL::uzrget('rsizel1'), 0, 1, charindex) if opt['units']
         | 
| 2268 | 
            +
                      end
         | 
| 2269 | 
            +
             | 
| 2270 | 
            +
                      uz_set_params(before)
         | 
| 2271 | 
            +
             | 
| 2272 | 
            +
                    else  ## landscape ##
         | 
| 2273 | 
            +
             | 
| 2274 | 
            +
                      if voff > 0
         | 
| 2275 | 
            +
                        before = uz_set_params('labelxt'=>true,'labelxb'=>false)
         | 
| 2276 | 
            +
                      else
         | 
| 2277 | 
            +
                        before = uz_set_params('labelxt'=>false,'labelxb'=>true)
         | 
| 2278 | 
            +
                      end
         | 
| 2279 | 
            +
             | 
| 2280 | 
            +
                      # draw frame, tick lines, and labels
         | 
| 2281 | 
            +
                      cfmt_bk = DCL::uxqfmt
         | 
| 2282 | 
            +
                      if opt["log"]
         | 
| 2283 | 
            +
                        fmt = opt['chval_fmt'] || "b"
         | 
| 2284 | 
            +
                      else
         | 
| 2285 | 
            +
                        fmt = opt['chval_fmt'] || level_chval_fmt(lvmx,lvmn,dlv)
         | 
| 2286 | 
            +
                      end
         | 
| 2287 | 
            +
                      DCL::uxsfmt(fmt)
         | 
| 2288 | 
            +
             | 
| 2289 | 
            +
                      rsizet1_bk = DCL::uzrget("rsizet1")
         | 
| 2290 | 
            +
                      rsizet2_bk = DCL::uzrget("rsizet2")
         | 
| 2291 | 
            +
                      uz_set_params('rsizet1'=>vwidth,'rsizet2'=>0.0)
         | 
| 2292 | 
            +
                      if no_label
         | 
| 2293 | 
            +
                        nl_labelxt = DCL::uzlget('labelxt')
         | 
| 2294 | 
            +
                        nl_labelxb = DCL::uzlget('labelxb')
         | 
| 2295 | 
            +
                        nl_labelyl = DCL::uzlget('labelyl')
         | 
| 2296 | 
            +
                        nl_labelyr = DCL::uzlget('labelyr')
         | 
| 2297 | 
            +
                        uz_set_params('labelxt'=>false,'labelxb'=>false,'labelyl'=>false,'labelyr'=>false)
         | 
| 2298 | 
            +
                      end
         | 
| 2299 | 
            +
                      if no_tick
         | 
| 2300 | 
            +
                        nt_rsizet1 = DCL::uzrget('rsizet1')
         | 
| 2301 | 
            +
                        DCL::uzrset("rsizet1",0.0)
         | 
| 2302 | 
            +
                      end
         | 
| 2303 | 
            +
             | 
| 2304 | 
            +
                      if labels_ud
         | 
| 2305 | 
            +
                        if labels_ud.size != tick2.size
         | 
| 2306 | 
            +
                          raise ArgumentError, "'labels_ud' must be an Array of length==#{tick2.size} in this case"
         | 
| 2307 | 
            +
                        end
         | 
| 2308 | 
            +
                        nc = labels_ud.collect{|c| c.size}.max
         | 
| 2309 | 
            +
                        DCL::uxaxlb("t",tick1,tick2,labels_ud,nc)
         | 
| 2310 | 
            +
                        DCL::uxaxlb("b",tick1,tick2,labels_ud,nc)
         | 
| 2311 | 
            +
                      else
         | 
| 2312 | 
            +
                        DCL::uxaxnm("t",tick1,tick2)
         | 
| 2313 | 
            +
                        DCL::uxaxnm("b",tick1,tick2)
         | 
| 2314 | 
            +
                      end
         | 
| 2315 | 
            +
                      DCL::uyaxdv("l",1,index) if !inf0
         | 
| 2316 | 
            +
                      DCL::uyaxdv("r",1,index) if !inf1
         | 
| 2317 | 
            +
             | 
| 2318 | 
            +
                      if no_tick
         | 
| 2319 | 
            +
                        DCL::uzrset("rsizet1",nt_rsizet1)
         | 
| 2320 | 
            +
                      end
         | 
| 2321 | 
            +
                      if no_label
         | 
| 2322 | 
            +
                        uz_set_params('labelxt'=>nl_labelxt,'labelxb'=>nl_labelxb,'labelyl'=>nl_labelyl,'labelyr'=>nl_labelyr)
         | 
| 2323 | 
            +
                      end
         | 
| 2324 | 
            +
                      DCL::uzrset("rsizet1",rsizet1_bk)
         | 
| 2325 | 
            +
                      DCL::uzrset("rsizet2",rsizet2_bk)
         | 
| 2326 | 
            +
             | 
| 2327 | 
            +
                      DCL::uxsfmt(cfmt_bk)
         | 
| 2328 | 
            +
             | 
| 2329 | 
            +
                      if voff > 0
         | 
| 2330 | 
            +
                        # title
         | 
| 2331 | 
            +
                        DCL::sgtxzr((vxmin+vxmax)/2.0+opt['title_voff'], vymin-(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['title'], DCL::uzrget('rsizel1'), 0, 0, charindex) if opt["title"]
         | 
| 2332 | 
            +
                        # units
         | 
| 2333 | 
            +
                        DCL::sgtxzr(vxmax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], vymax+(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['units'], DCL::uzrget('rsizel1'), 0, -1, charindex) if opt['units']
         | 
| 2334 | 
            +
                      else
         | 
| 2335 | 
            +
                        # title
         | 
| 2336 | 
            +
                        DCL::sgtxzr((vxmin+vxmax)/2.0+opt['title_voff'], vymax+(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['title'], DCL::uzrget('rsizel1'), 0, 0, charindex) if opt["title"]
         | 
| 2337 | 
            +
                        # units
         | 
| 2338 | 
            +
                        DCL::sgtxzr(vxmax+2.6*DCL::uzrget('rsizel1')+opt['units_voff'], vymin-(0.5+DCL::uzrget('pad1'))*DCL::uzrget('rsizel1'), opt['units'], DCL::uzrget('rsizel1'), 0, -1, charindex) if opt['units']
         | 
| 2339 | 
            +
                      end
         | 
| 2340 | 
            +
             | 
| 2341 | 
            +
                      uz_set_params(before)
         | 
| 2342 | 
            +
             | 
| 2343 | 
            +
                    end
         | 
| 2344 | 
            +
             | 
| 2345 | 
            +
                    DCL::uzlset("labelxb",xb)
         | 
| 2346 | 
            +
                    DCL::uzlset("labelyl",yl)
         | 
| 2347 | 
            +
             | 
| 2348 | 
            +
                    DCL::grsvpt(vx1,vx2,vy1,vy2)
         | 
| 2349 | 
            +
                    if itrsv <= 4
         | 
| 2350 | 
            +
                      DCL::grswnd(ux1sv, ux2sv, uy1sv, uy2sv)
         | 
| 2351 | 
            +
                      DCL::grstrn(itrsv)
         | 
| 2352 | 
            +
                    elsif itrsv <= 9
         | 
| 2353 | 
            +
                      DCL::sgssim(simfacsv,vxoffsv,vyoffsv)
         | 
| 2354 | 
            +
                      DCL::grstrn(itrsv)
         | 
| 2355 | 
            +
                    ### TENTATIVE WORKAROUND (2012/2/9)
         | 
| 2356 | 
            +
                    elsif itrsv <= 34
         | 
| 2357 | 
            +
                      DCL::grswnd(ux1sv, ux2sv, uy1sv, uy2sv)
         | 
| 2358 | 
            +
                      DCL.sgstrn(itrsv)
         | 
| 2359 | 
            +
                      DCL.umpset('lglobe', lglobesv)
         | 
| 2360 | 
            +
                      DCL::grstxy(*grstxysv)
         | 
| 2361 | 
            +
                      DCL.umscnt(plxsv,plysv,plrotsv)
         | 
| 2362 | 
            +
                      DCL.umpfit
         | 
| 2363 | 
            +
                    ###
         | 
| 2364 | 
            +
                      DCL.sgssim(simfacsv,vxoffsv,vyoffsv)
         | 
| 2365 | 
            +
                      #DCL.sgsmpl(plxsv,plysv,plrotsv)
         | 
| 2366 | 
            +
                    end
         | 
| 2367 | 
            +
                    DCL::grstrf
         | 
| 2368 | 
            +
             | 
| 2369 | 
            +
                    uz_set_params('inner'=>inner_bk)
         | 
| 2370 | 
            +
                  end
         | 
| 2371 | 
            +
             | 
| 2372 | 
            +
                  DCL::uziset("indext1",indext1_bk)
         | 
| 2373 | 
            +
                  DCL::uziset("indext2",indext2_bk)
         | 
| 2374 | 
            +
                  DCL::uziset("indexl1",indexl1_bk)
         | 
| 2375 | 
            +
                  DCL::uzrset("rsizel1",rsizel1_bk)
         | 
| 2376 | 
            +
             | 
| 2377 | 
            +
                  DCL::sglset("lclip", lclip_bk)
         | 
| 2378 | 
            +
                  nil
         | 
| 2379 | 
            +
                end
         | 
| 2380 | 
            +
             | 
| 2381 | 
            +
                # Annotates line/mark type and index (and size if mark).
         | 
| 2382 | 
            +
                # By default it is shown in the right margin of the viewport.
         | 
| 2383 | 
            +
                #
         | 
| 2384 | 
            +
                # * str is a String to show
         | 
| 2385 | 
            +
                # * line: true->line ; false->mark
         | 
| 2386 | 
            +
                # * vx: vx of the left-hand point of legend line (or mark position).
         | 
| 2387 | 
            +
                #     * nil : internally determined
         | 
| 2388 | 
            +
                #     * Float && > 0 : set explicitly
         | 
| 2389 | 
            +
                #     * Float && < 0 : move it relatively to the left from the default
         | 
| 2390 | 
            +
                # * dx: length of the legend line (not used if mark).
         | 
| 2391 | 
            +
                #     * nil : internally determined
         | 
| 2392 | 
            +
                #     * Float && > 0 : set explicitly
         | 
| 2393 | 
            +
                # * vy: vy of the legend (not used if !first -- see below).
         | 
| 2394 | 
            +
                #     * nil : internally determined
         | 
| 2395 | 
            +
                #     * Float && > 0 : set explicitly
         | 
| 2396 | 
            +
                #     * Float && < 0 : move it relatively lower from the default
         | 
| 2397 | 
            +
                # * first : if false, vy is moved lower relatively from the previous vy.
         | 
| 2398 | 
            +
                # * mark_size : size of the mark. if nil, size is used.
         | 
| 2399 | 
            +
                def legend(str, type, index, line=false, size=nil,
         | 
| 2400 | 
            +
                           vx=nil, dx=nil, vy=nil, first=true, mark_size=nil)
         | 
| 2401 | 
            +
             | 
| 2402 | 
            +
                  size = DCL::uzrget("rsizel1")*0.95 if !size
         | 
| 2403 | 
            +
                  mark_size = size if !mark_size
         | 
| 2404 | 
            +
             | 
| 2405 | 
            +
                  vpx1,vpx2,vpy1,vpy2 = DCL.sgqvpt
         | 
| 2406 | 
            +
                  if first
         | 
| 2407 | 
            +
                    if !vy
         | 
| 2408 | 
            +
                      vy = vpy2 - 0.04
         | 
| 2409 | 
            +
                    elsif vy < 0
         | 
| 2410 | 
            +
                      vy = ( vpy2 - 0.04 ) + vy
         | 
| 2411 | 
            +
                    end
         | 
| 2412 | 
            +
                    @vy = vy
         | 
| 2413 | 
            +
                  else
         | 
| 2414 | 
            +
                    vy = @vy - 1.5*size
         | 
| 2415 | 
            +
                  end
         | 
| 2416 | 
            +
             | 
| 2417 | 
            +
                  if !vx
         | 
| 2418 | 
            +
                    vx = vpx2 + 0.015
         | 
| 2419 | 
            +
                  elsif vx < 0
         | 
| 2420 | 
            +
                    vx = (vpx2 + 0.015) + vx
         | 
| 2421 | 
            +
                  end
         | 
| 2422 | 
            +
             | 
| 2423 | 
            +
                  if line
         | 
| 2424 | 
            +
                    dx=0.06 if !dx
         | 
| 2425 | 
            +
                    vx2 = vx + dx
         | 
| 2426 | 
            +
                    DCL::sgplzv([vx,vx2],[vy,vy],type,index)
         | 
| 2427 | 
            +
                    DCL.sgtxzv(vx2+0.01,vy,str,size,0,-1,3)
         | 
| 2428 | 
            +
                  else  # --> mark
         | 
| 2429 | 
            +
                    DCL::sgpmzv([vx],[vy],type,index,mark_size)
         | 
| 2430 | 
            +
                    DCL.sgtxzv(vx+0.015+mark_size*0.5,vy,str,size,0,-1,3)
         | 
| 2431 | 
            +
                  end
         | 
| 2432 | 
            +
                  nil
         | 
| 2433 | 
            +
                end
         | 
| 2434 | 
            +
             | 
| 2435 | 
            +
                # Driver of quasi_log_levels with data values
         | 
| 2436 | 
            +
                def quasi_log_levels_z(vals, nlev=nil, max=nil, min=nil, cycle=1)
         | 
| 2437 | 
            +
                  if max && min
         | 
| 2438 | 
            +
                    quasi_log_levels(max.to_f, min.to_f, cycle)
         | 
| 2439 | 
            +
                  else
         | 
| 2440 | 
            +
                    if nlev
         | 
| 2441 | 
            +
                      eps = 0.1
         | 
| 2442 | 
            +
                      norder = (nlev-1.0+eps)/cycle
         | 
| 2443 | 
            +
                    else
         | 
| 2444 | 
            +
                      norder = 3
         | 
| 2445 | 
            +
                    end
         | 
| 2446 | 
            +
                    mx1 = vals.max
         | 
| 2447 | 
            +
                    mx2 = vals.min
         | 
| 2448 | 
            +
                    if min && min < 0
         | 
| 2449 | 
            +
                      max = min
         | 
| 2450 | 
            +
                      min = nil
         | 
| 2451 | 
            +
                    elsif max && max < 0
         | 
| 2452 | 
            +
                      min = max
         | 
| 2453 | 
            +
                      max = nil
         | 
| 2454 | 
            +
                    end
         | 
| 2455 | 
            +
                    maxsv = max
         | 
| 2456 | 
            +
                    minsv = min
         | 
| 2457 | 
            +
                    if !max
         | 
| 2458 | 
            +
                      max = [ mx1.abs, mx2.abs ].max.to_f
         | 
| 2459 | 
            +
                      max = -max if mx1<0
         | 
| 2460 | 
            +
                    end
         | 
| 2461 | 
            +
                    if !min
         | 
| 2462 | 
            +
                      min = max/10**norder
         | 
| 2463 | 
            +
                    else
         | 
| 2464 | 
            +
                      max = min*10**norder if nlev
         | 
| 2465 | 
            +
                    end
         | 
| 2466 | 
            +
                    if !(minsv && minsv>0) && !(maxsv && maxsv <0) && ( mx2<0 && mx1>0 )
         | 
| 2467 | 
            +
                      min = -min
         | 
| 2468 | 
            +
                    end
         | 
| 2469 | 
            +
                    quasi_log_levels(max, min, cycle)
         | 
| 2470 | 
            +
                  end
         | 
| 2471 | 
            +
                end
         | 
| 2472 | 
            +
             | 
| 2473 | 
            +
                # Returns approximately log-scaled contour/tone levels as well as
         | 
| 2474 | 
            +
                # major/minor flags for contours. No DCL call is made in here.
         | 
| 2475 | 
            +
                #
         | 
| 2476 | 
            +
                # * cycle (Integer; 1, or 2 or 3) : number of level in one-order.
         | 
| 2477 | 
            +
                #   e.g. 1,10,100,.. for cycle==1; 1,3,10,30,.. for cycle==2;
         | 
| 2478 | 
            +
                #   1,2,5,10,20,50,.. for cycle==3
         | 
| 2479 | 
            +
                # * lev0, lev1 (Float) : levels are set between this two params
         | 
| 2480 | 
            +
                #   * if lev0 & lev1 > 0 : positive only
         | 
| 2481 | 
            +
                #   * if lev0 & lev1 < 0 : negative only
         | 
| 2482 | 
            +
                #   * if lev0 * lev1 < 0 : both positive and negative
         | 
| 2483 | 
            +
                #     (usig +-[lev0.abs,lev1.abs])
         | 
| 2484 | 
            +
                # RETURN VALUE:
         | 
| 2485 | 
            +
                # * [ levels, mjmn ]
         | 
| 2486 | 
            +
                def quasi_log_levels(lev0, lev1, cycle=1)
         | 
| 2487 | 
            +
                  raise(ArgumentError, "lev0 is zero (non-zero required)") if lev0 == 0.0
         | 
| 2488 | 
            +
                  raise(ArgumentError, "lev1 is zero (non-zero required)") if lev1 == 0.0
         | 
| 2489 | 
            +
                  case cycle
         | 
| 2490 | 
            +
                  when 1
         | 
| 2491 | 
            +
                    cycl_levs = [1.0]
         | 
| 2492 | 
            +
                  when 2
         | 
| 2493 | 
            +
                    cycl_levs = [1.0, 3.0]
         | 
| 2494 | 
            +
                  when 3
         | 
| 2495 | 
            +
                    cycl_levs = [1.0, 2.0, 5.0]
         | 
| 2496 | 
            +
                  else
         | 
| 2497 | 
            +
                    raise(ArgumentError, "cycle must be 1,2,or 3, which is now #{cycle}")
         | 
| 2498 | 
            +
                  end
         | 
| 2499 | 
            +
             | 
| 2500 | 
            +
                  if lev0 > 0 and lev1 > 0
         | 
| 2501 | 
            +
                    positive = true
         | 
| 2502 | 
            +
                    negative = false
         | 
| 2503 | 
            +
                  elsif  lev0 < 0 and lev1 < 0
         | 
| 2504 | 
            +
                    positive = false
         | 
| 2505 | 
            +
                    negative = true
         | 
| 2506 | 
            +
                  else
         | 
| 2507 | 
            +
                    positive = true
         | 
| 2508 | 
            +
                    negative = true
         | 
| 2509 | 
            +
                  end
         | 
| 2510 | 
            +
                  sml, big = [lev0.abs,lev1.abs].sort
         | 
| 2511 | 
            +
             | 
| 2512 | 
            +
                  expsml = Math::log10(sml).floor
         | 
| 2513 | 
            +
                  expbig = Math::log10(big).ceil
         | 
| 2514 | 
            +
             | 
| 2515 | 
            +
                  levels = Array.new
         | 
| 2516 | 
            +
                  mjmn = Array.new
         | 
| 2517 | 
            +
             | 
| 2518 | 
            +
                  for i in expsml..expbig-1
         | 
| 2519 | 
            +
                    for k in 0..cycle-1
         | 
| 2520 | 
            +
                      lev = cycl_levs[k] * 10**i
         | 
| 2521 | 
            +
                      if lev >= sml && lev <= big
         | 
| 2522 | 
            +
                        levels.push( lev )
         | 
| 2523 | 
            +
                        mjmn.push( k==0 ? 1 : 0 )
         | 
| 2524 | 
            +
                      end
         | 
| 2525 | 
            +
                    end
         | 
| 2526 | 
            +
                  end
         | 
| 2527 | 
            +
                  lev = 10**expbig
         | 
| 2528 | 
            +
                  if lev == big
         | 
| 2529 | 
            +
                    levels.push( lev )
         | 
| 2530 | 
            +
                    mjmn.push( 1 )
         | 
| 2531 | 
            +
                  end
         | 
| 2532 | 
            +
             | 
| 2533 | 
            +
                  if negative && !positive
         | 
| 2534 | 
            +
                    levels = levels.reverse.collect{|x| -x}
         | 
| 2535 | 
            +
                    mjmn = mjmn.reverse
         | 
| 2536 | 
            +
                  elsif negative && positive
         | 
| 2537 | 
            +
                    levels.dup.each{|x| levels.unshift(-x)}
         | 
| 2538 | 
            +
                    mjmn.dup.each{|x| mjmn.unshift(x)}
         | 
| 2539 | 
            +
                  end
         | 
| 2540 | 
            +
             | 
| 2541 | 
            +
                  [ levels, mjmn ]
         | 
| 2542 | 
            +
                end
         | 
| 2543 | 
            +
              end
         | 
| 2544 | 
            +
             | 
| 2545 | 
            +
            end
         | 
| 2546 | 
            +
             | 
| 2547 | 
            +
            if $0 == __FILE__
         | 
| 2548 | 
            +
              include NumRu
         | 
| 2549 | 
            +
             | 
| 2550 | 
            +
              require "numru/derivative"
         | 
| 2551 | 
            +
              include Misc::EMath
         | 
| 2552 | 
            +
              nx = 33
         | 
| 2553 | 
            +
              ny = 17
         | 
| 2554 | 
            +
              x = NArray.sfloat(nx).indgen! * (2*PI/(nx-1))
         | 
| 2555 | 
            +
              #y = ( NArray.sfloat(ny).indgen! - (ny-1)/2.0 ) *(PI/ny)
         | 
| 2556 | 
            +
              y = ( NArray.sfloat(ny).indgen! - (ny-1)/2.0 ) *(PI/(ny-1))
         | 
| 2557 | 
            +
              #p x,y
         | 
| 2558 | 
            +
              xdeg = x*(180/PI)
         | 
| 2559 | 
            +
              ydeg = y*(180/PI)
         | 
| 2560 | 
            +
              #xdegc = xdeg[[0..-1,0]]
         | 
| 2561 | 
            +
              #xdegc[-1] += 360
         | 
| 2562 | 
            +
              xx = x.newdim(1)
         | 
| 2563 | 
            +
              yy = y.newdim(0)
         | 
| 2564 | 
            +
              z = (cos(4*yy)-1)*sin(2*xx) - 2*cos(2*yy)
         | 
| 2565 | 
            +
              u = - Derivative.cderiv(z,y,1,Derivative::CYCLIC_EXT)
         | 
| 2566 | 
            +
              v =   Derivative.cderiv(z,x,0,Derivative::CYCLIC_EXT) / cos(yy)
         | 
| 2567 | 
            +
              u = NArrayMiss.to_nam(u)
         | 
| 2568 | 
            +
              #DCL.ugpset('lmissp',true)
         | 
| 2569 | 
            +
              u.invalidation(2..6,-5..-2)
         | 
| 2570 | 
            +
              v[7..10,-5] = 999.0
         | 
| 2571 | 
            +
              
         | 
| 2572 | 
            +
              DCL.gropn(1)
         | 
| 2573 | 
            +
              DCL.glpset('lmiss',true)
         | 
| 2574 | 
            +
             | 
| 2575 | 
            +
              DCL.sgpset('lclip',true)
         | 
| 2576 | 
            +
             | 
| 2577 | 
            +
              for itr in [10,12]
         | 
| 2578 | 
            +
                DCL.grfrm
         | 
| 2579 | 
            +
                DCL.grstrn(itr)
         | 
| 2580 | 
            +
                DCL.grsvpt(0.1,0.9,0.25,0.75)
         | 
| 2581 | 
            +
                DCL.umscnt(180, 0, 0)
         | 
| 2582 | 
            +
                DCL.grswnd(xdeg[0],xdeg[-1],ydeg[0],ydeg[-1])
         | 
| 2583 | 
            +
                DCL.grstxy(-180, 180, -90, 90 )
         | 
| 2584 | 
            +
                DCL.umpset('lglobe', true)
         | 
| 2585 | 
            +
                DCL.umpfit
         | 
| 2586 | 
            +
                DCL.grstrf
         | 
| 2587 | 
            +
                DCL.udcntz(z)
         | 
| 2588 | 
            +
                vfratio, flenmax = DCLExt.flow_vect_anyproj(u, v, xdeg, ydeg)
         | 
| 2589 | 
            +
                DCLExt.unit_vect_single(vfratio, flenmax)
         | 
| 2590 | 
            +
                DCL.umplim
         | 
| 2591 | 
            +
              end
         | 
| 2592 | 
            +
             | 
| 2593 | 
            +
              itr = 30
         | 
| 2594 | 
            +
              DCL.grfrm
         | 
| 2595 | 
            +
              DCL.grstrn(itr)
         | 
| 2596 | 
            +
              DCL.grsvpt(0.1,0.9,0.1,0.9)
         | 
| 2597 | 
            +
              DCL.umscnt(180, 90, 0)
         | 
| 2598 | 
            +
              DCL.grswnd(xdeg[0],xdeg[-1],ydeg[0],ydeg[-1])
         | 
| 2599 | 
            +
              DCL.grssim(0.3,0,0)
         | 
| 2600 | 
            +
              DCL.grstxy(-180, 180, 10, 90 )
         | 
| 2601 | 
            +
              DCL.umpset('lglobe', true)
         | 
| 2602 | 
            +
              DCL.umpfit
         | 
| 2603 | 
            +
              DCL.grstrf
         | 
| 2604 | 
            +
              DCL.udcntz(z)
         | 
| 2605 | 
            +
              vfratio, flenmax = 
         | 
| 2606 | 
            +
                DCLExt.flow_vect_anyproj(u[true,ny/2+1..-1], v[true,ny/2+1..-1],
         | 
| 2607 | 
            +
                                            xdeg, ydeg[ny/2+1..-1])
         | 
| 2608 | 
            +
              DCLExt.unit_vect_single(vfratio, flenmax)
         | 
| 2609 | 
            +
              DCL.umplim
         | 
| 2610 | 
            +
             | 
| 2611 | 
            +
              itr = 30
         | 
| 2612 | 
            +
              DCL.grfrm
         | 
| 2613 | 
            +
              DCL.grstrn(itr)
         | 
| 2614 | 
            +
              DCL.grsvpt(0.1,0.9,0.1,0.9)
         | 
| 2615 | 
            +
              DCL.umscnt(180, 30, 0)
         | 
| 2616 | 
            +
              DCL.grswnd(xdeg[0],xdeg[-1],ydeg[0],ydeg[-1])
         | 
| 2617 | 
            +
              DCL.grssim(0.3,0,0)
         | 
| 2618 | 
            +
              DCL.grstxy(-180, 180, 0, 90 )
         | 
| 2619 | 
            +
              DCL.umpset('lglobe', true)
         | 
| 2620 | 
            +
              DCL.umpfit
         | 
| 2621 | 
            +
              DCL.grstrf
         | 
| 2622 | 
            +
              #DCL.udcntz(z[true,ny/2+1..-1])
         | 
| 2623 | 
            +
              DCL.uepset("ltone",true)
         | 
| 2624 | 
            +
              DCL.udcntz(z[true,ny/2+1..-1])
         | 
| 2625 | 
            +
              vfratio, flenmax = 
         | 
| 2626 | 
            +
                DCLExt.flow_vect_anyproj(u, v,
         | 
| 2627 | 
            +
                                            xdeg, ydeg,
         | 
| 2628 | 
            +
                                            1.0,1,1,true,nil,0.3)
         | 
| 2629 | 
            +
                #DCLExt.flow_vect_anyproj(u[true,ny/2..-1], v[true,ny/2..-1],
         | 
| 2630 | 
            +
                #                            xdeg, ydeg[ny/2..-1])
         | 
| 2631 | 
            +
              DCLExt.unit_vect_single(vfratio, flenmax)
         | 
| 2632 | 
            +
              DCL.umplim
         | 
| 2633 | 
            +
             | 
| 2634 | 
            +
              DCL.grcls
         | 
| 2635 | 
            +
             | 
| 2636 | 
            +
            end
         |