| Non-linear Fractal Interpolating FunctionsR. Kobes, H. Letkeman Abstract:We consider two non-linear generalizations of fractal interpolating 
      functions generated from iterated function systems. The first corresponds 
      to fitting data using a 
      Kth-order polynomial, while 
      the second relates to the freedom of adding certain arbitrary functions. 
      An escape-time algorithm that can be used for such systems to generate 
      fractal images like those associated with Julia or Mandelbrot sets is also 
      described.  
 IntroductionAn Iterated Function System (IFS) can be used to construct a fractal interpolating function for a given set of data [1,2]. The simplest such system defines an IFS with coefficients an, cn, en, and fn determined from discrete data points (ti, xi), i = 0, 1,..., N. Such an IFS interpolates the data set in the sense that, under certain assumptions on the coefficients [1], the attractor of the IFS is a graph that passes through the data points. In this particular case, the IFS of Eq. (1) uses a linear (in t) function between adjacent points to interpolate the data.Various generalizations of fractal interpolating functions have been considered, including those for higher dimensional functions, the use of hidden variables, and extensions to certain non-linear distortions [3,4,5,6,7]. In this note we describe a generalization whereby the transformation incorporates a Kth-order polynomial (in t) interpolation. We also discuss certain classes of non-linear functions that can arise in such interpolating functions, and show how such functions can, with the use of a particular escape-time algorithm, be used to generate fractal images.    We first review 
      the construction of a linear fractal interpolating function. Suppose we 
      have data points (ti, xi), i = 0...N, describing a function 
      x(t). Consider the IFS of Eq. (1) and impose, 
      for n = 1, 2,..., N, 
      
      
      This leads to determination of the coefficients as 
      
      
      whereby the transformation of Eq. (1) can be 
      written as | 
| cn =  -  ,        fn 
            =  -  . | (6) | 
| xn |  | xn + gn(x) - gn(xN) | |
| xn - 1 |  | xn - 1 + gn(x) - gn(x0). | (7) | 
| Wn(t) | = | ant + en | |
| Wn(x) | = | cnt + dnt2 + fn | (8) | 
| an | = |  | |
| en | = |  | |
| cn | = |  | |
| dn | = |  | |
| fn | = |  | (11) | 
 ) interpolating function between the points 
      (tn, xn), ( tn - 1, xn 
      - 1), and ( tn - 
      2, xn - 2).
) interpolating function between the points 
      (tn, xn), ( tn - 1, xn 
      - 1), and ( tn - 
      2, xn - 2). 
      As in the previous section, including an arbitrary function 
      gn(x) in the IFS transformation via 
      
| xn |  | xn + gn(x) - gn(xN) | |
| xn - 1 |  | xn - 1 + gn(x) - gn(xm) | |
| xn - 2 |  | xn - 2 + gn(x) - gn(x0). | (14) | 
From these considerations, the pattern to constructing a Kth-order fractal 
      interpolating function is apparent. Start with a transformation of the 
      form 
      
| Wn(t)  t  | = |  tn +  tn - K | |
| Wn(x)  x  | = |  xn + | |
| + |  xn - 1 +...+ | ||
| + |  xn - K | (17) | 
      
| ![\includegraphics[width=3.375in]{error}](index_files/img71.gif) | 
Suppose we have an IFS transformation Wn(t, 
      x), generated by some data points (xi, 
      yi), i = 0, 
      1,..., N, which includes a non-linear function 
      gn(x), as was done for the linear and quadratic 
      transformations of Eqs. (5) and (13) 
      respectively. We now continue the real variable x of this 
      transformation to complex values: x z = 
      (zR, zI), in effect defining a complex 
      map:
z = 
      (zR, zI), in effect defining a complex 
      map: 
      
| tn + 1 | = | antn + en | |
| zn + 1 | = | Bn(0) + Bn(1)tn + Bn(2)tn2 +...+ Bn(K)tnK + gn(zn) | (18) | 
 , z
, z ) = 
            Wn(t, z)
) = 
            Wn(t, z) 
             exceeds a maximum
 
            exceeds a maximum 
             , z
, z )
) The arbitrariness of the function gn(x) and 
      the data set (ti, xi) used to fix the 
      IFS leads to a wide variety of possible fractal images. An interesting 
      class of functions gn(x) to consider are those 
      for which, when continued to the complex plane x z = (zR, zI), lead to 
      a map having a fixed point zI* 
      = 0 = Imgn(zR, 
      zI*). In such a case one could augment the 
      usual condition of the escape-time algorithm to cease iteration:
z = (zR, zI), lead to 
      a map having a fixed point zI* 
      = 0 = Imgn(zR, 
      zI*). In such a case one could augment the 
      usual condition of the escape-time algorithm to cease iteration:  >
 >  , where
, where  is some suitably large value, to also cease 
      iteration when | zI| 
      <
 is some suitably large value, to also cease 
      iteration when | zI| 
      <  , where
, where  is a suitably 
      small value. The coloring algorithm used to plot a pixel, which depends on 
      the number of iterations attained when this break-out condition was met 
      (if at all), will then lead to structure in the region where the break-out 
      condition on the magnitude of z is not met.
 is a suitably 
      small value. The coloring algorithm used to plot a pixel, which depends on 
      the number of iterations attained when this break-out condition was met 
      (if at all), will then lead to structure in the region where the break-out 
      condition on the magnitude of z is not met. 
      
We give two examples of fractal images generated this way for the choice gn(x) = - 0.4x + 0.5x2 + 0.2x3, with the data generated from the logistic map xn + 1 = 3.4xn(1 - xn), with n = 0, 1,...60. The first one, appearing on the left in Fig. 2, corresponds to the generalization Eq. (5) of a linear (in t) fractal interpolating function, while the second image on the right of Fig. 2 corresponds to the generalization Eq. (13) of a quadratic (in t) interpolating function. A coloring algorithm that simply mapped a color to the number of iterations attained when the break-out condition became satisfied was used in both cases.
      
 is satisfied, 
      which numerically for
 is satisfied, 
      which numerically for  
  10-5 is attained after a 
      relatively small number (10-30) of iterations.
 10-5 is attained after a 
      relatively small number (10-30) of iterations.