Tcl Library Source Code

Hex Artifact Content
Login

Artifact 154bcd9992ab91f19732c81d8e536b77355ff08beec368d5239a9bb908f241ce:


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.