packages icon



 gforge(1)                                                         gforge(1)
                            May 18 1996  ver 1.3



 NAME
      gforge - fractal forgery of landscapes and textures

 SYNOPSIS
      gforge [-mesh size] [-dimension dim [-adim dim scale]] [-power factor]
               [-limit low high] [-peak xpos ypos] [-craters [density
               height]] [-seed seed] [-name filename] [-type
               TGA|PGM|PG8|OCT|MAT|PNG] [-bpfilter cent_freq Q] [-brfilter
               cent_freq Q] [-lpfilter cut_freq Order] [-hpfilter cut_freq
               Order] [-version]

 DESCRIPTION
      gforge generates a landscape texture by "random fractal forgery,"  the
      term  coined  by  Richard F. Voss of the IBM Thomas J. Watson Research
      Center for seemingly realistic pictures of natural  objects  generated
      by simple algorithms embodying randomness and fractal self-similarity.
      The techniques used by gforge are essentially those given by  Voss[1],
      particularly the technique of spectral synthesis explained in more de-
      tail by Dietmar Saupe[2]. The source code  (and  this  man  page)  was
      mostly  taken  from the "ppmforge" module[3] in the PBMPLUS package of
      graphics utilities. The gforge  "crater"  option  was  contributed  by
      Heiko Eissfeldt <heiko@colossus.escape.de>.

      The generation of a landscape begins with the preparation of an  array
      of  random  data in the frequency domain.  The size of this array, the
      "mesh size," can be set with the -mesh option; the larger the mesh the
      more  realistic  the  pictures but the calculation time and memory re-
      quirement increases as the square of the mesh  size.   The  degree  of
      roughness,  which  you  can specify with the -dimension option, deter-
      mines whether the resulting terrain is rolling hills or  jagged  moun-
      tins.  As  the  dimension value is increased, more high frequency com-
      ponents are added into the random mesh. (Note that  this  number  does
      NOT  directly  correspond to a conventional 'fractal' dimension, eg. a
      Hausdorff- Besicovich dimension. All gforge surfaces have  a  'fractal
      dimension' near 2.0.)

      You may apply a band-pass and/or band-reject filter to  the  frequency
      data,  specifying the normalized [0..1] center frequency and Q (sharp-
      ness) of each filter. Lowpass and highpass filters are also available.
      Then an inverse Fourier transform is performed upon it, which converts
      the original random frequency domain data into spatial amplitudes.  We
      scale  the real components that result from the Fourier transform into
      numbers from 0 to 1 associated with each point on the mesh.   You  can
      further  modify this number by applying a "power law scale" to it with
      the -power option.  Unity scale leaves the numbers unmodified; a power
      scale of 0.5 takes the square root of the numbers in the mesh, while a
      power scale of 3 replaces the numbers in the mesh  with  their  cubes.
      Powers  less  than  1  yield landscapes with vertical scarps that look
      like glacially-carved valleys (with -limit -1.0 1.0);  powers  greater
      than  one make fairy-castle spires (which require large mesh sizes for
      best results). Craters, if that option is selected, are added at  this



                                    - 1 -        Formatted:  January 2, 2025






 gforge(1)                                                         gforge(1)
                            May 18 1996  ver 1.3



      point.  After  these  calculations,  we have an array of the specified
      size containing numbers that range from 0 to 1. Six output formats are
      available as described below.

      Invoking the program with no options writes a 128x128 TGA file  called
      "output.tga"  which  looks like a somewhat bumpy hillside (in POV any-
      way... being a special format, it will look like green speckled  noise
      in  a standard viewer).  "gforge -help" tells you briefly what options
      are available.  You can abbreviate keywords also. Try

      gforge -t pg8 -pow 1 -dim 4 -n sand.pgm

      for an image of sand, or

      gforge -type tga -pow 1.8 -dim 2.4 -m 400 -n mountain.tga


      for a mountain range to render with POV.  Getting  your  landscape  to
      look  just  right  will require playing around with the -dimension and
      -power specs.


 OPTIONS
      -mesh meshsize

           The size of the (n x n) IFFT (inverse fast-fourier transform) ma-
           trix.   To  prevent  the  IFFT  from  becoming  a  _slow_ fourier
           transform, it is suggested that the mesh size be a power of  two,
           but  you  can choose any number you want. If it happens to have a
           large prime factor, or be itself a prime number, the IFFT  calcu-
           lation will be considerably slowed.  The default meshsize is 128.
           Note that a mesh size of 1024 will require just over 8  megabytes
           of memory.


      -dimension dim
           Sets the dimension to the specified dim, which may be any  float-
           ing  point  value between 0 and 3.  Higher dimensions create more
           ``chaotic'' images, which require higher resolution output and  a
           larger FFT mesh size to look good.  If no dimension is specified,
           2.15 is used. To be precise, the  initial  mesh  is  filled  with
           gaussian  noise of amplitude (1/f)^(4 - dim).  Accordingly, dim=4
           would give you pure white noise.

      -adim ad ascale
           Adds an additional component of noise  in  the  frequency  domain
           with the dimension ad and amplitude (scaled relative to the first
           specified dimension) of ascale.  You can add up to nine addition-
           al  dimensions,  although  one or two is almost certainly enough.
           Often you don't need any at all. An  example  might  be  to  have
           large  rolling  hills of dim 1.7, with a touch of higher frequen-



                                    - 2 -        Formatted:  January 2, 2025






 gforge(1)                                                         gforge(1)
                            May 18 1996  ver 1.3



           cies for a rougher texture:

           gforge -dim 1.7 -adim 2.0 0.1 -pow 1.8


      -bpfilter center-freq Q

      -brfilter center-freq Q
           Apply a band-pass (bpfilter) and/or band-reject (brfilter) to the
           frequency data before the inverse FFT. Center-frequency should be
           between 0.0 and 1.0. A band-pass filter at f=0 is just a low-pass
           filter,  and  at f=1.0 it is a high-pass filter. Q ("quality fac-
           tor") = 0.5 is a broad filter, Q=20 is narrow. Try these  options
           to see their effects.

      -lpfilter cut-freq Order

      -hpfilter cut-freq Order
           Apply a low-pass or  high-pass  filter  to  the  frequency  data.
           Cutoff-frequency,  between 0 and 1, is the frequency at which the
           response drops by half. Order may be any positive value; 1  is  a
           soft filter, 1000 is a brick-wall filter.

      -power exponent
           Raise the elevation powers to the specified  exponent,  giving  a
           nonlinear scaling effect, useful for some purposes.

      -limit min max
           Only relevant if a -power exponent other than  1.0  is  selected.
           Scales  terrain  to  the range [ min- max ] prior to raising to a
           power. Default is [0.0 - 1.0]. See the sample  script/batch  file
           for example usages.

      -crater density height
           Add craters to the landscape. The optional density parameter con-
           trols  how  many  there  are.  The default 1.0 gives you moderate
           cratering, but you can specify any positive value. Crater  height
           defaults to 1.0, for what I felt were reasonable looking craters.
           This is the vertical crater height  relative  to  the  underlying
           landscape scale, and will need to be changed depending on how you
           scale the vertical axis of your heightfield when you  render  it.
           As  height goes to zero, the craters dwindle in height and disap-
           pear.  Crater radius follows a power law distribution.

      -wrapoff
           Turn off  the  default  wraparound  of  craters.  The  underlying
           landscape  is always tilable, but with this option it will become
           farther and farther from being tilable as more craters are added.
           I'm  not  sure  if  this is actually useful. Note: cannot be used
           with the "peak" option.




                                    - 3 -        Formatted:  January 2, 2025






 gforge(1)                                                         gforge(1)
                            May 18 1996  ver 1.3



      -peak xpos ypos
           You can specify the location of the largest value (highest  peak)
           in the image as a fraction of the image height and width. For ex-
           ample,

           gforge -dim 1.5 -pow 3 -peak 0.5 0.5 -name mtn.tga

           puts the highest peak in the center of the image.  This  is  most
           useful  for  lower values of dim where there is only one or a few
           broad maxima; at -dim 2 or above it tends to  make  less  differ-
           ence. If you don't specify it, it's somewhere random.

      -seed seed
           You can give it a random number seed, otherwise  it  chooses  one
           based  on  the current time from the system clock. If you use the
           same seed, you get the same image every time.

      -name filename
           If you don't specify it, it's "output.tga" (or "output.xxx",  the
           extension  depending on which file type is being written). Exist-
           ing files with that name are overwritten without warning.

      -type TGA|PGM|PG8|OCT|MAT|PNG
           Six options, default is TGA. TGA and PGM are 16-bit formats,  and
           PG8  is just PGM 8-bit binary format.  PG8 , will produce a stan-
           dard PGM file suitable for viewing in a standard  graphic  viewer
           to  check  out what the options are doing to your landscape.  OCT
           produces an ascii file compatible with Octave v1.1.1,  a  matrix-
           math  package  similar in function to Matlab.  MAT produces a 32-
           bit floating-point file in the Matlab binary  format.   PNG  gen-
           erates 16-bit PNG (portable network graphics) greyscale, which at
           the time of this writing is a very new  format,  but  gaining  in
           support.

      Flags may be abbreviated.

 BUGS
      tiling 'feature'
           Because the FFT operates  on  periodic  functions,  the  opposite
           edges of the image will always match up. If it turns out you want
           to cover a large area by tiling these textures together, this  is
           just what you want (ie, it's a FEATURE... in fact one way to gen-
           erate useful tilable textures is by taking the  FFT  of  any  in-
           teresting  picture,  filtering  a  bit,  and  doing  the  inverse
           transform.) If you don't want periodicity, just generate a larger
           image  than  you need and use some smaller fraction of it. The "-
           wrapoff" option applies only to craters crossing the  page  edge.
           The "-peak" and "-wrapoff" options cannot be used simultaneously.

      fixed output sizes
           The output is always a square grid. If you want a  different  as-



                                    - 4 -        Formatted:  January 2, 2025






 gforge(1)                                                         gforge(1)
                            May 18 1996  ver 1.3



           pect  ratio,  you  should use another image processing package to
           crop or rescale as appropriate. Unfortunately most of them  don't
           support 16 bits of precision. John Cristy's ImageMagick 3.6.5 can
           be compiled to support 16-bit PNG, and Andreas Dilger's patch  to
           POV-Ray  2.2  supports  PNG input, output, imagemaps, and height-
           fields. POV-Ray 3.0 supports PNG.

           http://www.wizards.dupont.com/cristy/ImageMagick.html
           http://www-mddsp.enel.ucalgary.ca/People/adilger/povray


 SEE ALSO
      ppmforge(1), ppm(5), povray(1)

      [1]  Voss, Richard F., ``Random Fractal Forgeries,'' in  Earnshaw  et.
           al.,   Fundamental  Algorithms  for  Computer  Graphics,  Berlin:
           Springer-Verlag, 1985.

      [2]  Peitgen, H.-O., and Saupe, D. eds., The Science  Of  Fractal  Im-
           ages, New York: Springer Verlag, 1988.

      [3]  Walker, John, "ppmforge.c"  in  Jef  Poskanzer's  PBMPLUS  raster
           toolkit, 1991.  <kelvin@fourmilab.ch>  <http://www.fourmilab.ch/>

 AUTHORS
           John Beale                            Heiko Eissfeldt
           1745 Webster St.                 <heiko@colossus.escape.de>
           Palo Alto, CA 94301
           -----------------------------------------------------------------
           beale@best.com               http://jump.stanford.edu:8080/~beale
           http://www.best.com/~beale   http://chomsky.stanford.edu/~beale


      The gforge program is copyright (c) 1995 by John  P.  Beale,  and  the
      crater  code is copyright (c) 1995 Heiko Eissfeldt. This program comes
      with ABSOLUTELY NO WARRANTY. Permission is granted to redistribute the
      full  source  code  under the terms of the GNU General Public License,
      version 2.  For more details, see the GPL.
















                                    - 5 -        Formatted:  January 2, 2025