source: palm/trunk/TUTORIAL/SOURCE/ncl.tex @ 1220

Last change on this file since 1220 was 1080, checked in by maronga, 12 years ago

several updates in the tutorial

  • Property svn:keywords set to Id
File size: 16.3 KB
RevLine 
[1080]1%$Id: ncl.tex 1080 2012-12-13 13:39:39Z heinze $
2\input{header_tmp.tex}
3%\input{../header_lectures.tex}
4
5\usepackage[utf8]{inputenc}
6\usepackage{ngerman}
7\usepackage{pgf}
8\usetheme{Dresden}
9\usepackage{subfigure}
10\usepackage{units}
11\usepackage{multimedia}
12\usepackage{hyperref}
13\newcommand{\event}[1]{\newcommand{\eventname}{#1}}
14\usepackage{xmpmulti}
15\usepackage{tikz}
16\usetikzlibrary{shapes,arrows,positioning}
17\usetikzlibrary{calc}                             %neues paket
18\usetikzlibrary{decorations.markings}             %neues paket
19\usetikzlibrary{decorations.pathreplacing}        %neues paket
20\def\Tiny{\fontsize{4pt}{4pt}\selectfont}
21\usepackage{amsmath}
22\usepackage{amssymb}
23\usepackage{multicol}
24\usepackage{pdfcomment}
25\usepackage{graphicx}
26\usepackage{listings}
27\lstset{showspaces=false,language=fortran,basicstyle=
28        \ttfamily,showstringspaces=false,captionpos=b}
29
30\institute{Institut fÌr Meteorologie und Klimatologie, Leibniz UniversitÀt Hannover}
31\date{last update: \today}
32\event{PALM Seminar}
33\setbeamertemplate{navigation symbols}{}
34
35\setbeamertemplate{footline}
36  {
37    \begin{beamercolorbox}[rightskip=-0.1cm]&
38     {\includegraphics[height=0.65cm]{imuk_logo.pdf}\hfill \includegraphics[height=0.65cm]{luh_logo.pdf}}
39    \end{beamercolorbox}
40    \begin{beamercolorbox}[ht=2.5ex,dp=1.125ex,
41      leftskip=.3cm,rightskip=0.3cm plus1fil]{title in head/foot}
42      {\leavevmode{\usebeamerfont{author in head/foot}\insertshortauthor} \hfill \eventname \hfill \insertframenumber \; / \inserttotalframenumber}
43    \end{beamercolorbox}
44    \begin{beamercolorbox}[colsep=1.5pt]{lower separation line foot}
45    \end{beamercolorbox}
46  }
47%\logo{\includegraphics[width=0.3\textwidth]{luhimuk_logo.pdf}}
48
49\title[Introduction to NCL]{Introduction to NCL}
50\author{Siegfried Raasch}
51
52\begin{document}
53
54% Folie 1
55\begin{frame}
56\titlepage
57\end{frame}
58
59\section{Introduction to NCL}
60\subsection{Introduction to NCL}
61
62% Folie 2
63\begin{frame}
64   \frametitle{Visualization of PALM Output Data}
65   \small
66   \begin{itemize}     
67           \item<1-> There are several ways how you can visualize netCDF data
68           \item<1-> If you are lacking experience in the visualization of netCDF data or if you have not yet found your favourite way how to visualize netCDF data, here is one recommendation:
69      \item<2-> NCL – The \textbf{N}CAR \textbf{C}ommand \textbf{L}anguage
70      \item<2-> Developed by the Computational \& Information Systems Laboratory at the NCAR (continuously updated)
71      \item<2-> Detailed information is available under http://www.ncl.ucar.edu
72      \item<3-> With the information revealed in this talk you will be able to visualize the output of this week's simulations
73   \end{itemize}   
74\end{frame}
75
76% Folie 3
77\begin{frame}
78   \frametitle{What is NCL and Which are its Advantages? (I)}
79   \small
80   \begin{itemize}     
81           \item<1-> Interpreted language designed specifically for scientific data processing and visualization, free available
82           \item<2-> Portable: it is running on many different operating systems including Solaris, AIX, IRIX, Linux, MacOSX, DecAlpha, Cygwin/Windows
83      \item<3-> It's a powerful tool for file input and output, visualization and data analysis (but please \textbf{avoid the excessive usage of loops}, as NCL is an interpreted language) $\rightarrow$ integrated processing environment
84   \end{itemize} 
85   \centering
86   \onslide<3-> \includegraphics[scale=0.28]{ncl_figures/ncl.png}
87   
88\end{frame}
89
90% Folie 4
91\begin{frame}
92   \frametitle{What is NCL and Which are its Advantages? (II)}
93   \small
94   \begin{itemize}     
95           \item<1-> Supports calling C and FORTRAN extended routines
96           \item<1-> Over 600 functions and procedures for visualization and data analysis are provided with NCL
97           \item<2-> Interactive mode: \texttt{\$ ncl}\\
98      \texttt{ncl 0>}
99      \item<3-> each line is interpreted as it is entered
100      \item<1-> Batch mode: \texttt{\$ ncl ncl\underline{ }script.ncl}\\
101      interpreter of complete scripts, variables within the NCL script can\\
102      be steered by providing additional parameters with the ncl call\\
103      \texttt{\$ ncl ncl\underline{ }script.ncl parameter1=value}
104      \texttt{'parameter2=\dq string\dq ' ...}
105   \end{itemize} 
106
107\end{frame}
108
109% Folie 5
110\begin{frame}
111   \frametitle{What is NCL and Which are its Advantages? (III)}
112
113   \begin{itemize}     
114           \item<1-> Complete Programming Language
115           \begin{itemize}   
116              \footnotesize
117              \item<1-> data types
118              \item<1-> variables
119              \item<1-> operators
120              \item<1-> expressions
121              \item<1-> loops
122              \item<1-> functions/procedures/graphics
123      \end{itemize} 
124           \item<2-> Features
125           \begin{itemize}   
126              \footnotesize
127              \item<2-> query / manipulate meta data
128              \item<2-> import data in a variety of formats
129              \item<2-> array syntax / operations
130              \item<2-> can use user FORTRAN/C codes and commercial libraries
131              \item<2-> most functions/procedures ignore missing data
132      \end{itemize} 
133   \end{itemize} 
134
135\end{frame}
136
137% Folie 6
138\begin{frame}
139   \frametitle{How to Install NCL (Under Linux) (I)?}
140   \small
141   \begin{itemize}     
142           \item<1-> Detailed information is available under\\
143      \underline{http://www.ncl.ucar.edu/Download/index.shtml}
144           \item<1-> Request an Earth System Grid account
145      \underline{http://www.earthsystemgrid.org/}
146           \item<2-> Download the appropriate binaries e.g. \texttt{A.tar.gz} for your system e.g. to \texttt{\$HOME}
147      \item<2-> \texttt{\% gunzip \$HOME/A.tar.gz}
148      \item<2-> \texttt{\% mkdir -p /usr/local}\\
149      \quad \texttt{\% cd /usr/local}\\
150      \quad \texttt{\% tar -xvf \$HOME/A.tar}
151   \end{itemize} 
152
153\end{frame}
154
155% Folie 7
156\begin{frame}
157   \frametitle{How to Install NCL (Under Linux) (II)?}
158   \footnotesize 
159   \begin{itemize}     
160           \item<1-> Set the \texttt{NCARG\underline{ }ROOT} environment variable and your search path to where NCL/NCARG resides\\
161           csh: \texttt{setenv NCARG\underline{ }ROOT /usr/local/}\\
162           \hspace{1.6em} \texttt{setenv PATH /usr/local/bin:\$PATH}\\
163           bash/ksh: \texttt{export NCARG\underline{ }ROOT=/usr/local/}\\
164           \hspace{4.1em} \texttt{export PATH=/usr/local/bin:\$PATH}\\
165           \vspace{3mm}
166      \item<2-> Set the DISPLAY environment variable to indicate where to display graphics as for any X11 Windows application that you run\\
167      e.g. ksh: \texttt{export DISPLAY=localhost:13.0}, or use \texttt{ssh -X} to tunnel X-communication.\\
168      \vspace{3mm}
169      \item<3-> Test your NCL installation\\
170      \quad \texttt{\% ng4ex gsun01}\\
171      NCL script gsun01n.ncl is copied to your working directory and run through NCL. An X11 window should pop up.
172   \end{itemize} 
173
174\end{frame}
175
176% Folie 8
177\begin{frame}
178   \frametitle{NCL Scripts Delivered with PALM (I)}
179   \footnotesize 
180   \begin{itemize}     
181           \item<1-> Together with the PALM installation you have also received four NCL scripts, a configuration file and a manual; they can be found in the directory\\
182           \texttt{\$HOME/palm/current\underline{ }version/trunk/SCRIPTS/NCL/}
183      \item<2-> All standard netCDF data output of PALM can be visualized by one of the scripts:
184      \begin{itemize}
185         \scriptsize
186         \item[-]<2-> \texttt{cross\underline{ }sections.ncl} (2D/3D data, e.g. contour or vector plots)
187         \item[-]<2-> \texttt{profiles.ncl} (profile data)
188         \item[-]<2-> \texttt{timeseries.ncl} (time series data)
189         \item[-]<2-> \texttt{spectra.ncl} (spectra data)
190      \end{itemize} 
191      \item<3-> To run these NCL scripts you can use the shell script \texttt{palmplot} which can be found in the directory\\
192      \texttt{\$HOME/palm/current\underline{ }version/trunk/SCRIPTS}
193      \item<4-> The output of the plots can be changed with several parameters; these parameters can be either written in the prompt (when calling the shell script \texttt{palmplot}) or modified within the configuration file \texttt{.ncl.config}
194   \end{itemize} 
195
196\end{frame}
197
198% Folie 9
199\begin{frame}
200   \frametitle{NCL Scripts Delivered with PALM (II)}
201
202   Using \texttt{.ncl.config}
203   \small
204   \begin{itemize}     
205           \item[-]<1-> Please create a personal configuration file by copying the default configuration file \texttt{.ncl.config.default} to the PALM working directory \texttt{\$HOME/palm/current\underline{ }version} and naming it \texttt{.ncl.config}
206           \item[-]<2-> \texttt{.ncl.config} is used by NCL directly, thus the parameters have to be written according to the rules of the scripting language NCL
207           \item[-]<3-> The configuration file contains all steering parameters with a short description and can be modified to personal needs
208   \end{itemize} 
209
210\end{frame}
211
212% Folie 10
213\begin{frame}
214   \frametitle{NCL Scripts Delivered with PALM (III)}
215
216   Using \texttt{palmplot} (I)
217   \footnotesize
218   \begin{itemize}     
219           \item[-]<1-> The shell script is used as follows:\\
220      \texttt{palmplot <plot\underline{ }identifier>}
221      \item[-]<1-> \texttt{<plot\underline{ }identifier>} has to be \texttt{xy}, \texttt{xz}, \texttt{yz}, \texttt{pr}, \texttt{sp} or \texttt{ts} depending on the data to be plotted
222   \end{itemize}     
223   \vspace{3mm}
224   \onslide<2->\begin{tabular}{ccc}
225      \textbf{plot\underline{ }identifier} & \textbf{data used} & \textbf{ncl script}\\
226           xy & instantaneous or time-averaged xy or 3D data & cross\underline{ }sections.ncl\\
227           xz & instantaneous or time-averaged xz or 3D data & cross\underline{ }sections.ncl\\
228           yz & instantaneous or time-averaged yz or 3D data & cross\underline{ }sections.ncl\\
229           pr & profile or 3D data & profiles.ncl\\
230           sp & spectra data & spectra.ncl\\
231           ts & time series data & timeseries.ncl\\ 
232   \end{tabular}
233
234\end{frame}
235
236% Folie 11
237\begin{frame}
238   \frametitle{NCL Scripts Delivered with PALM (IV)}
239
240   Using \texttt{palmplot} (II)
241   \footnotesize
242   \begin{itemize}     
243           \item[-]<1-> To change the output of the plot you can also use:\\
244      \scriptsize \texttt{palmplot \textbf{plot\underline{ }identifier} parameter=value parameter=string ...} 
245      \footnotesize \\
246      \vspace{2mm}
247      \item[-]<2-> A list of all available parameters can be found in the configuration file \texttt{.ncl.config} or in the documentation:\\
248      \uncover<3->{\texttt{http://palm.muk.uni-hannover.de/wiki/doc/app/nclparlist}}\\
249      \vspace{2mm}
250      \item[-]<4-> Parameters specified in the prompt override parameters given in the configuration file\\
251      \vspace{2mm}
252      \item[-]<5-> String parameters which can contain lists (\texttt{var}, \texttt{c\underline{ }var}, \texttt{vec1}, \texttt{vec2}, \texttt{plotvec}) have to be set in single quotes and the list itself has to be separated by blanks, e.g. \texttt{var='pt u w'}\\
253      \vspace{2mm}
254      \item[-]<1-> A short introduction for using the shell script is given by typing\\
255      \texttt{palmplot ?}
256   \end{itemize}     
257
258\end{frame}
259
260% Folie 12
261\begin{frame}
262   \frametitle{Application Example: Visualization of the Output of the Example Run (example\underline{ }cbl) (I)}
263   \small
264   \begin{itemize}     
265           \item<1-> Starting the example run with the command\\
266           \vspace{2mm}
267      \texttt{mrun -d example\underline{ }cbl ... -r 'd3\# pr\# ts\# xy\# xz\#'}\\
268      \vspace{2mm}
269      results in the following output files in\\
270      \vspace{2mm}
271      \texttt{\$HOME/palm/current\underline{ }version/JOBS/example\underline{ }cbl/OUTPUT/}:\\
272      \texttt{example\underline{ }cbl\underline{ }pr.nc}, \texttt{example\underline{ }cbl\underline{ }xy.nc}, \texttt{example\underline{ }cbl\underline{ }xz.nc},\\
273      \texttt{example\underline{ }cbl\underline{ }ts.nc}
274      \item<2-> Example: Visualization of the time series data\\
275      \vspace{2mm}
276      Goal: Output as eps-file \texttt{timeseries.eps} (by default the plot would be output to an X11 window)
277   \end{itemize}     
278
279\end{frame}
280
281% Folie 13
282\begin{frame}
283   \frametitle{Application Example: Visualization of the Output of the Example Run (example\underline{ }cbl) (II)}
284   \small
285   \begin{itemize}     
286           \item<1-> In order to reach the goal you can either ...
287      \item<1-> ... Change to the directory\\
288      \texttt{\$HOME/palm/current\underline{ }version/JOBS/example\underline{ }cbl/OUTPUT/}\\
289      and use the shell script with the command\\
290      \vspace{2mm}
291      \texttt{palmplot ts file\underline{ }1=example\underline{ }cbl\underline{ }ts.nc format\underline{ }out=eps file\underline{ }out=timeseries}\\
292      \vspace{2mm}
293      Thus, the script \texttt{timeseries.ncl} is called and some of the parameters in the configuration file \texttt{.ncl.config} are directly set by specifying the related parameters in the command line,\\
294      \vspace{2mm}
295      \onslide<2-> e.g. \texttt{file\underline{ }1 = <netCDF file>} \textbf{(Note: the input file has always to be specified!)}, \texttt{file\underline{ }out = <output file>}
296   \end{itemize}     
297
298\end{frame}
299
300% Folie 14
301\begin{frame}
302   \frametitle{Application Example: Visualization of the Output of the Example Run (example\underline{ }cbl) (III)}
303   \footnotesize
304   ... or you can modify the configuration file \texttt{.ncl.config}, e.g.\\
305   \vspace{2mm}
306   \texttt{if(.not. isvar(\dq file\underline{ }1\dq))then}\\
307   \quad \quad \texttt{file\underline{ }1 = \dq File in\dq}\\
308   \texttt{end if}\\
309   \vspace{2mm}
310   \onslide<2-> has to be changed to\\
311   \vspace{2mm}
312\texttt{if(.not. isvar(\dq file\underline{ }1\dq))then}\\
313   \quad \quad \texttt{file\underline{ }1 = \dq \$HOME/palm/current\underline{ }version/JOBS/example\underline{ }cbl/OUTPUT/example\underline{ }cbl\underline{ }ts.nc\dq}\\
314   \texttt{end if}
315
316\end{frame}
317
318% Folie 15
319\begin{frame}
320   \frametitle{Application Example: Visualization of the Output of the Example Run (example\underline{ }cbl) (IV)}
321   \footnotesize
322   \begin{itemize}
323      \item<1-> Both ways will lead to the creation of a new file called \texttt{timeseries.eps} in the directory\\
324      \texttt{\$HOME/palm/current\underline{ }version/JOBS/example\underline{ }cbl/OUTPUT/}
325   \end{itemize}
326   \centering
327   \onslide<2->\includegraphics[scale=0.4]{ncl_figures/vis1.png}
328   
329\end{frame}
330
331% Folie 16
332\begin{frame}
333   \frametitle{Application Example: Visualization of the Output of the Example Run (example\underline{ }cbl) (V)}
334   \footnotesize
335   \begin{itemize}
336      \item<1-> If you only want to get the plot of the time series of one variable, e.g. the maximum of the velocity component u, you can add the command line parameter \texttt{var='umax'} or modify the configuration file respectively, e.g.\\
337      \vspace{2mm}
338      \texttt{if(.not. isvar(\dq var\dq ))then}\\
339      \quad \quad \texttt{var = \dq ,umax,\dq }\\       
340      \texttt{end if}
341   \end{itemize}
342   \centering
343   \onslide<2->\includegraphics[scale=0.7]{ncl_figures/vis2.png}
344   
345\end{frame}
346
347% Folie 17
348\begin{frame}[t]
349   \tikzstyle{plain} = [rectangle, text width=0.27\textwidth, font=\small]
350   \frametitle{Application Example: Visualization of the Output of the Example Run (example\underline{ }cbl) (VI)}
351   \footnotesize
352   Plot profiles with the command\\
353   \quad \texttt{palmplot pr file\underline{ }1=example\underline{ }cbl\underline{ }pr.nc}\\
354   \vspace{3mm}
355   Profiles of same dimension are plotted\\
356   together, e.g. total, resolved and\\
357   subgridscale temperature flux (default)\\
358   \vspace{3mm}
359   (This composition is written to the\\
360   NetCDF header by the \texttt{d3par}\\
361   parameter \texttt{cross\underline{ }profiles})\\
362   \vspace{3mm}
363   If you add the parameter var=all to\\
364   the command, all profiles will be plotted\\
365   separately
366   \begin{tikzpicture}[remember picture, overlay]
367      \node at (current page.north west){%
368      \begin{tikzpicture}[overlay]
369         \node[plain,anchor=west] at (72mm,-51.5mm) {\includegraphics[scale=0.32]{ncl_figures/vis3.png}};
370      \end{tikzpicture}
371      };
372   \end{tikzpicture}
373   
374\end{frame}
375
376% Folie 18
377\begin{frame}
378   \frametitle{More Comments}
379   \small
380   \begin{itemize}     
381           \item<1-> The other NCL scripts delivered with PALM can be used in a similar way, however the parameters that can be specified differ from script to script
382           \item<2-> There are plenty of parameters for each script. Please have a look to the NCL documentation (\texttt{http://palm.muk.uni-hannover.de/wiki/doc/app/nclparlist}) for detailed information
383      \item<1-> If one of the program aborts and there is no comment, check the configuration file - the scripts should not abort with the default values. Be sure to use the right data type (e.g.: integer = 2; float = 2.0; double = 2.0d; string = \dq name\dq ) 
384   \end{itemize}   
385\end{frame}
386
387
388
389
390
391
392
393
394\end{document}
Note: See TracBrowser for help on using the repository browser.