File
idoc/man/files/modules/math/fourier.n
— part of check-in
[f6714a7464]
at
2024-01-08 21:29:53
on branch trunk
— ticket [8dd305fd78] - doctools - D, EF - Extended `require` formatting command
Accept multiple version arguments, like Tcl's `package require` builtin.
Version bumped to 1.6.
Thanks to Rolf for the suggestion.
Online docs regenerated.
(user:
aku
size: 11588)
[more...]
0000: 27 5c 22 0a 27 5c 22 20 47 65 6e 65 72 61 74 65 '\".'\" Generate
0010: 64 20 66 72 6f 6d 20 66 69 6c 65 20 27 66 6f 75 d from file 'fou
0020: 72 69 65 72 5c 26 2e 6d 61 6e 27 20 62 79 20 74 rier\&.man' by t
0030: 63 6c 6c 69 62 2f 64 6f 63 74 6f 6f 6c 73 20 77 cllib/doctools w
0040: 69 74 68 20 66 6f 72 6d 61 74 20 27 6e 72 6f 66 ith format 'nrof
0050: 66 27 0a 27 5c 22 0a 2e 54 48 20 22 6d 61 74 68 f'.'\"..TH "math
0060: 3a 3a 66 6f 75 72 69 65 72 22 20 6e 20 31 5c 26 ::fourier" n 1\&
0070: 2e 30 5c 26 2e 33 20 74 63 6c 6c 69 62 20 22 54 .0\&.3 tcllib "T
0080: 63 6c 20 4d 61 74 68 20 4c 69 62 72 61 72 79 22 cl Math Library"
0090: 0a 2e 5c 22 20 54 68 65 20 2d 2a 2d 20 6e 72 6f ..\" The -*- nro
00a0: 66 66 20 2d 2a 2d 20 64 65 66 69 6e 69 74 69 6f ff -*- definitio
00b0: 6e 73 20 62 65 6c 6f 77 20 61 72 65 20 66 6f 72 ns below are for
00c0: 20 73 75 70 70 6c 65 6d 65 6e 74 61 6c 20 6d 61 supplemental ma
00d0: 63 72 6f 73 20 75 73 65 64 0a 2e 5c 22 20 69 6e cros used..\" in
00e0: 20 54 63 6c 2f 54 6b 20 6d 61 6e 75 61 6c 20 65 Tcl/Tk manual e
00f0: 6e 74 72 69 65 73 2e 0a 2e 5c 22 0a 2e 5c 22 20 ntries...\"..\"
0100: 2e 41 50 20 74 79 70 65 20 6e 61 6d 65 20 69 6e .AP type name in
0110: 2f 6f 75 74 20 3f 69 6e 64 65 6e 74 3f 0a 2e 5c /out ?indent?..\
0120: 22 09 53 74 61 72 74 20 70 61 72 61 67 72 61 70 ".Start paragrap
0130: 68 20 64 65 73 63 72 69 62 69 6e 67 20 61 6e 20 h describing an
0140: 61 72 67 75 6d 65 6e 74 20 74 6f 20 61 20 6c 69 argument to a li
0150: 62 72 61 72 79 20 70 72 6f 63 65 64 75 72 65 2e brary procedure.
0160: 0a 2e 5c 22 09 74 79 70 65 20 69 73 20 74 79 70 ..\".type is typ
0170: 65 20 6f 66 20 61 72 67 75 6d 65 6e 74 20 28 69 e of argument (i
0180: 6e 74 2c 20 65 74 63 2e 29 2c 20 69 6e 2f 6f 75 nt, etc.), in/ou
0190: 74 20 69 73 20 65 69 74 68 65 72 20 22 69 6e 22 t is either "in"
01a0: 2c 20 22 6f 75 74 22 2c 0a 2e 5c 22 09 6f 72 20 , "out",..\".or
01b0: 22 69 6e 2f 6f 75 74 22 20 74 6f 20 64 65 73 63 "in/out" to desc
01c0: 72 69 62 65 20 77 68 65 74 68 65 72 20 70 72 6f ribe whether pro
01d0: 63 65 64 75 72 65 20 72 65 61 64 73 20 6f 72 20 cedure reads or
01e0: 6d 6f 64 69 66 69 65 73 20 61 72 67 2c 0a 2e 5c modifies arg,..\
01f0: 22 09 61 6e 64 20 69 6e 64 65 6e 74 20 69 73 20 ".and indent is
0200: 65 71 75 69 76 61 6c 65 6e 74 20 74 6f 20 73 65 equivalent to se
0210: 63 6f 6e 64 20 61 72 67 20 6f 66 20 2e 49 50 20 cond arg of .IP
0220: 28 73 68 6f 75 6c 64 6e 27 74 20 65 76 65 72 20 (shouldn't ever
0230: 62 65 0a 2e 5c 22 09 6e 65 65 64 65 64 3b 20 20 be..\".needed;
0240: 75 73 65 20 2e 41 53 20 62 65 6c 6f 77 20 69 6e use .AS below in
0250: 73 74 65 61 64 29 0a 2e 5c 22 0a 2e 5c 22 20 2e stead)..\"..\" .
0260: 41 53 20 3f 74 79 70 65 3f 20 3f 6e 61 6d 65 3f AS ?type? ?name?
0270: 0a 2e 5c 22 09 47 69 76 65 20 6d 61 78 69 6d 75 ..\".Give maximu
0280: 6d 20 73 69 7a 65 73 20 6f 66 20 61 72 67 75 6d m sizes of argum
0290: 65 6e 74 73 20 66 6f 72 20 73 65 74 74 69 6e 67 ents for setting
02a0: 20 74 61 62 20 73 74 6f 70 73 2e 20 20 54 79 70 tab stops. Typ
02b0: 65 20 61 6e 64 0a 2e 5c 22 09 6e 61 6d 65 20 61 e and..\".name a
02c0: 72 65 20 65 78 61 6d 70 6c 65 73 20 6f 66 20 6c re examples of l
02d0: 61 72 67 65 73 74 20 70 6f 73 73 69 62 6c 65 20 argest possible
02e0: 61 72 67 75 6d 65 6e 74 73 20 74 68 61 74 20 77 arguments that w
02f0: 69 6c 6c 20 62 65 20 70 61 73 73 65 64 0a 2e 5c ill be passed..\
0300: 22 09 74 6f 20 2e 41 50 20 6c 61 74 65 72 2e 20 ".to .AP later.
0310: 20 49 66 20 61 72 67 73 20 61 72 65 20 6f 6d 69 If args are omi
0320: 74 74 65 64 2c 20 64 65 66 61 75 6c 74 20 74 61 tted, default ta
0330: 62 20 73 74 6f 70 73 20 61 72 65 20 75 73 65 64 b stops are used
0340: 2e 0a 2e 5c 22 0a 2e 5c 22 20 2e 42 53 0a 2e 5c ...\"..\" .BS..\
0350: 22 09 53 74 61 72 74 20 62 6f 78 20 65 6e 63 6c ".Start box encl
0360: 6f 73 75 72 65 2e 20 20 46 72 6f 6d 20 68 65 72 osure. From her
0370: 65 20 75 6e 74 69 6c 20 6e 65 78 74 20 2e 42 45 e until next .BE
0380: 2c 20 65 76 65 72 79 74 68 69 6e 67 20 77 69 6c , everything wil
0390: 6c 20 62 65 0a 2e 5c 22 09 65 6e 63 6c 6f 73 65 l be..\".enclose
03a0: 64 20 69 6e 20 6f 6e 65 20 6c 61 72 67 65 20 62 d in one large b
03b0: 6f 78 2e 0a 2e 5c 22 0a 2e 5c 22 20 2e 42 45 0a ox...\"..\" .BE.
03c0: 2e 5c 22 09 45 6e 64 20 6f 66 20 62 6f 78 20 65 .\".End of box e
03d0: 6e 63 6c 6f 73 75 72 65 2e 0a 2e 5c 22 0a 2e 5c nclosure...\"..\
03e0: 22 20 2e 43 53 0a 2e 5c 22 09 42 65 67 69 6e 20 " .CS..\".Begin
03f0: 63 6f 64 65 20 65 78 63 65 72 70 74 2e 0a 2e 5c code excerpt...\
0400: 22 0a 2e 5c 22 20 2e 43 45 0a 2e 5c 22 09 45 6e "..\" .CE..\".En
0410: 64 20 63 6f 64 65 20 65 78 63 65 72 70 74 2e 0a d code excerpt..
0420: 2e 5c 22 0a 2e 5c 22 20 2e 56 53 20 3f 76 65 72 .\"..\" .VS ?ver
0430: 73 69 6f 6e 3f 20 3f 62 72 3f 0a 2e 5c 22 09 42 sion? ?br?..\".B
0440: 65 67 69 6e 20 76 65 72 74 69 63 61 6c 20 73 69 egin vertical si
0450: 64 65 62 61 72 2c 20 66 6f 72 20 75 73 65 20 69 debar, for use i
0460: 6e 20 6d 61 72 6b 69 6e 67 20 6e 65 77 6c 79 2d n marking newly-
0470: 63 68 61 6e 67 65 64 20 70 61 72 74 73 0a 2e 5c changed parts..\
0480: 22 09 6f 66 20 6d 61 6e 20 70 61 67 65 73 2e 20 ".of man pages.
0490: 20 54 68 65 20 66 69 72 73 74 20 61 72 67 75 6d The first argum
04a0: 65 6e 74 20 69 73 20 69 67 6e 6f 72 65 64 20 61 ent is ignored a
04b0: 6e 64 20 75 73 65 64 20 66 6f 72 20 72 65 63 6f nd used for reco
04c0: 72 64 69 6e 67 0a 2e 5c 22 09 74 68 65 20 76 65 rding..\".the ve
04d0: 72 73 69 6f 6e 20 77 68 65 6e 20 74 68 65 20 2e rsion when the .
04e0: 56 53 20 77 61 73 20 61 64 64 65 64 2c 20 73 6f VS was added, so
04f0: 20 74 68 61 74 20 74 68 65 20 73 69 64 65 62 61 that the sideba
0500: 72 73 20 63 61 6e 20 62 65 0a 2e 5c 22 09 66 6f rs can be..\".fo
0510: 75 6e 64 20 61 6e 64 20 72 65 6d 6f 76 65 64 20 und and removed
0520: 77 68 65 6e 20 74 68 65 79 20 72 65 61 63 68 20 when they reach
0530: 61 20 63 65 72 74 61 69 6e 20 61 67 65 2e 20 20 a certain age.
0540: 49 66 20 61 6e 6f 74 68 65 72 20 61 72 67 75 6d If another argum
0550: 65 6e 74 0a 2e 5c 22 09 69 73 20 70 72 65 73 65 ent..\".is prese
0560: 6e 74 2c 20 74 68 65 6e 20 61 20 6c 69 6e 65 20 nt, then a line
0570: 62 72 65 61 6b 20 69 73 20 66 6f 72 63 65 64 20 break is forced
0580: 62 65 66 6f 72 65 20 73 74 61 72 74 69 6e 67 20 before starting
0590: 74 68 65 20 73 69 64 65 62 61 72 2e 0a 2e 5c 22 the sidebar...\"
05a0: 0a 2e 5c 22 20 2e 56 45 0a 2e 5c 22 09 45 6e 64 ..\" .VE..\".End
05b0: 20 6f 66 20 76 65 72 74 69 63 61 6c 20 73 69 64 of vertical sid
05c0: 65 62 61 72 2e 0a 2e 5c 22 0a 2e 5c 22 20 2e 44 ebar...\"..\" .D
05d0: 53 0a 2e 5c 22 09 42 65 67 69 6e 20 61 6e 20 69 S..\".Begin an i
05e0: 6e 64 65 6e 74 65 64 20 75 6e 66 69 6c 6c 65 64 ndented unfilled
05f0: 20 64 69 73 70 6c 61 79 2e 0a 2e 5c 22 0a 2e 5c display...\"..\
0600: 22 20 2e 44 45 0a 2e 5c 22 09 45 6e 64 20 6f 66 " .DE..\".End of
0610: 20 69 6e 64 65 6e 74 65 64 20 75 6e 66 69 6c 6c indented unfill
0620: 65 64 20 64 69 73 70 6c 61 79 2e 0a 2e 5c 22 0a ed display...\".
0630: 2e 5c 22 20 2e 53 4f 20 3f 6d 61 6e 70 61 67 65 .\" .SO ?manpage
0640: 3f 0a 2e 5c 22 09 53 74 61 72 74 20 6f 66 20 6c ?..\".Start of l
0650: 69 73 74 20 6f 66 20 73 74 61 6e 64 61 72 64 20 ist of standard
0660: 6f 70 74 69 6f 6e 73 20 66 6f 72 20 61 20 54 6b options for a Tk
0670: 20 77 69 64 67 65 74 2e 20 54 68 65 20 6d 61 6e widget. The man
0680: 70 61 67 65 0a 2e 5c 22 09 61 72 67 75 6d 65 6e page..\".argumen
0690: 74 20 64 65 66 69 6e 65 73 20 77 68 65 72 65 20 t defines where
06a0: 74 6f 20 6c 6f 6f 6b 20 75 70 20 74 68 65 20 73 to look up the s
06b0: 74 61 6e 64 61 72 64 20 6f 70 74 69 6f 6e 73 3b tandard options;
06c0: 20 69 66 0a 2e 5c 22 09 6f 6d 69 74 74 65 64 2c if..\".omitted,
06d0: 20 64 65 66 61 75 6c 74 73 20 74 6f 20 22 6f 70 defaults to "op
06e0: 74 69 6f 6e 73 22 2e 20 54 68 65 20 6f 70 74 69 tions". The opti
06f0: 6f 6e 73 20 66 6f 6c 6c 6f 77 20 6f 6e 20 73 75 ons follow on su
0700: 63 63 65 73 73 69 76 65 0a 2e 5c 22 09 6c 69 6e ccessive..\".lin
0710: 65 73 2c 20 69 6e 20 74 68 72 65 65 20 63 6f 6c es, in three col
0720: 75 6d 6e 73 20 73 65 70 61 72 61 74 65 64 20 62 umns separated b
0730: 79 20 74 61 62 73 2e 0a 2e 5c 22 0a 2e 5c 22 20 y tabs...\"..\"
0740: 2e 53 45 0a 2e 5c 22 09 45 6e 64 20 6f 66 20 6c .SE..\".End of l
0750: 69 73 74 20 6f 66 20 73 74 61 6e 64 61 72 64 20 ist of standard
0760: 6f 70 74 69 6f 6e 73 20 66 6f 72 20 61 20 54 6b options for a Tk
0770: 20 77 69 64 67 65 74 2e 0a 2e 5c 22 0a 2e 5c 22 widget...\"..\"
0780: 20 2e 4f 50 20 63 6d 64 4e 61 6d 65 20 64 62 4e .OP cmdName dbN
0790: 61 6d 65 20 64 62 43 6c 61 73 73 0a 2e 5c 22 09 ame dbClass..\".
07a0: 53 74 61 72 74 20 6f 66 20 64 65 73 63 72 69 70 Start of descrip
07b0: 74 69 6f 6e 20 6f 66 20 61 20 73 70 65 63 69 66 tion of a specif
07c0: 69 63 20 6f 70 74 69 6f 6e 2e 20 20 63 6d 64 4e ic option. cmdN
07d0: 61 6d 65 20 67 69 76 65 73 20 74 68 65 0a 2e 5c ame gives the..\
07e0: 22 09 6f 70 74 69 6f 6e 27 73 20 6e 61 6d 65 20 ".option's name
07f0: 61 73 20 73 70 65 63 69 66 69 65 64 20 69 6e 20 as specified in
0800: 74 68 65 20 63 6c 61 73 73 20 63 6f 6d 6d 61 6e the class comman
0810: 64 2c 20 64 62 4e 61 6d 65 20 67 69 76 65 73 0a d, dbName gives.
0820: 2e 5c 22 09 74 68 65 20 6f 70 74 69 6f 6e 27 73 .\".the option's
0830: 20 6e 61 6d 65 20 69 6e 20 74 68 65 20 6f 70 74 name in the opt
0840: 69 6f 6e 20 64 61 74 61 62 61 73 65 2c 20 61 6e ion database, an
0850: 64 20 64 62 43 6c 61 73 73 20 67 69 76 65 73 0a d dbClass gives.
0860: 2e 5c 22 09 74 68 65 20 6f 70 74 69 6f 6e 27 73 .\".the option's
0870: 20 63 6c 61 73 73 20 69 6e 20 74 68 65 20 6f 70 class in the op
0880: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 0a 2e tion database...
0890: 5c 22 0a 2e 5c 22 20 2e 55 4c 20 61 72 67 31 20 \"..\" .UL arg1
08a0: 61 72 67 32 0a 2e 5c 22 09 50 72 69 6e 74 20 61 arg2..\".Print a
08b0: 72 67 31 20 75 6e 64 65 72 6c 69 6e 65 64 2c 20 rg1 underlined,
08c0: 74 68 65 6e 20 70 72 69 6e 74 20 61 72 67 32 20 then print arg2
08d0: 6e 6f 72 6d 61 6c 6c 79 2e 0a 2e 5c 22 0a 2e 5c normally...\"..\
08e0: 22 20 2e 51 57 20 61 72 67 31 20 3f 61 72 67 32 " .QW arg1 ?arg2
08f0: 3f 0a 2e 5c 22 09 50 72 69 6e 74 20 61 72 67 31 ?..\".Print arg1
0900: 20 69 6e 20 71 75 6f 74 65 73 2c 20 74 68 65 6e in quotes, then
0910: 20 61 72 67 32 20 6e 6f 72 6d 61 6c 6c 79 20 28 arg2 normally (
0920: 66 6f 72 20 74 72 61 69 6c 69 6e 67 20 70 75 6e for trailing pun
0930: 63 74 75 61 74 69 6f 6e 29 2e 0a 2e 5c 22 0a 2e ctuation)...\"..
0940: 5c 22 20 2e 50 51 20 61 72 67 31 20 3f 61 72 67 \" .PQ arg1 ?arg
0950: 32 3f 0a 2e 5c 22 09 50 72 69 6e 74 20 61 6e 20 2?..\".Print an
0960: 6f 70 65 6e 20 70 61 72 65 6e 74 68 65 73 69 73 open parenthesis
0970: 2c 20 61 72 67 31 20 69 6e 20 71 75 6f 74 65 73 , arg1 in quotes
0980: 2c 20 74 68 65 6e 20 61 72 67 32 20 6e 6f 72 6d , then arg2 norm
0990: 61 6c 6c 79 0a 2e 5c 22 09 28 66 6f 72 20 74 72 ally..\".(for tr
09a0: 61 69 6c 69 6e 67 20 70 75 6e 63 74 75 61 74 69 ailing punctuati
09b0: 6f 6e 29 20 61 6e 64 20 74 68 65 6e 20 61 20 63 on) and then a c
09c0: 6c 6f 73 69 6e 67 20 70 61 72 65 6e 74 68 65 73 losing parenthes
09d0: 69 73 2e 0a 2e 5c 22 0a 2e 5c 22 09 23 20 53 65 is...\"..\".# Se
09e0: 74 20 75 70 20 74 72 61 70 73 20 61 6e 64 20 6f t up traps and o
09f0: 74 68 65 72 20 6d 69 73 63 65 6c 6c 61 6e 65 6f ther miscellaneo
0a00: 75 73 20 73 74 75 66 66 20 66 6f 72 20 54 63 6c us stuff for Tcl
0a10: 2f 54 6b 20 6d 61 6e 20 70 61 67 65 73 2e 0a 2e /Tk man pages...
0a20: 69 66 20 74 20 2e 77 68 20 2d 31 2e 33 69 20 5e if t .wh -1.3i ^
0a30: 42 0a 2e 6e 72 20 5e 6c 20 5c 6e 28 2e 6c 0a 2e B..nr ^l \n(.l..
0a40: 61 64 20 62 0a 2e 5c 22 09 23 20 53 74 61 72 74 ad b..\".# Start
0a50: 20 61 6e 20 61 72 67 75 6d 65 6e 74 20 64 65 73 an argument des
0a60: 63 72 69 70 74 69 6f 6e 0a 2e 64 65 20 41 50 0a cription..de AP.
0a70: 2e 69 65 20 21 22 5c 5c 24 34 22 22 20 2e 54 50 .ie !"\\$4"" .TP
0a80: 20 5c 5c 24 34 0a 2e 65 6c 20 5c 7b 5c 0a 2e 20 \\$4..el \{\..
0a90: 20 20 69 65 20 21 22 5c 5c 24 32 22 22 20 2e 54 ie !"\\$2"" .T
0aa0: 50 20 5c 5c 6e 28 29 43 75 0a 2e 20 20 20 65 6c P \\n()Cu.. el
0ab0: 20 20 20 20 20 20 20 20 20 20 2e 54 50 20 31 35 .TP 15
0ac0: 0a 2e 5c 7d 0a 2e 74 61 20 5c 5c 6e 28 29 41 75 ..\}..ta \\n()Au
0ad0: 20 5c 5c 6e 28 29 42 75 0a 2e 69 65 20 21 22 5c \\n()Bu..ie !"\
0ae0: 5c 24 33 22 22 20 5c 7b 5c 0a 5c 26 5c 5c 24 31 \$3"" \{\.\&\\$1
0af0: 20 5c 5c 66 49 5c 5c 24 32 5c 5c 66 50 20 28 5c \\fI\\$2\\fP (\
0b00: 5c 24 33 29 0a 2e 5c 22 2e 62 0a 2e 5c 7d 0a 2e \$3)..\".b..\}..
0b10: 65 6c 20 5c 7b 5c 0a 2e 62 72 0a 2e 69 65 20 21 el \{\..br..ie !
0b20: 22 5c 5c 24 32 22 22 20 5c 7b 5c 0a 5c 26 5c 5c "\\$2"" \{\.\&\\
0b30: 24 31 09 5c 5c 66 49 5c 5c 24 32 5c 5c 66 50 0a $1.\\fI\\$2\\fP.
0b40: 2e 5c 7d 0a 2e 65 6c 20 5c 7b 5c 0a 5c 26 5c 5c .\}..el \{\.\&\\
0b50: 66 49 5c 5c 24 31 5c 5c 66 50 0a 2e 5c 7d 0a 2e fI\\$1\\fP..\}..
0b60: 5c 7d 0a 2e 2e 0a 2e 5c 22 09 23 20 64 65 66 69 \}.....\".# defi
0b70: 6e 65 20 74 61 62 62 69 6e 67 20 76 61 6c 75 65 ne tabbing value
0b80: 73 20 66 6f 72 20 2e 41 50 0a 2e 64 65 20 41 53 s for .AP..de AS
0b90: 0a 2e 6e 72 20 29 41 20 31 30 6e 0a 2e 69 66 20 ..nr )A 10n..if
0ba0: 21 22 5c 5c 24 31 22 22 20 2e 6e 72 20 29 41 20 !"\\$1"" .nr )A
0bb0: 5c 5c 77 27 5c 5c 24 31 27 75 2b 33 6e 0a 2e 6e \\w'\\$1'u+3n..n
0bc0: 72 20 29 42 20 5c 5c 6e 28 29 41 75 2b 31 35 6e r )B \\n()Au+15n
0bd0: 0a 2e 5c 22 0a 2e 69 66 20 21 22 5c 5c 24 32 22 ..\"..if !"\\$2"
0be0: 22 20 2e 6e 72 20 29 42 20 5c 5c 77 27 5c 5c 24 " .nr )B \\w'\\$
0bf0: 32 27 75 2b 5c 5c 6e 28 29 41 75 2b 33 6e 0a 2e 2'u+\\n()Au+3n..
0c00: 6e 72 20 29 43 20 5c 5c 6e 28 29 42 75 2b 5c 5c nr )C \\n()Bu+\\
0c10: 77 27 28 69 6e 2f 6f 75 74 29 27 75 2b 32 6e 0a w'(in/out)'u+2n.
0c20: 2e 2e 0a 2e 41 53 20 54 63 6c 5f 49 6e 74 65 72 ....AS Tcl_Inter
0c30: 70 20 54 63 6c 5f 43 72 65 61 74 65 49 6e 74 65 p Tcl_CreateInte
0c40: 72 70 20 69 6e 2f 6f 75 74 0a 2e 5c 22 09 23 20 rp in/out..\".#
0c50: 42 53 20 2d 20 73 74 61 72 74 20 62 6f 78 65 64 BS - start boxed
0c60: 20 74 65 78 74 0a 2e 5c 22 09 23 20 5e 79 20 3d text..\".# ^y =
0c70: 20 73 74 61 72 74 69 6e 67 20 79 20 6c 6f 63 61 starting y loca
0c80: 74 69 6f 6e 0a 2e 5c 22 09 23 20 5e 62 20 3d 20 tion..\".# ^b =
0c90: 31 0a 2e 64 65 20 42 53 0a 2e 62 72 0a 2e 6d 6b 1..de BS..br..mk
0ca0: 20 5e 79 0a 2e 6e 72 20 5e 62 20 31 75 0a 2e 69 ^y..nr ^b 1u..i
0cb0: 66 20 6e 20 2e 6e 66 0a 2e 69 66 20 6e 20 2e 74 f n .nf..if n .t
0cc0: 69 20 30 0a 2e 69 66 20 6e 20 5c 6c 27 5c 5c 6e i 0..if n \l'\\n
0cd0: 28 2e 6c 75 5c 28 75 6c 27 0a 2e 69 66 20 6e 20 (.lu\(ul'..if n
0ce0: 2e 66 69 0a 2e 2e 0a 2e 5c 22 09 23 20 42 45 20 .fi.....\".# BE
0cf0: 2d 20 65 6e 64 20 62 6f 78 65 64 20 74 65 78 74 - end boxed text
0d00: 20 28 64 72 61 77 20 62 6f 78 20 6e 6f 77 29 0a (draw box now).
0d10: 2e 64 65 20 42 45 0a 2e 6e 66 0a 2e 74 69 20 30 .de BE..nf..ti 0
0d20: 0a 2e 6d 6b 20 5e 74 0a 2e 69 65 20 6e 20 5c 6c ..mk ^t..ie n \l
0d30: 27 5c 5c 6e 28 5e 6c 75 5c 28 75 6c 27 0a 2e 65 '\\n(^lu\(ul'..e
0d40: 6c 20 5c 7b 5c 0a 2e 5c 22 09 44 72 61 77 20 66 l \{\..\".Draw f
0d50: 6f 75 72 2d 73 69 64 65 64 20 62 6f 78 20 6e 6f our-sided box no
0d60: 72 6d 61 6c 6c 79 2c 20 62 75 74 20 64 6f 6e 27 rmally, but don'
0d70: 74 20 64 72 61 77 20 74 6f 70 20 6f 66 0a 2e 5c t draw top of..\
0d80: 22 09 62 6f 78 20 69 66 20 74 68 65 20 62 6f 78 ".box if the box
0d90: 20 73 74 61 72 74 65 64 20 6f 6e 20 61 6e 20 65 started on an e
0da0: 61 72 6c 69 65 72 20 70 61 67 65 2e 0a 2e 69 65 arlier page...ie
0db0: 20 21 5c 5c 6e 28 5e 62 2d 31 20 5c 7b 5c 0a 5c !\\n(^b-1 \{\.\
0dc0: 68 27 2d 31 2e 35 6e 27 5c 4c 27 7c 5c 5c 6e 28 h'-1.5n'\L'|\\n(
0dd0: 5e 79 75 2d 31 76 27 5c 6c 27 5c 5c 6e 28 5e 6c ^yu-1v'\l'\\n(^l
0de0: 75 2b 33 6e 5c 28 75 6c 27 5c 4c 27 5c 5c 6e 28 u+3n\(ul'\L'\\n(
0df0: 5e 74 75 2b 31 76 2d 5c 5c 6e 28 5e 79 75 27 5c ^tu+1v-\\n(^yu'\
0e00: 6c 27 7c 30 75 2d 31 2e 35 6e 5c 28 75 6c 27 0a l'|0u-1.5n\(ul'.
0e10: 2e 5c 7d 0a 2e 65 6c 20 5c 7d 5c 0a 5c 68 27 2d .\}..el \}\.\h'-
0e20: 31 2e 35 6e 27 5c 4c 27 7c 5c 5c 6e 28 5e 79 75 1.5n'\L'|\\n(^yu
0e30: 2d 31 76 27 5c 68 27 5c 5c 6e 28 5e 6c 75 2b 33 -1v'\h'\\n(^lu+3
0e40: 6e 27 5c 4c 27 5c 5c 6e 28 5e 74 75 2b 31 76 2d n'\L'\\n(^tu+1v-
0e50: 5c 5c 6e 28 5e 79 75 27 5c 6c 27 7c 30 75 2d 31 \\n(^yu'\l'|0u-1
0e60: 2e 35 6e 5c 28 75 6c 27 0a 2e 5c 7d 0a 2e 5c 7d .5n\(ul'..\}..\}
0e70: 0a 2e 66 69 0a 2e 62 72 0a 2e 6e 72 20 5e 62 20 ..fi..br..nr ^b
0e80: 30 0a 2e 2e 0a 2e 5c 22 09 23 20 56 53 20 2d 20 0.....\".# VS -
0e90: 73 74 61 72 74 20 76 65 72 74 69 63 61 6c 20 73 start vertical s
0ea0: 69 64 65 62 61 72 0a 2e 5c 22 09 23 20 5e 59 20 idebar..\".# ^Y
0eb0: 3d 20 73 74 61 72 74 69 6e 67 20 79 20 6c 6f 63 = starting y loc
0ec0: 61 74 69 6f 6e 0a 2e 5c 22 09 23 20 5e 76 20 3d ation..\".# ^v =
0ed0: 20 31 20 28 66 6f 72 20 74 72 6f 66 66 3b 20 20 1 (for troff;
0ee0: 66 6f 72 20 6e 72 6f 66 66 20 74 68 69 73 20 64 for nroff this d
0ef0: 6f 65 73 6e 27 74 20 6d 61 74 74 65 72 29 0a 2e oesn't matter)..
0f00: 64 65 20 56 53 0a 2e 69 66 20 21 22 5c 5c 24 32 de VS..if !"\\$2
0f10: 22 22 20 2e 62 72 0a 2e 6d 6b 20 5e 59 0a 2e 69 "" .br..mk ^Y..i
0f20: 65 20 6e 20 27 6d 63 20 5c 73 31 32 5c 28 62 72 e n 'mc \s12\(br
0f30: 5c 73 30 0a 2e 65 6c 20 2e 6e 72 20 5e 76 20 31 \s0..el .nr ^v 1
0f40: 75 0a 2e 2e 0a 2e 5c 22 09 23 20 56 45 20 2d 20 u.....\".# VE -
0f50: 65 6e 64 20 6f 66 20 76 65 72 74 69 63 61 6c 20 end of vertical
0f60: 73 69 64 65 62 61 72 0a 2e 64 65 20 56 45 0a 2e sidebar..de VE..
0f70: 69 65 20 6e 20 27 6d 63 0a 2e 65 6c 20 5c 7b 5c ie n 'mc..el \{\
0f80: 0a 2e 65 76 20 32 0a 2e 6e 66 0a 2e 74 69 20 30 ..ev 2..nf..ti 0
0f90: 0a 2e 6d 6b 20 5e 74 0a 5c 68 27 7c 5c 5c 6e 28 ..mk ^t.\h'|\\n(
0fa0: 5e 6c 75 2b 33 6e 27 5c 4c 27 7c 5c 5c 6e 28 5e ^lu+3n'\L'|\\n(^
0fb0: 59 75 2d 31 76 5c 28 62 76 27 5c 76 27 5c 5c 6e Yu-1v\(bv'\v'\\n
0fc0: 28 5e 74 75 2b 31 76 2d 5c 5c 6e 28 5e 59 75 27 (^tu+1v-\\n(^Yu'
0fd0: 5c 68 27 2d 7c 5c 5c 6e 28 5e 6c 75 2b 33 6e 27 \h'-|\\n(^lu+3n'
0fe0: 0a 2e 73 70 20 2d 31 0a 2e 66 69 0a 2e 65 76 0a ..sp -1..fi..ev.
0ff0: 2e 5c 7d 0a 2e 6e 72 20 5e 76 20 30 0a 2e 2e 0a .\}..nr ^v 0....
1000: 2e 5c 22 09 23 20 53 70 65 63 69 61 6c 20 6d 61 .\".# Special ma
1010: 63 72 6f 20 74 6f 20 68 61 6e 64 6c 65 20 70 61 cro to handle pa
1020: 67 65 20 62 6f 74 74 6f 6d 3a 20 20 66 69 6e 69 ge bottom: fini
1030: 73 68 20 6f 66 66 20 63 75 72 72 65 6e 74 0a 2e sh off current..
1040: 5c 22 09 23 20 62 6f 78 2f 73 69 64 65 62 61 72 \".# box/sidebar
1050: 20 69 66 20 69 6e 20 62 6f 78 2f 73 69 64 65 62 if in box/sideb
1060: 61 72 20 6d 6f 64 65 2c 20 74 68 65 6e 20 69 6e ar mode, then in
1070: 76 6f 6b 65 64 20 73 74 61 6e 64 61 72 64 0a 2e voked standard..
1080: 5c 22 09 23 20 70 61 67 65 20 62 6f 74 74 6f 6d \".# page bottom
1090: 20 6d 61 63 72 6f 2e 0a 2e 64 65 20 5e 42 0a 2e macro...de ^B..
10a0: 65 76 20 32 0a 27 74 69 20 30 0a 27 6e 66 0a 2e ev 2.'ti 0.'nf..
10b0: 6d 6b 20 5e 74 0a 2e 69 66 20 5c 5c 6e 28 5e 62 mk ^t..if \\n(^b
10c0: 20 5c 7b 5c 0a 2e 5c 22 09 44 72 61 77 20 74 68 \{\..\".Draw th
10d0: 72 65 65 2d 73 69 64 65 64 20 62 6f 78 20 69 66 ree-sided box if
10e0: 20 74 68 69 73 20 69 73 20 74 68 65 20 62 6f 78 this is the box
10f0: 27 73 20 66 69 72 73 74 20 70 61 67 65 2c 0a 2e 's first page,..
1100: 5c 22 09 64 72 61 77 20 74 77 6f 20 73 69 64 65 \".draw two side
1110: 73 20 62 75 74 20 6e 6f 20 74 6f 70 20 6f 74 68 s but no top oth
1120: 65 72 77 69 73 65 2e 0a 2e 69 65 20 21 5c 5c 6e erwise...ie !\\n
1130: 28 5e 62 2d 31 20 5c 68 27 2d 31 2e 35 6e 27 5c (^b-1 \h'-1.5n'\
1140: 4c 27 7c 5c 5c 6e 28 5e 79 75 2d 31 76 27 5c 6c L'|\\n(^yu-1v'\l
1150: 27 5c 5c 6e 28 5e 6c 75 2b 33 6e 5c 28 75 6c 27 '\\n(^lu+3n\(ul'
1160: 5c 4c 27 5c 5c 6e 28 5e 74 75 2b 31 76 2d 5c 5c \L'\\n(^tu+1v-\\
1170: 6e 28 5e 79 75 27 5c 68 27 7c 30 75 27 5c 63 0a n(^yu'\h'|0u'\c.
1180: 2e 65 6c 20 5c 68 27 2d 31 2e 35 6e 27 5c 4c 27 .el \h'-1.5n'\L'
1190: 7c 5c 5c 6e 28 5e 79 75 2d 31 76 27 5c 68 27 5c |\\n(^yu-1v'\h'\
11a0: 5c 6e 28 5e 6c 75 2b 33 6e 27 5c 4c 27 5c 5c 6e \n(^lu+3n'\L'\\n
11b0: 28 5e 74 75 2b 31 76 2d 5c 5c 6e 28 5e 79 75 27 (^tu+1v-\\n(^yu'
11c0: 5c 68 27 7c 30 75 27 5c 63 0a 2e 5c 7d 0a 2e 69 \h'|0u'\c..\}..i
11d0: 66 20 5c 5c 6e 28 5e 76 20 5c 7b 5c 0a 2e 6e 72 f \\n(^v \{\..nr
11e0: 20 5e 78 20 5c 5c 6e 28 5e 74 75 2b 31 76 2d 5c ^x \\n(^tu+1v-\
11f0: 5c 6e 28 5e 59 75 0a 5c 6b 78 5c 68 27 2d 5c 5c \n(^Yu.\kx\h'-\\
1200: 6e 78 75 27 5c 68 27 7c 5c 5c 6e 28 5e 6c 75 2b nxu'\h'|\\n(^lu+
1210: 33 6e 27 5c 6b 79 5c 4c 27 2d 5c 5c 6e 28 5e 78 3n'\ky\L'-\\n(^x
1220: 75 27 5c 76 27 5c 5c 6e 28 5e 78 75 27 5c 68 27 u'\v'\\n(^xu'\h'
1230: 7c 30 75 27 5c 63 0a 2e 5c 7d 0a 2e 62 70 0a 27 |0u'\c..\}..bp.'
1240: 66 69 0a 2e 65 76 0a 2e 69 66 20 5c 5c 6e 28 5e fi..ev..if \\n(^
1250: 62 20 5c 7b 5c 0a 2e 6d 6b 20 5e 79 0a 2e 6e 72 b \{\..mk ^y..nr
1260: 20 5e 62 20 32 0a 2e 5c 7d 0a 2e 69 66 20 5c 5c ^b 2..\}..if \\
1270: 6e 28 5e 76 20 5c 7b 5c 0a 2e 6d 6b 20 5e 59 0a n(^v \{\..mk ^Y.
1280: 2e 5c 7d 0a 2e 2e 0a 2e 5c 22 09 23 20 44 53 20 .\}.....\".# DS
1290: 2d 20 62 65 67 69 6e 20 64 69 73 70 6c 61 79 0a - begin display.
12a0: 2e 64 65 20 44 53 0a 2e 52 53 0a 2e 6e 66 0a 2e .de DS..RS..nf..
12b0: 73 70 0a 2e 2e 0a 2e 5c 22 09 23 20 44 45 20 2d sp.....\".# DE -
12c0: 20 65 6e 64 20 64 69 73 70 6c 61 79 0a 2e 64 65 end display..de
12d0: 20 44 45 0a 2e 66 69 0a 2e 52 45 0a 2e 73 70 0a DE..fi..RE..sp.
12e0: 2e 2e 0a 2e 5c 22 09 23 20 53 4f 20 2d 20 73 74 ....\".# SO - st
12f0: 61 72 74 20 6f 66 20 6c 69 73 74 20 6f 66 20 73 art of list of s
1300: 74 61 6e 64 61 72 64 20 6f 70 74 69 6f 6e 73 0a tandard options.
1310: 2e 64 65 20 53 4f 0a 27 69 65 20 27 5c 5c 24 31 .de SO.'ie '\\$1
1320: 27 27 20 2e 64 73 20 53 6f 20 5c 5c 66 42 6f 70 '' .ds So \\fBop
1330: 74 69 6f 6e 73 5c 5c 66 52 0a 27 65 6c 20 2e 64 tions\\fR.'el .d
1340: 73 20 53 6f 20 5c 5c 66 42 5c 5c 24 31 5c 5c 66 s So \\fB\\$1\\f
1350: 52 0a 2e 53 48 20 22 53 54 41 4e 44 41 52 44 20 R..SH "STANDARD
1360: 4f 50 54 49 4f 4e 53 22 0a 2e 4c 50 0a 2e 6e 66 OPTIONS"..LP..nf
1370: 0a 2e 74 61 20 35 2e 35 63 20 31 31 63 0a 2e 66 ..ta 5.5c 11c..f
1380: 74 20 42 0a 2e 2e 0a 2e 5c 22 09 23 20 53 45 20 t B.....\".# SE
1390: 2d 20 65 6e 64 20 6f 66 20 6c 69 73 74 20 6f 66 - end of list of
13a0: 20 73 74 61 6e 64 61 72 64 20 6f 70 74 69 6f 6e standard option
13b0: 73 0a 2e 64 65 20 53 45 0a 2e 66 69 0a 2e 66 74 s..de SE..fi..ft
13c0: 20 52 0a 2e 4c 50 0a 53 65 65 20 74 68 65 20 5c R..LP.See the \
13d0: 5c 2a 28 53 6f 20 6d 61 6e 75 61 6c 20 65 6e 74 \*(So manual ent
13e0: 72 79 20 66 6f 72 20 64 65 74 61 69 6c 73 20 6f ry for details o
13f0: 6e 20 74 68 65 20 73 74 61 6e 64 61 72 64 20 6f n the standard o
1400: 70 74 69 6f 6e 73 2e 0a 2e 2e 0a 2e 5c 22 09 23 ptions......\".#
1410: 20 4f 50 20 2d 20 73 74 61 72 74 20 6f 66 20 66 OP - start of f
1420: 75 6c 6c 20 64 65 73 63 72 69 70 74 69 6f 6e 20 ull description
1430: 66 6f 72 20 61 20 73 69 6e 67 6c 65 20 6f 70 74 for a single opt
1440: 69 6f 6e 0a 2e 64 65 20 4f 50 0a 2e 4c 50 0a 2e ion..de OP..LP..
1450: 6e 66 0a 2e 74 61 20 34 63 0a 43 6f 6d 6d 61 6e nf..ta 4c.Comman
1460: 64 2d 4c 69 6e 65 20 4e 61 6d 65 3a 09 5c 5c 66 d-Line Name:.\\f
1470: 42 5c 5c 24 31 5c 5c 66 52 0a 44 61 74 61 62 61 B\\$1\\fR.Databa
1480: 73 65 20 4e 61 6d 65 3a 09 5c 5c 66 42 5c 5c 24 se Name:.\\fB\\$
1490: 32 5c 5c 66 52 0a 44 61 74 61 62 61 73 65 20 43 2\\fR.Database C
14a0: 6c 61 73 73 3a 09 5c 5c 66 42 5c 5c 24 33 5c 5c lass:.\\fB\\$3\\
14b0: 66 52 0a 2e 66 69 0a 2e 49 50 0a 2e 2e 0a 2e 5c fR..fi..IP.....\
14c0: 22 09 23 20 43 53 20 2d 20 62 65 67 69 6e 20 63 ".# CS - begin c
14d0: 6f 64 65 20 65 78 63 65 72 70 74 0a 2e 64 65 20 ode excerpt..de
14e0: 43 53 0a 2e 52 53 0a 2e 6e 66 0a 2e 74 61 20 2e CS..RS..nf..ta .
14f0: 32 35 69 20 2e 35 69 20 2e 37 35 69 20 31 69 0a 25i .5i .75i 1i.
1500: 2e 2e 0a 2e 5c 22 09 23 20 43 45 20 2d 20 65 6e ....\".# CE - en
1510: 64 20 63 6f 64 65 20 65 78 63 65 72 70 74 0a 2e d code excerpt..
1520: 64 65 20 43 45 0a 2e 66 69 0a 2e 52 45 0a 2e 2e de CE..fi..RE...
1530: 0a 2e 5c 22 09 23 20 55 4c 20 2d 20 75 6e 64 65 ..\".# UL - unde
1540: 72 6c 69 6e 65 20 77 6f 72 64 0a 2e 64 65 20 55 rline word..de U
1550: 4c 0a 5c 5c 24 31 5c 6c 27 7c 30 5c 28 75 6c 27 L.\\$1\l'|0\(ul'
1560: 5c 5c 24 32 0a 2e 2e 0a 2e 5c 22 09 23 20 51 57 \\$2.....\".# QW
1570: 20 2d 20 61 70 70 6c 79 20 71 75 6f 74 61 74 69 - apply quotati
1580: 6f 6e 20 6d 61 72 6b 73 20 74 6f 20 77 6f 72 64 on marks to word
1590: 0a 2e 64 65 20 51 57 0a 2e 69 65 20 27 5c 5c 2a ..de QW..ie '\\*
15a0: 28 6c 71 27 22 27 20 60 60 5c 5c 24 31 27 27 5c (lq'"' ``\\$1''\
15b0: 5c 24 32 0a 2e 5c 22 22 20 66 69 78 20 65 6d 61 \$2..\"" fix ema
15c0: 63 73 20 68 69 67 68 6c 69 67 68 74 69 6e 67 0a cs highlighting.
15d0: 2e 65 6c 20 5c 5c 2a 28 6c 71 5c 5c 24 31 5c 5c .el \\*(lq\\$1\\
15e0: 2a 28 72 71 5c 5c 24 32 0a 2e 2e 0a 2e 5c 22 09 *(rq\\$2.....\".
15f0: 23 20 50 51 20 2d 20 61 70 70 6c 79 20 70 61 72 # PQ - apply par
1600: 65 6e 73 20 61 6e 64 20 71 75 6f 74 61 74 69 6f ens and quotatio
1610: 6e 20 6d 61 72 6b 73 20 74 6f 20 77 6f 72 64 0a n marks to word.
1620: 2e 64 65 20 50 51 0a 2e 69 65 20 27 5c 5c 2a 28 .de PQ..ie '\\*(
1630: 6c 71 27 22 27 20 28 60 60 5c 5c 24 31 27 27 5c lq'"' (``\\$1''\
1640: 5c 24 32 29 5c 5c 24 33 0a 2e 5c 22 22 20 66 69 \$2)\\$3..\"" fi
1650: 78 20 65 6d 61 63 73 20 68 69 67 68 6c 69 67 68 x emacs highligh
1660: 74 69 6e 67 0a 2e 65 6c 20 28 5c 5c 2a 28 6c 71 ting..el (\\*(lq
1670: 5c 5c 24 31 5c 5c 2a 28 72 71 5c 5c 24 32 29 5c \\$1\\*(rq\\$2)\
1680: 5c 24 33 0a 2e 2e 0a 2e 5c 22 09 23 20 51 52 20 \$3.....\".# QR
1690: 2d 20 71 75 6f 74 65 64 20 72 61 6e 67 65 0a 2e - quoted range..
16a0: 64 65 20 51 52 0a 2e 69 65 20 27 5c 5c 2a 28 6c de QR..ie '\\*(l
16b0: 71 27 22 27 20 60 60 5c 5c 24 31 27 27 5c 5c 2d q'"' ``\\$1''\\-
16c0: 60 60 5c 5c 24 32 27 27 5c 5c 24 33 0a 2e 5c 22 ``\\$2''\\$3..\"
16d0: 22 20 66 69 78 20 65 6d 61 63 73 20 68 69 67 68 " fix emacs high
16e0: 6c 69 67 68 74 69 6e 67 0a 2e 65 6c 20 5c 5c 2a lighting..el \\*
16f0: 28 6c 71 5c 5c 24 31 5c 5c 2a 28 72 71 5c 5c 2d (lq\\$1\\*(rq\\-
1700: 5c 5c 2a 28 6c 71 5c 5c 24 32 5c 5c 2a 28 72 71 \\*(lq\\$2\\*(rq
1710: 5c 5c 24 33 0a 2e 2e 0a 2e 5c 22 09 23 20 4d 54 \\$3.....\".# MT
1720: 20 2d 20 22 65 6d 70 74 79 22 20 73 74 72 69 6e - "empty" strin
1730: 67 0a 2e 64 65 20 4d 54 0a 2e 51 57 20 22 22 0a g..de MT..QW "".
1740: 2e 2e 0a 2e 42 53 0a 2e 53 48 20 4e 41 4d 45 0a ....BS..SH NAME.
1750: 6d 61 74 68 3a 3a 66 6f 75 72 69 65 72 20 5c 2d math::fourier \-
1760: 20 44 69 73 63 72 65 74 65 20 61 6e 64 20 66 61 Discrete and fa
1770: 73 74 20 66 6f 75 72 69 65 72 20 74 72 61 6e 73 st fourier trans
1780: 66 6f 72 6d 73 0a 2e 53 48 20 53 59 4e 4f 50 53 forms..SH SYNOPS
1790: 49 53 0a 70 61 63 6b 61 67 65 20 72 65 71 75 69 IS.package requi
17a0: 72 65 20 5c 66 42 54 63 6c 20 38 5c 26 2e 35 20 re \fBTcl 8\&.5
17b0: 39 5c 66 52 0a 2e 73 70 0a 70 61 63 6b 61 67 65 9\fR..sp.package
17c0: 20 72 65 71 75 69 72 65 20 5c 66 42 6d 61 74 68 require \fBmath
17d0: 3a 3a 66 6f 75 72 69 65 72 20 31 5c 26 2e 30 5c ::fourier 1\&.0\
17e0: 26 2e 33 5c 66 52 0a 2e 73 70 0a 5c 66 42 3a 3a &.3\fR..sp.\fB::
17f0: 6d 61 74 68 3a 3a 66 6f 75 72 69 65 72 3a 3a 64 math::fourier::d
1800: 66 74 5c 66 52 20 5c 66 49 69 6e 5f 64 61 74 61 ft\fR \fIin_data
1810: 5c 66 52 0a 2e 73 70 0a 5c 66 42 3a 3a 6d 61 74 \fR..sp.\fB::mat
1820: 68 3a 3a 66 6f 75 72 69 65 72 3a 3a 69 6e 76 65 h::fourier::inve
1830: 72 73 65 5f 64 66 74 5c 66 52 20 5c 66 49 69 6e rse_dft\fR \fIin
1840: 5f 64 61 74 61 5c 66 52 0a 2e 73 70 0a 5c 66 42 _data\fR..sp.\fB
1850: 3a 3a 6d 61 74 68 3a 3a 66 6f 75 72 69 65 72 3a ::math::fourier:
1860: 3a 6c 6f 77 70 61 73 73 5c 66 52 20 5c 66 49 63 :lowpass\fR \fIc
1870: 75 74 6f 66 66 5c 66 52 20 5c 66 49 69 6e 5f 64 utoff\fR \fIin_d
1880: 61 74 61 5c 66 52 0a 2e 73 70 0a 5c 66 42 3a 3a ata\fR..sp.\fB::
1890: 6d 61 74 68 3a 3a 66 6f 75 72 69 65 72 3a 3a 68 math::fourier::h
18a0: 69 67 68 70 61 73 73 5c 66 52 20 5c 66 49 63 75 ighpass\fR \fIcu
18b0: 74 6f 66 66 5c 66 52 20 5c 66 49 69 6e 5f 64 61 toff\fR \fIin_da
18c0: 74 61 5c 66 52 0a 2e 73 70 0a 2e 42 45 0a 2e 53 ta\fR..sp..BE..S
18d0: 48 20 44 45 53 43 52 49 50 54 49 4f 4e 0a 2e 50 H DESCRIPTION..P
18e0: 50 0a 54 68 65 20 5c 66 42 6d 61 74 68 3a 3a 66 P.The \fBmath::f
18f0: 6f 75 72 69 65 72 5c 66 52 20 70 61 63 6b 61 67 ourier\fR packag
1900: 65 20 75 73 65 73 20 74 68 65 20 66 61 73 74 0a e uses the fast.
1910: 46 6f 75 72 69 65 72 20 74 72 61 6e 73 66 6f 72 Fourier transfor
1920: 6d 2c 20 69 66 20 61 70 70 6c 69 63 61 62 6c 65 m, if applicable
1930: 2c 20 6f 72 20 74 68 65 20 6f 72 64 69 6e 61 72 , or the ordinar
1940: 79 20 74 72 61 6e 73 66 6f 72 6d 20 74 6f 20 69 y transform to i
1950: 6d 70 6c 65 6d 65 6e 74 0a 74 68 65 20 64 69 73 mplement.the dis
1960: 63 72 65 74 65 20 46 6f 75 72 69 65 72 20 74 72 crete Fourier tr
1970: 61 6e 73 66 6f 72 6d 5c 26 2e 20 49 74 20 61 6c ansform\&. It al
1980: 73 6f 20 70 72 6f 76 69 64 65 73 20 61 20 66 65 so provides a fe
1990: 77 20 73 69 6d 70 6c 65 20 66 69 6c 74 65 72 0a w simple filter.
19a0: 70 72 6f 63 65 64 75 72 65 73 20 61 73 20 61 6e procedures as an
19b0: 20 69 6c 6c 75 73 74 72 61 74 69 6f 6e 20 6f 66 illustration of
19c0: 20 68 6f 77 20 73 75 63 68 20 66 69 6c 74 65 72 how such filter
19d0: 73 20 63 61 6e 20 62 65 20 69 6d 70 6c 65 6d 65 s can be impleme
19e0: 6e 74 65 64 5c 26 2e 0a 2e 50 50 0a 54 68 65 20 nted\&...PP.The
19f0: 70 75 72 70 6f 73 65 20 6f 66 20 74 68 69 73 20 purpose of this
1a00: 64 6f 63 75 6d 65 6e 74 20 69 73 20 74 6f 20 64 document is to d
1a10: 65 73 63 72 69 62 65 20 74 68 65 20 69 6d 70 6c escribe the impl
1a20: 65 6d 65 6e 74 65 64 20 70 72 6f 63 65 64 75 72 emented procedur
1a30: 65 73 0a 61 6e 64 20 70 72 6f 76 69 64 65 20 73 es.and provide s
1a40: 6f 6d 65 20 65 78 61 6d 70 6c 65 73 20 6f 66 20 ome examples of
1a50: 74 68 65 69 72 20 75 73 61 67 65 5c 26 2e 20 41 their usage\&. A
1a60: 73 20 74 68 65 72 65 20 69 73 20 61 6d 70 6c 65 s there is ample
1a70: 20 6c 69 74 65 72 61 74 75 72 65 0a 6f 6e 20 74 literature.on t
1a80: 68 65 20 61 6c 67 6f 72 69 74 68 6d 73 20 69 6e he algorithms in
1a90: 76 6f 6c 76 65 64 2c 20 77 65 20 72 65 66 65 72 volved, we refer
1aa0: 20 74 6f 20 72 65 6c 65 76 61 6e 74 20 74 65 78 to relevant tex
1ab0: 74 20 62 6f 6f 6b 73 20 66 6f 72 20 6d 6f 72 65 t books for more
1ac0: 0a 65 78 70 6c 61 6e 61 74 69 6f 6e 73 5c 26 2e .explanations\&.
1ad0: 20 57 65 20 61 6c 73 6f 20 72 65 66 65 72 20 74 We also refer t
1ae0: 6f 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 57 o the original W
1af0: 69 6b 69 20 70 61 67 65 20 6f 6e 20 74 68 65 20 iki page on the
1b00: 73 75 62 6a 65 63 74 0a 77 68 69 63 68 20 64 65 subject.which de
1b10: 73 63 72 69 62 65 73 20 73 6f 6d 65 20 6f 66 20 scribes some of
1b20: 74 68 65 20 63 6f 6e 73 69 64 65 72 61 74 69 6f the consideratio
1b30: 6e 73 20 62 65 68 69 6e 64 20 74 68 65 20 63 75 ns behind the cu
1b40: 72 72 65 6e 74 0a 69 6d 70 6c 65 6d 65 6e 74 61 rrent.implementa
1b50: 74 69 6f 6e 5c 26 2e 0a 2e 53 48 20 22 47 45 4e tion\&...SH "GEN
1b60: 45 52 41 4c 20 49 4e 46 4f 52 4d 41 54 49 4f 4e ERAL INFORMATION
1b70: 22 0a 54 68 65 20 74 77 6f 20 74 6f 70 2d 6c 65 ".The two top-le
1b80: 76 65 6c 20 70 72 6f 63 65 64 75 72 65 73 20 64 vel procedures d
1b90: 65 66 69 6e 65 64 20 61 72 65 0a 2e 49 50 20 5c efined are..IP \
1ba0: 28 62 75 0a 64 66 74 20 64 61 74 61 2d 6c 69 73 (bu.dft data-lis
1bb0: 74 0a 2e 49 50 20 5c 28 62 75 0a 69 6e 76 65 72 t..IP \(bu.inver
1bc0: 73 65 5f 64 66 74 20 64 61 74 61 2d 6c 69 73 74 se_dft data-list
1bd0: 0a 2e 50 50 0a 42 6f 74 68 20 74 61 6b 65 20 61 ..PP.Both take a
1be0: 20 6c 69 73 74 20 6f 66 20 5c 66 49 63 6f 6d 70 list of \fIcomp
1bf0: 6c 65 78 20 6e 75 6d 62 65 72 73 5c 66 52 20 61 lex numbers\fR a
1c00: 6e 64 20 61 70 70 6c 79 20 61 20 44 69 73 63 72 nd apply a Discr
1c10: 65 74 65 20 46 6f 75 72 69 65 72 0a 54 72 61 6e ete Fourier.Tran
1c20: 73 66 6f 72 6d 20 28 44 46 54 29 20 6f 72 20 69 sform (DFT) or i
1c30: 74 73 20 69 6e 76 65 72 73 65 20 72 65 73 70 65 ts inverse respe
1c40: 63 74 69 76 65 6c 79 20 74 6f 20 74 68 65 73 65 ctively to these
1c50: 20 6c 69 73 74 73 20 6f 66 20 6e 75 6d 62 65 72 lists of number
1c60: 73 5c 26 2e 0a 41 20 22 63 6f 6d 70 6c 65 78 20 s\&..A "complex
1c70: 6e 75 6d 62 65 72 22 20 69 6e 20 74 68 69 73 20 number" in this
1c80: 63 61 73 65 20 69 73 20 65 69 74 68 65 72 20 28 case is either (
1c90: 69 29 20 61 20 70 61 69 72 20 28 74 77 6f 20 65 i) a pair (two e
1ca0: 6c 65 6d 65 6e 74 20 6c 69 73 74 29 20 6f 66 0a lement list) of.
1cb0: 6e 75 6d 62 65 72 73 2c 20 69 6e 74 65 72 70 72 numbers, interpr
1cc0: 65 74 65 64 20 61 73 20 74 68 65 20 72 65 61 6c eted as the real
1cd0: 20 61 6e 64 20 69 6d 61 67 69 6e 61 72 79 20 70 and imaginary p
1ce0: 61 72 74 73 20 6f 66 20 74 68 65 20 63 6f 6d 70 arts of the comp
1cf0: 6c 65 78 20 6e 75 6d 62 65 72 2c 0a 6f 72 20 28 lex number,.or (
1d00: 69 69 29 20 61 20 73 69 6e 67 6c 65 20 6e 75 6d ii) a single num
1d10: 62 65 72 2c 20 69 6e 74 65 72 70 72 65 74 65 64 ber, interpreted
1d20: 20 61 73 20 74 68 65 20 72 65 61 6c 20 70 61 72 as the real par
1d30: 74 20 6f 66 20 61 20 63 6f 6d 70 6c 65 78 20 6e t of a complex n
1d40: 75 6d 62 65 72 0a 77 68 6f 73 65 20 69 6d 61 67 umber.whose imag
1d50: 69 6e 61 72 79 20 70 61 72 74 20 69 73 20 7a 65 inary part is ze
1d60: 72 6f 5c 26 2e 20 54 68 65 20 72 65 74 75 72 6e ro\&. The return
1d70: 20 76 61 6c 75 65 20 69 73 20 61 6c 77 61 79 73 value is always
1d80: 20 69 6e 20 74 68 65 0a 66 69 72 73 74 20 66 6f in the.first fo
1d90: 72 6d 61 74 5c 26 2e 20 28 54 68 65 20 44 46 54 rmat\&. (The DFT
1da0: 20 67 65 6e 65 72 61 6c 6c 79 20 70 72 6f 64 75 generally produ
1db0: 63 65 73 20 63 6f 6d 70 6c 65 78 20 72 65 73 75 ces complex resu
1dc0: 6c 74 73 20 65 76 65 6e 20 69 66 20 74 68 65 0a lts even if the.
1dd0: 69 6e 70 75 74 20 69 73 20 70 75 72 65 6c 79 20 input is purely
1de0: 72 65 61 6c 5c 26 2e 29 20 41 70 70 6c 79 69 6e real\&.) Applyin
1df0: 67 20 66 69 72 73 74 20 6f 6e 65 20 61 6e 64 20 g first one and
1e00: 74 68 65 6e 20 74 68 65 20 6f 74 68 65 72 20 6f then the other o
1e10: 66 20 74 68 65 73 65 0a 70 72 6f 63 65 64 75 72 f these.procedur
1e20: 65 73 20 74 6f 20 61 20 6c 69 73 74 20 6f 66 20 es to a list of
1e30: 63 6f 6d 70 6c 65 78 20 6e 75 6d 62 65 72 73 20 complex numbers
1e40: 77 69 6c 6c 20 28 6d 6f 64 75 6c 6f 20 72 6f 75 will (modulo rou
1e50: 6e 64 69 6e 67 20 65 72 72 6f 72 73 0a 64 75 65 nding errors.due
1e60: 20 74 6f 20 66 6c 6f 61 74 69 6e 67 20 70 6f 69 to floating poi
1e70: 6e 74 20 61 72 69 74 68 6d 65 74 69 63 29 20 72 nt arithmetic) r
1e80: 65 74 75 72 6e 20 74 68 65 20 6f 72 69 67 69 6e eturn the origin
1e90: 61 6c 20 6c 69 73 74 20 6f 66 20 6e 75 6d 62 65 al list of numbe
1ea0: 72 73 5c 26 2e 0a 2e 50 50 0a 49 66 20 74 68 65 rs\&...PP.If the
1eb0: 20 69 6e 70 75 74 20 6c 65 6e 67 74 68 20 4e 20 input length N
1ec0: 69 73 20 61 20 70 6f 77 65 72 20 6f 66 20 74 77 is a power of tw
1ed0: 6f 20 74 68 65 6e 20 74 68 65 73 65 20 70 72 6f o then these pro
1ee0: 63 65 64 75 72 65 73 20 77 69 6c 6c 0a 75 74 69 cedures will.uti
1ef0: 6c 69 7a 65 20 74 68 65 20 4f 28 4e 20 6c 6f 67 lize the O(N log
1f00: 20 4e 29 20 46 61 73 74 20 46 6f 75 72 69 65 72 N) Fast Fourier
1f10: 20 54 72 61 6e 73 66 6f 72 6d 20 61 6c 67 6f 72 Transform algor
1f20: 69 74 68 6d 5c 26 2e 20 49 66 20 69 6e 70 75 74 ithm\&. If input
1f30: 0a 6c 65 6e 67 74 68 20 69 73 20 6e 6f 74 20 61 .length is not a
1f40: 20 70 6f 77 65 72 20 6f 66 20 74 77 6f 20 74 68 power of two th
1f50: 65 6e 20 74 68 65 20 44 46 54 20 77 69 6c 6c 20 en the DFT will
1f60: 69 6e 73 74 65 61 64 20 62 65 20 63 6f 6d 70 75 instead be compu
1f70: 74 65 64 0a 75 73 69 6e 67 20 74 68 65 20 6e 61 ted.using the na
1f80: 69 76 65 20 71 75 61 64 72 61 74 69 63 20 61 6c ive quadratic al
1f90: 67 6f 72 69 74 68 6d 5c 26 2e 0a 2e 50 50 0a 53 gorithm\&...PP.S
1fa0: 6f 6d 65 20 65 78 61 6d 70 6c 65 73 3a 0a 2e 43 ome examples:..C
1fb0: 53 0a 0a 0a 20 20 20 20 25 20 64 66 74 20 7b 31 S... % dft {1
1fc0: 20 32 20 33 20 34 7d 0a 20 20 20 20 7b 31 30 20 2 3 4}. {10
1fd0: 30 5c 26 2e 30 7d 20 7b 2d 32 5c 26 2e 30 20 32 0\&.0} {-2\&.0 2
1fe0: 5c 26 2e 30 7d 20 7b 2d 32 20 30 5c 26 2e 30 7d \&.0} {-2 0\&.0}
1ff0: 20 7b 2d 32 5c 26 2e 30 20 2d 32 5c 26 2e 30 7d {-2\&.0 -2\&.0}
2000: 0a 20 20 20 20 25 20 69 6e 76 65 72 73 65 5f 64 . % inverse_d
2010: 66 74 20 7b 7b 31 30 20 30 5c 26 2e 30 7d 20 7b ft {{10 0\&.0} {
2020: 2d 32 5c 26 2e 30 20 32 5c 26 2e 30 7d 20 7b 2d -2\&.0 2\&.0} {-
2030: 32 20 30 5c 26 2e 30 7d 20 7b 2d 32 5c 26 2e 30 2 0\&.0} {-2\&.0
2040: 20 2d 32 5c 26 2e 30 7d 7d 0a 20 20 20 20 7b 31 -2\&.0}}. {1
2050: 5c 26 2e 30 20 30 5c 26 2e 30 7d 20 7b 32 5c 26 \&.0 0\&.0} {2\&
2060: 2e 30 20 30 5c 26 2e 30 7d 20 7b 33 5c 26 2e 30 .0 0\&.0} {3\&.0
2070: 20 30 5c 26 2e 30 7d 20 7b 34 5c 26 2e 30 20 30 0\&.0} {4\&.0 0
2080: 5c 26 2e 30 7d 0a 20 20 20 20 25 20 64 66 74 20 \&.0}. % dft
2090: 7b 31 20 32 20 33 20 34 20 35 7d 0a 20 20 20 20 {1 2 3 4 5}.
20a0: 7b 31 35 5c 26 2e 30 20 30 5c 26 2e 30 7d 20 7b {15\&.0 0\&.0} {
20b0: 2d 32 5c 26 2e 35 20 33 5c 26 2e 34 34 30 39 35 -2\&.5 3\&.44095
20c0: 34 38 30 31 31 38 7d 20 7b 2d 32 5c 26 2e 35 20 480118} {-2\&.5
20d0: 30 5c 26 2e 38 31 32 32 39 39 32 34 30 35 38 32 0\&.812299240582
20e0: 7d 20 7b 2d 32 5c 26 2e 35 20 2d 30 5c 26 2e 38 } {-2\&.5 -0\&.8
20f0: 31 32 32 39 39 32 34 30 35 38 32 7d 20 7b 2d 32 12299240582} {-2
2100: 5c 26 2e 35 20 2d 33 5c 26 2e 34 34 30 39 35 34 \&.5 -3\&.440954
2110: 38 30 31 31 38 7d 0a 20 20 20 20 25 20 69 6e 76 80118}. % inv
2120: 65 72 73 65 5f 64 66 74 20 7b 7b 31 35 5c 26 2e erse_dft {{15\&.
2130: 30 20 30 5c 26 2e 30 7d 20 7b 2d 32 5c 26 2e 35 0 0\&.0} {-2\&.5
2140: 20 33 5c 26 2e 34 34 30 39 35 34 38 30 31 31 38 3\&.44095480118
2150: 7d 20 7b 2d 32 5c 26 2e 35 20 30 5c 26 2e 38 31 } {-2\&.5 0\&.81
2160: 32 32 39 39 32 34 30 35 38 32 7d 20 7b 2d 32 5c 2299240582} {-2\
2170: 26 2e 35 20 2d 30 5c 26 2e 38 31 32 32 39 39 32 &.5 -0\&.8122992
2180: 34 30 35 38 32 7d 20 7b 2d 32 5c 26 2e 35 20 2d 40582} {-2\&.5 -
2190: 33 5c 26 2e 34 34 30 39 35 34 38 30 31 31 38 7d 3\&.44095480118}
21a0: 7d 0a 20 20 20 20 7b 31 5c 26 2e 30 20 30 5c 26 }. {1\&.0 0\&
21b0: 2e 30 7d 20 7b 32 5c 26 2e 30 20 38 5c 26 2e 38 .0} {2\&.0 8\&.8
21c0: 38 31 37 38 34 31 39 37 65 2d 31 37 7d 20 7b 33 81784197e-17} {3
21d0: 5c 26 2e 30 20 34 5c 26 2e 34 34 30 38 39 32 30 \&.0 4\&.4408920
21e0: 39 38 35 65 2d 31 37 7d 20 7b 34 5c 26 2e 30 20 985e-17} {4\&.0
21f0: 34 5c 26 2e 34 34 30 38 39 32 30 39 38 35 65 2d 4\&.4408920985e-
2200: 31 37 7d 20 7b 35 5c 26 2e 30 20 2d 38 5c 26 2e 17} {5\&.0 -8\&.
2210: 38 38 31 37 38 34 31 39 37 65 2d 31 37 7d 0a 0a 881784197e-17}..
2220: 2e 43 45 0a 2e 50 50 0a 49 6e 20 74 68 65 20 6c .CE..PP.In the l
2230: 61 73 74 20 63 61 73 65 2c 20 74 68 65 20 69 6d ast case, the im
2240: 61 67 69 6e 61 72 79 20 70 61 72 74 73 20 3c 31 aginary parts <1
2250: 65 2d 31 36 20 77 6f 75 6c 64 20 68 61 76 65 20 e-16 would have
2260: 62 65 65 6e 20 7a 65 72 6f 20 69 6e 20 65 78 61 been zero in exa
2270: 63 74 0a 61 72 69 74 68 6d 65 74 69 63 2c 20 62 ct.arithmetic, b
2280: 75 74 20 61 72 65 6e 27 74 20 68 65 72 65 20 64 ut aren't here d
2290: 75 65 20 74 6f 20 72 6f 75 6e 64 69 6e 67 20 65 ue to rounding e
22a0: 72 72 6f 72 73 5c 26 2e 0a 2e 50 50 0a 49 6e 74 rrors\&...PP.Int
22b0: 65 72 6e 61 6c 6c 79 2c 20 74 68 65 20 70 72 6f ernally, the pro
22c0: 63 65 64 75 72 65 73 20 75 73 65 20 61 20 66 6c cedures use a fl
22d0: 61 74 20 6c 69 73 74 20 66 6f 72 6d 61 74 20 77 at list format w
22e0: 68 65 72 65 20 65 76 65 72 79 20 65 76 65 6e 0a here every even.
22f0: 69 6e 64 65 78 20 65 6c 65 6d 65 6e 74 20 6f 66 index element of
2300: 20 61 20 6c 69 73 74 20 69 73 20 61 20 72 65 61 a list is a rea
2310: 6c 20 70 61 72 74 20 61 6e 64 20 65 76 65 72 79 l part and every
2320: 20 6f 64 64 20 69 6e 64 65 78 20 65 6c 65 6d 65 odd index eleme
2330: 6e 74 0a 69 73 20 61 6e 20 69 6d 61 67 69 6e 61 nt.is an imagina
2340: 72 79 20 70 61 72 74 5c 26 2e 20 54 68 69 73 20 ry part\&. This
2350: 69 73 20 72 65 66 6c 65 63 74 65 64 20 69 6e 20 is reflected in
2360: 74 68 65 20 76 61 72 69 61 62 6c 65 20 6e 61 6d the variable nam
2370: 65 73 20 62 79 20 52 65 5f 0a 61 6e 64 20 49 6d es by Re_.and Im
2380: 5f 20 70 72 65 66 69 78 65 73 5c 26 2e 0a 2e 50 _ prefixes\&...P
2390: 50 0a 54 68 65 20 70 61 63 6b 61 67 65 20 69 6e P.The package in
23a0: 63 6c 75 64 65 73 20 74 77 6f 20 73 69 6d 70 6c cludes two simpl
23b0: 65 20 66 69 6c 74 65 72 73 5c 26 2e 20 54 68 65 e filters\&. The
23c0: 79 20 68 61 76 65 20 61 6e 20 61 6e 61 6c 6f 67 y have an analog
23d0: 75 65 0a 65 71 75 69 76 61 6c 65 6e 74 20 69 6e ue.equivalent in
23e0: 20 61 20 73 69 6d 70 6c 65 20 65 6c 65 63 74 72 a simple electr
23f0: 6f 6e 69 63 20 63 69 72 63 75 69 74 2c 20 61 20 onic circuit, a
2400: 72 65 73 69 73 74 6f 72 20 61 6e 64 20 61 20 63 resistor and a c
2410: 61 70 61 63 69 74 61 6e 63 65 0a 69 6e 20 73 65 apacitance.in se
2420: 72 69 65 73 5c 26 2e 20 55 73 69 6e 67 20 74 68 ries\&. Using th
2430: 65 73 65 20 66 69 6c 74 65 72 73 20 72 65 71 75 ese filters requ
2440: 69 72 65 73 20 74 68 65 0a 5c 66 42 6d 61 74 68 ires the.\fBmath
2450: 3a 3a 63 6f 6d 70 6c 65 78 6e 75 6d 62 65 72 73 ::complexnumbers
2460: 5c 66 52 20 70 61 63 6b 61 67 65 5c 26 2e 0a 2e \fR package\&...
2470: 53 48 20 50 52 4f 43 45 44 55 52 45 53 0a 54 68 SH PROCEDURES.Th
2480: 65 20 70 75 62 6c 69 63 20 46 6f 75 72 69 65 72 e public Fourier
2490: 20 74 72 61 6e 73 66 6f 72 6d 20 70 72 6f 63 65 transform proce
24a0: 64 75 72 65 73 20 61 72 65 3a 0a 2e 54 50 0a 5c dures are:..TP.\
24b0: 66 42 3a 3a 6d 61 74 68 3a 3a 66 6f 75 72 69 65 fB::math::fourie
24c0: 72 3a 3a 64 66 74 5c 66 52 20 5c 66 49 69 6e 5f r::dft\fR \fIin_
24d0: 64 61 74 61 5c 66 52 0a 44 65 74 65 72 6d 69 6e data\fR.Determin
24e0: 65 20 74 68 65 20 5c 66 49 46 6f 75 72 69 65 72 e the \fIFourier
24f0: 20 74 72 61 6e 73 66 6f 72 6d 5c 66 52 20 6f 66 transform\fR of
2500: 20 74 68 65 20 67 69 76 65 6e 20 6c 69 73 74 20 the given list
2510: 6f 66 20 63 6f 6d 70 6c 65 78 0a 6e 75 6d 62 65 of complex.numbe
2520: 72 73 5c 26 2e 20 54 68 65 20 72 65 73 75 6c 74 rs\&. The result
2530: 20 69 73 20 61 20 6c 69 73 74 20 6f 66 20 63 6f is a list of co
2540: 6d 70 6c 65 78 20 6e 75 6d 62 65 72 73 20 72 65 mplex numbers re
2550: 70 72 65 73 65 6e 74 69 6e 67 20 74 68 65 0a 28 presenting the.(
2560: 63 6f 6d 70 6c 65 78 29 20 61 6d 70 6c 69 74 75 complex) amplitu
2570: 64 65 73 20 6f 66 20 74 68 65 20 46 6f 75 72 69 des of the Fouri
2580: 65 72 20 63 6f 6d 70 6f 6e 65 6e 74 73 5c 26 2e er components\&.
2590: 0a 2e 52 53 0a 2e 54 50 0a 6c 69 73 74 20 5c 66 ..RS..TP.list \f
25a0: 49 69 6e 5f 64 61 74 61 5c 66 52 0a 4c 69 73 74 Iin_data\fR.List
25b0: 20 6f 66 20 64 61 74 61 0a 2e 52 45 0a 2e 73 70 of data..RE..sp
25c0: 0a 2e 54 50 0a 5c 66 42 3a 3a 6d 61 74 68 3a 3a ..TP.\fB::math::
25d0: 66 6f 75 72 69 65 72 3a 3a 69 6e 76 65 72 73 65 fourier::inverse
25e0: 5f 64 66 74 5c 66 52 20 5c 66 49 69 6e 5f 64 61 _dft\fR \fIin_da
25f0: 74 61 5c 66 52 0a 44 65 74 65 72 6d 69 6e 65 20 ta\fR.Determine
2600: 74 68 65 20 5c 66 49 69 6e 76 65 72 73 65 20 46 the \fIinverse F
2610: 6f 75 72 69 65 72 20 74 72 61 6e 73 66 6f 72 6d ourier transform
2620: 5c 66 52 20 6f 66 20 74 68 65 20 67 69 76 65 6e \fR of the given
2630: 20 6c 69 73 74 20 6f 66 0a 63 6f 6d 70 6c 65 78 list of.complex
2640: 20 6e 75 6d 62 65 72 73 20 28 69 6e 74 65 72 70 numbers (interp
2650: 72 65 74 65 64 20 61 73 20 61 6d 70 6c 69 74 75 reted as amplitu
2660: 64 65 73 29 5c 26 2e 20 54 68 65 20 72 65 73 75 des)\&. The resu
2670: 6c 74 20 69 73 20 61 20 6c 69 73 74 20 6f 66 0a lt is a list of.
2680: 63 6f 6d 70 6c 65 78 20 6e 75 6d 62 65 72 73 20 complex numbers
2690: 72 65 70 72 65 73 65 6e 74 69 6e 67 20 74 68 65 representing the
26a0: 20 6f 72 69 67 69 6e 61 6c 20 28 63 6f 6d 70 6c original (compl
26b0: 65 78 29 20 64 61 74 61 0a 2e 52 53 0a 2e 54 50 ex) data..RS..TP
26c0: 0a 6c 69 73 74 20 5c 66 49 69 6e 5f 64 61 74 61 .list \fIin_data
26d0: 5c 66 52 0a 4c 69 73 74 20 6f 66 20 64 61 74 61 \fR.List of data
26e0: 20 28 61 6d 70 6c 69 74 75 64 65 73 29 0a 2e 52 (amplitudes)..R
26f0: 45 0a 2e 73 70 0a 2e 54 50 0a 5c 66 42 3a 3a 6d E..sp..TP.\fB::m
2700: 61 74 68 3a 3a 66 6f 75 72 69 65 72 3a 3a 6c 6f ath::fourier::lo
2710: 77 70 61 73 73 5c 66 52 20 5c 66 49 63 75 74 6f wpass\fR \fIcuto
2720: 66 66 5c 66 52 20 5c 66 49 69 6e 5f 64 61 74 61 ff\fR \fIin_data
2730: 5c 66 52 0a 46 69 6c 74 65 72 20 74 68 65 20 28 \fR.Filter the (
2740: 63 6f 6d 70 6c 65 78 29 20 61 6d 70 6c 69 74 75 complex) amplitu
2750: 64 65 73 20 73 6f 20 74 68 61 74 20 68 69 67 68 des so that high
2760: 2d 66 72 65 71 75 65 6e 63 79 20 63 6f 6d 70 6f -frequency compo
2770: 6e 65 6e 74 73 0a 61 72 65 20 73 75 70 70 72 65 nents.are suppre
2780: 73 73 65 64 5c 26 2e 20 54 68 65 20 69 6d 70 6c ssed\&. The impl
2790: 65 6d 65 6e 74 65 64 20 66 69 6c 74 65 72 20 69 emented filter i
27a0: 73 20 61 20 66 69 72 73 74 2d 6f 72 64 65 72 20 s a first-order
27b0: 6c 6f 77 2d 70 61 73 73 20 66 69 6c 74 65 72 2c low-pass filter,
27c0: 0a 74 68 65 20 64 69 73 63 72 65 74 65 20 65 71 .the discrete eq
27d0: 75 69 76 61 6c 65 6e 74 20 6f 66 20 61 20 73 69 uivalent of a si
27e0: 6d 70 6c 65 20 65 6c 65 63 74 72 6f 6e 69 63 20 mple electronic
27f0: 63 69 72 63 75 69 74 20 77 69 74 68 20 61 20 72 circuit with a r
2800: 65 73 69 73 74 6f 72 0a 61 6e 64 20 61 20 63 61 esistor.and a ca
2810: 70 61 63 69 74 61 6e 63 65 5c 26 2e 0a 2e 52 53 pacitance\&...RS
2820: 0a 2e 54 50 0a 66 6c 6f 61 74 20 5c 66 49 63 75 ..TP.float \fIcu
2830: 74 6f 66 66 5c 66 52 0a 43 75 74 2d 6f 66 66 20 toff\fR.Cut-off
2840: 66 72 65 71 75 65 6e 63 79 0a 2e 54 50 0a 6c 69 frequency..TP.li
2850: 73 74 20 5c 66 49 69 6e 5f 64 61 74 61 5c 66 52 st \fIin_data\fR
2860: 0a 4c 69 73 74 20 6f 66 20 64 61 74 61 20 28 61 .List of data (a
2870: 6d 70 6c 69 74 75 64 65 73 29 0a 2e 52 45 0a 2e mplitudes)..RE..
2880: 73 70 0a 2e 54 50 0a 5c 66 42 3a 3a 6d 61 74 68 sp..TP.\fB::math
2890: 3a 3a 66 6f 75 72 69 65 72 3a 3a 68 69 67 68 70 ::fourier::highp
28a0: 61 73 73 5c 66 52 20 5c 66 49 63 75 74 6f 66 66 ass\fR \fIcutoff
28b0: 5c 66 52 20 5c 66 49 69 6e 5f 64 61 74 61 5c 66 \fR \fIin_data\f
28c0: 52 0a 46 69 6c 74 65 72 20 74 68 65 20 28 63 6f R.Filter the (co
28d0: 6d 70 6c 65 78 29 20 61 6d 70 6c 69 74 75 64 65 mplex) amplitude
28e0: 73 20 73 6f 20 74 68 61 74 20 6c 6f 77 2d 66 72 s so that low-fr
28f0: 65 71 75 65 6e 63 79 20 63 6f 6d 70 6f 6e 65 6e equency componen
2900: 74 73 0a 61 72 65 20 73 75 70 70 72 65 73 73 65 ts.are suppresse
2910: 64 5c 26 2e 20 54 68 65 20 69 6d 70 6c 65 6d 65 d\&. The impleme
2920: 6e 74 65 64 20 66 69 6c 74 65 72 20 69 73 20 61 nted filter is a
2930: 20 66 69 72 73 74 2d 6f 72 64 65 72 20 6c 6f 77 first-order low
2940: 2d 70 61 73 73 20 66 69 6c 74 65 72 2c 0a 74 68 -pass filter,.th
2950: 65 20 64 69 73 63 72 65 74 65 20 65 71 75 69 76 e discrete equiv
2960: 61 6c 65 6e 74 20 6f 66 20 61 20 73 69 6d 70 6c alent of a simpl
2970: 65 20 65 6c 65 63 74 72 6f 6e 69 63 20 63 69 72 e electronic cir
2980: 63 75 69 74 20 77 69 74 68 20 61 20 72 65 73 69 cuit with a resi
2990: 73 74 6f 72 0a 61 6e 64 20 61 20 63 61 70 61 63 stor.and a capac
29a0: 69 74 61 6e 63 65 5c 26 2e 0a 2e 52 53 0a 2e 54 itance\&...RS..T
29b0: 50 0a 66 6c 6f 61 74 20 5c 66 49 63 75 74 6f 66 P.float \fIcutof
29c0: 66 5c 66 52 0a 43 75 74 2d 6f 66 66 20 66 72 65 f\fR.Cut-off fre
29d0: 71 75 65 6e 63 79 0a 2e 54 50 0a 6c 69 73 74 20 quency..TP.list
29e0: 5c 66 49 69 6e 5f 64 61 74 61 5c 66 52 0a 4c 69 \fIin_data\fR.Li
29f0: 73 74 20 6f 66 20 64 61 74 61 20 28 61 6d 70 6c st of data (ampl
2a00: 69 74 75 64 65 73 29 0a 2e 52 45 0a 2e 73 70 0a itudes)..RE..sp.
2a10: 2e 50 50 0a 2e 53 48 20 22 42 55 47 53 2c 20 49 .PP..SH "BUGS, I
2a20: 44 45 41 53 2c 20 46 45 45 44 42 41 43 4b 22 0a DEAS, FEEDBACK".
2a30: 54 68 69 73 20 64 6f 63 75 6d 65 6e 74 2c 20 61 This document, a
2a40: 6e 64 20 74 68 65 20 70 61 63 6b 61 67 65 20 69 nd the package i
2a50: 74 20 64 65 73 63 72 69 62 65 73 2c 20 77 69 6c t describes, wil
2a60: 6c 20 75 6e 64 6f 75 62 74 65 64 6c 79 20 63 6f l undoubtedly co
2a70: 6e 74 61 69 6e 0a 62 75 67 73 20 61 6e 64 20 6f ntain.bugs and o
2a80: 74 68 65 72 20 70 72 6f 62 6c 65 6d 73 5c 26 2e ther problems\&.
2a90: 0a 50 6c 65 61 73 65 20 72 65 70 6f 72 74 20 73 .Please report s
2aa0: 75 63 68 20 69 6e 20 74 68 65 20 63 61 74 65 67 uch in the categ
2ab0: 6f 72 79 20 5c 66 49 6d 61 74 68 20 3a 3a 20 66 ory \fImath :: f
2ac0: 6f 75 72 69 65 72 5c 66 52 20 6f 66 20 74 68 65 ourier\fR of the
2ad0: 0a 5c 66 49 54 63 6c 6c 69 62 20 54 72 61 63 6b .\fITcllib Track
2ae0: 65 72 73 5c 66 52 20 5b 68 74 74 70 3a 2f 2f 63 ers\fR [http://c
2af0: 6f 72 65 5c 26 2e 74 63 6c 5c 26 2e 74 6b 2f 74 ore\&.tcl\&.tk/t
2b00: 63 6c 6c 69 62 2f 72 65 70 6f 72 74 6c 69 73 74 cllib/reportlist
2b10: 5d 5c 26 2e 0a 50 6c 65 61 73 65 20 61 6c 73 6f ]\&..Please also
2b20: 20 72 65 70 6f 72 74 20 61 6e 79 20 69 64 65 61 report any idea
2b30: 73 20 66 6f 72 20 65 6e 68 61 6e 63 65 6d 65 6e s for enhancemen
2b40: 74 73 20 79 6f 75 20 6d 61 79 20 68 61 76 65 20 ts you may have
2b50: 66 6f 72 20 65 69 74 68 65 72 0a 70 61 63 6b 61 for either.packa
2b60: 67 65 20 61 6e 64 2f 6f 72 20 64 6f 63 75 6d 65 ge and/or docume
2b70: 6e 74 61 74 69 6f 6e 5c 26 2e 0a 2e 50 50 0a 57 ntation\&...PP.W
2b80: 68 65 6e 20 70 72 6f 70 6f 73 69 6e 67 20 63 6f hen proposing co
2b90: 64 65 20 63 68 61 6e 67 65 73 2c 20 70 6c 65 61 de changes, plea
2ba0: 73 65 20 70 72 6f 76 69 64 65 20 5c 66 49 75 6e se provide \fIun
2bb0: 69 66 69 65 64 20 64 69 66 66 73 5c 66 52 2c 0a ified diffs\fR,.
2bc0: 69 5c 26 2e 65 20 74 68 65 20 6f 75 74 70 75 74 i\&.e the output
2bd0: 20 6f 66 20 5c 66 42 64 69 66 66 20 2d 75 5c 66 of \fBdiff -u\f
2be0: 52 5c 26 2e 0a 2e 50 50 0a 4e 6f 74 65 20 66 75 R\&...PP.Note fu
2bf0: 72 74 68 65 72 20 74 68 61 74 20 5c 66 49 61 74 rther that \fIat
2c00: 74 61 63 68 6d 65 6e 74 73 5c 66 52 20 61 72 65 tachments\fR are
2c10: 20 73 74 72 6f 6e 67 6c 79 20 70 72 65 66 65 72 strongly prefer
2c20: 72 65 64 20 6f 76 65 72 0a 69 6e 6c 69 6e 65 64 red over.inlined
2c30: 20 70 61 74 63 68 65 73 5c 26 2e 20 41 74 74 61 patches\&. Atta
2c40: 63 68 6d 65 6e 74 73 20 63 61 6e 20 62 65 20 6d chments can be m
2c50: 61 64 65 20 62 79 20 67 6f 69 6e 67 20 74 6f 20 ade by going to
2c60: 74 68 65 20 5c 66 42 45 64 69 74 5c 66 52 0a 66 the \fBEdit\fR.f
2c70: 6f 72 6d 20 6f 66 20 74 68 65 20 74 69 63 6b 65 orm of the ticke
2c80: 74 20 69 6d 6d 65 64 69 61 74 65 6c 79 20 61 66 t immediately af
2c90: 74 65 72 20 69 74 73 20 63 72 65 61 74 69 6f 6e ter its creation
2ca0: 2c 20 61 6e 64 20 74 68 65 6e 20 75 73 69 6e 67 , and then using
2cb0: 20 74 68 65 0a 6c 65 66 74 2d 6d 6f 73 74 20 62 the.left-most b
2cc0: 75 74 74 6f 6e 20 69 6e 20 74 68 65 20 73 65 63 utton in the sec
2cd0: 6f 6e 64 61 72 79 20 6e 61 76 69 67 61 74 69 6f ondary navigatio
2ce0: 6e 20 62 61 72 5c 26 2e 0a 2e 53 48 20 4b 45 59 n bar\&...SH KEY
2cf0: 57 4f 52 44 53 0a 46 46 54 2c 20 46 6f 75 72 69 WORDS.FFT, Fouri
2d00: 65 72 20 74 72 61 6e 73 66 6f 72 6d 2c 20 63 6f er transform, co
2d10: 6d 70 6c 65 78 20 6e 75 6d 62 65 72 73 2c 20 6d mplex numbers, m
2d20: 61 74 68 65 6d 61 74 69 63 73 0a 2e 53 48 20 43 athematics..SH C
2d30: 41 54 45 47 4f 52 59 0a 4d 61 74 68 65 6d 61 74 ATEGORY.Mathemat
2d40: 69 63 73 0a ics.