comparison src/fftw-3.3.5/doc/html/Fortran-Examples.html @ 127:7867fa7e1b6b

Current fftw source
author Chris Cannam <cannam@all-day-breakfast.com>
date Tue, 18 Oct 2016 13:40:26 +0100
parents
children
comparison
equal deleted inserted replaced
126:4a7071416412 127:7867fa7e1b6b
1 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
2 <html>
3 <!-- This manual is for FFTW
4 (version 3.3.5, 30 July 2016).
5
6 Copyright (C) 2003 Matteo Frigo.
7
8 Copyright (C) 2003 Massachusetts Institute of Technology.
9
10 Permission is granted to make and distribute verbatim copies of this
11 manual provided the copyright notice and this permission notice are
12 preserved on all copies.
13
14 Permission is granted to copy and distribute modified versions of this
15 manual under the conditions for verbatim copying, provided that the
16 entire resulting derived work is distributed under the terms of a
17 permission notice identical to this one.
18
19 Permission is granted to copy and distribute translations of this manual
20 into another language, under the above conditions for modified versions,
21 except that this permission notice may be stated in a translation
22 approved by the Free Software Foundation. -->
23 <!-- Created by GNU Texinfo 5.2, http://www.gnu.org/software/texinfo/ -->
24 <head>
25 <title>FFTW 3.3.5: Fortran Examples</title>
26
27 <meta name="description" content="FFTW 3.3.5: Fortran Examples">
28 <meta name="keywords" content="FFTW 3.3.5: Fortran Examples">
29 <meta name="resource-type" content="document">
30 <meta name="distribution" content="global">
31 <meta name="Generator" content="makeinfo">
32 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
33 <link href="index.html#Top" rel="start" title="Top">
34 <link href="Concept-Index.html#Concept-Index" rel="index" title="Concept Index">
35 <link href="index.html#SEC_Contents" rel="contents" title="Table of Contents">
36 <link href="Calling-FFTW-from-Legacy-Fortran.html#Calling-FFTW-from-Legacy-Fortran" rel="up" title="Calling FFTW from Legacy Fortran">
37 <link href="Wisdom-of-Fortran_003f.html#Wisdom-of-Fortran_003f" rel="next" title="Wisdom of Fortran?">
38 <link href="FFTW-Execution-in-Fortran.html#FFTW-Execution-in-Fortran" rel="prev" title="FFTW Execution in Fortran">
39 <style type="text/css">
40 <!--
41 a.summary-letter {text-decoration: none}
42 blockquote.smallquotation {font-size: smaller}
43 div.display {margin-left: 3.2em}
44 div.example {margin-left: 3.2em}
45 div.indentedblock {margin-left: 3.2em}
46 div.lisp {margin-left: 3.2em}
47 div.smalldisplay {margin-left: 3.2em}
48 div.smallexample {margin-left: 3.2em}
49 div.smallindentedblock {margin-left: 3.2em; font-size: smaller}
50 div.smalllisp {margin-left: 3.2em}
51 kbd {font-style:oblique}
52 pre.display {font-family: inherit}
53 pre.format {font-family: inherit}
54 pre.menu-comment {font-family: serif}
55 pre.menu-preformatted {font-family: serif}
56 pre.smalldisplay {font-family: inherit; font-size: smaller}
57 pre.smallexample {font-size: smaller}
58 pre.smallformat {font-family: inherit; font-size: smaller}
59 pre.smalllisp {font-size: smaller}
60 span.nocodebreak {white-space:nowrap}
61 span.nolinebreak {white-space:nowrap}
62 span.roman {font-family:serif; font-weight:normal}
63 span.sansserif {font-family:sans-serif; font-weight:normal}
64 ul.no-bullet {list-style: none}
65 -->
66 </style>
67
68
69 </head>
70
71 <body lang="en" bgcolor="#FFFFFF" text="#000000" link="#0000FF" vlink="#800080" alink="#FF0000">
72 <a name="Fortran-Examples"></a>
73 <div class="header">
74 <p>
75 Next: <a href="Wisdom-of-Fortran_003f.html#Wisdom-of-Fortran_003f" accesskey="n" rel="next">Wisdom of Fortran?</a>, Previous: <a href="FFTW-Execution-in-Fortran.html#FFTW-Execution-in-Fortran" accesskey="p" rel="prev">FFTW Execution in Fortran</a>, Up: <a href="Calling-FFTW-from-Legacy-Fortran.html#Calling-FFTW-from-Legacy-Fortran" accesskey="u" rel="up">Calling FFTW from Legacy Fortran</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html#Concept-Index" title="Index" rel="index">Index</a>]</p>
76 </div>
77 <hr>
78 <a name="Fortran-Examples-1"></a>
79 <h3 class="section">8.4 Fortran Examples</h3>
80
81 <p>In C, you might have something like the following to transform a
82 one-dimensional complex array:
83 </p>
84 <div class="example">
85 <pre class="example"> fftw_complex in[N], out[N];
86 fftw_plan plan;
87
88 plan = fftw_plan_dft_1d(N,in,out,FFTW_FORWARD,FFTW_ESTIMATE);
89 fftw_execute(plan);
90 fftw_destroy_plan(plan);
91 </pre></div>
92
93 <p>In Fortran, you would use the following to accomplish the same thing:
94 </p>
95 <div class="example">
96 <pre class="example"> double complex in, out
97 dimension in(N), out(N)
98 integer*8 plan
99
100 call dfftw_plan_dft_1d(plan,N,in,out,FFTW_FORWARD,FFTW_ESTIMATE)
101 call dfftw_execute_dft(plan, in, out)
102 call dfftw_destroy_plan(plan)
103 </pre></div>
104 <a name="index-dfftw_005fplan_005fdft_005f1d"></a>
105 <a name="index-dfftw_005fexecute_005fdft-1"></a>
106 <a name="index-dfftw_005fdestroy_005fplan"></a>
107
108 <p>Notice how all routines are called as Fortran subroutines, and the
109 plan is returned via the first argument to <code>dfftw_plan_dft_1d</code>.
110 Notice also that we changed <code>fftw_execute</code> to
111 <code>dfftw_execute_dft</code> (see <a href="FFTW-Execution-in-Fortran.html#FFTW-Execution-in-Fortran">FFTW Execution in Fortran</a>). To do
112 the same thing, but using 8 threads in parallel (see <a href="Multi_002dthreaded-FFTW.html#Multi_002dthreaded-FFTW">Multi-threaded FFTW</a>), you would simply prefix these calls with:
113 </p>
114 <div class="example">
115 <pre class="example"> integer iret
116 call dfftw_init_threads(iret)
117 call dfftw_plan_with_nthreads(8)
118 </pre></div>
119 <a name="index-dfftw_005finit_005fthreads"></a>
120 <a name="index-dfftw_005fplan_005fwith_005fnthreads"></a>
121
122 <p>(You might want to check the value of <code>iret</code>: if it is zero, it
123 indicates an unlikely error during thread initialization.)
124 </p>
125 <p>To transform a three-dimensional array in-place with C, you might do:
126 </p>
127 <div class="example">
128 <pre class="example"> fftw_complex arr[L][M][N];
129 fftw_plan plan;
130
131 plan = fftw_plan_dft_3d(L,M,N, arr,arr,
132 FFTW_FORWARD, FFTW_ESTIMATE);
133 fftw_execute(plan);
134 fftw_destroy_plan(plan);
135 </pre></div>
136
137 <p>In Fortran, you would use this instead:
138 </p>
139 <div class="example">
140 <pre class="example"> double complex arr
141 dimension arr(L,M,N)
142 integer*8 plan
143
144 call dfftw_plan_dft_3d(plan, L,M,N, arr,arr,
145 &amp; FFTW_FORWARD, FFTW_ESTIMATE)
146 call dfftw_execute_dft(plan, arr, arr)
147 call dfftw_destroy_plan(plan)
148 </pre></div>
149 <a name="index-dfftw_005fplan_005fdft_005f3d"></a>
150
151 <p>Note that we pass the array dimensions in the &ldquo;natural&rdquo; order in both C
152 and Fortran.
153 </p>
154 <p>To transform a one-dimensional real array in Fortran, you might do:
155 </p>
156 <div class="example">
157 <pre class="example"> double precision in
158 dimension in(N)
159 double complex out
160 dimension out(N/2 + 1)
161 integer*8 plan
162
163 call dfftw_plan_dft_r2c_1d(plan,N,in,out,FFTW_ESTIMATE)
164 call dfftw_execute_dft_r2c(plan, in, out)
165 call dfftw_destroy_plan(plan)
166 </pre></div>
167 <a name="index-dfftw_005fplan_005fdft_005fr2c_005f1d"></a>
168 <a name="index-dfftw_005fexecute_005fdft_005fr2c"></a>
169
170 <p>To transform a two-dimensional real array, out of place, you might use
171 the following:
172 </p>
173 <div class="example">
174 <pre class="example"> double precision in
175 dimension in(M,N)
176 double complex out
177 dimension out(M/2 + 1, N)
178 integer*8 plan
179
180 call dfftw_plan_dft_r2c_2d(plan,M,N,in,out,FFTW_ESTIMATE)
181 call dfftw_execute_dft_r2c(plan, in, out)
182 call dfftw_destroy_plan(plan)
183 </pre></div>
184 <a name="index-dfftw_005fplan_005fdft_005fr2c_005f2d"></a>
185
186 <p><strong>Important:</strong> Notice that it is the <em>first</em> dimension of the
187 complex output array that is cut in half in Fortran, rather than the
188 last dimension as in C. This is a consequence of the interface routines
189 reversing the order of the array dimensions passed to FFTW so that the
190 Fortran program can use its ordinary column-major order.
191 <a name="index-column_002dmajor-3"></a>
192 <a name="index-r2c_002fc2r-multi_002ddimensional-array-format-3"></a>
193 </p>
194 <hr>
195 <div class="header">
196 <p>
197 Next: <a href="Wisdom-of-Fortran_003f.html#Wisdom-of-Fortran_003f" accesskey="n" rel="next">Wisdom of Fortran?</a>, Previous: <a href="FFTW-Execution-in-Fortran.html#FFTW-Execution-in-Fortran" accesskey="p" rel="prev">FFTW Execution in Fortran</a>, Up: <a href="Calling-FFTW-from-Legacy-Fortran.html#Calling-FFTW-from-Legacy-Fortran" accesskey="u" rel="up">Calling FFTW from Legacy Fortran</a> &nbsp; [<a href="index.html#SEC_Contents" title="Table of contents" rel="contents">Contents</a>][<a href="Concept-Index.html#Concept-Index" title="Index" rel="index">Index</a>]</p>
198 </div>
199
200
201
202 </body>
203 </html>