Class FunctionType3

java.lang.Object
com.sun.pdfview.function.PDFFunction
com.sun.pdfview.function.FunctionType3

public class FunctionType3 extends PDFFunction
3.9.3 - A stitching function define a stitching of the subdomains of several 1-input functions to produce a single new 1-input function. Since the resulting stitching function is a 1-input function, the domain is given by a two-element array, [ Domain0 Domain1 ].
 Example 4.25
 5 0 obj                          % Shading dictionary
  invalid input: '<'invalid input: '<' /ShadingType 3
      /ColorSpace /DeviceCMYK
      /Coords [ 0.0 0.0 0.096 0.0 0.0 1.0 00]% Concentric circles
      /Function 10 0 R
      /Extend [ true true ]
  >>
 endobj

 10 0 obj                         % Color function
  invalid input: '<'invalid input: '<' /FunctionType 3
      /Domain [ 0.0 1.0 ]
      /Functions [ 11 0 R 12 0 R ]
      /Bounds [ 0.708 ]
      /Encode [ 1.0 0.0 0.0 1.0 ]
  >>
 endobj

 11 0 obj                         % First subfunction
  invalid input: '<'invalid input: '<' /FunctionType 2
      /Domain [ 0.0 1.0 ]
      /C0 [ 0.929 0.357 1.000 0.298 ]
      /C1 [ 0.631 0.278 1.000 0.027 ]
      /N 1.048
  >>
 endobj

 12 0 obj                         % Second subfunction
  invalid input: '<'invalid input: '<' /FunctionType 2
      /Domain [ 0.0 1.0 ]
      /C0 [ 0.929 0.357 1.000 0.298 ]
      /C1 [ 0.941 0.400 1.000 0.102 ]
      /N 1.374
  >>
 endobj
 
  • Field Details

    • samples

      private int[][] samples
      the actual samples, converted to integers. The first index is input values (from 0 to size[m - 1] * size[m - 2] * ... * size[0]), and the second is the output dimension within the sample (from 0 to n)
  • Constructor Details

    • FunctionType3

      protected FunctionType3()
      Creates a new instance of FunctionType3
  • Method Details

    • parse

      protected void parse(PDFObject obj) throws IOException

      Read the function information from a PDF Object.

      Required entries ( Table 3.38) (3200-1:2008:7.10.4, table: 41) are:

    • Functions array (Required) An array of k 1-input functions making up the stitching function. The output dimensionality of all functions must be the same, and compatible with the value of Range if Range is present.
    • Domainarray (Required) A 2 element array where Domain0 is less than Domain1. This is read by the PDFFunction superclass.
    • Bounds array (Required) An array of k-1 numbers that, in combination with Domain, define the intervals to which each function from the Functions array applies. Bounds elements must be in order of increasing value, and each value must be within the domain defined by >b>Domain.
    • Encode array (Required) An array of 2 * k numbers that, taken in pairs, map each subset of the domain defined by invalid input: '<'bDomain and the Bounds array to the domain of the corresponding function.
    • Specified by:
      parse in class PDFFunction
      Throws:
      IOException
    • doFunction

      protected void doFunction(float[] inputs, int inputOffset, float[] outputs, int outputOffset)
      Map from m input values to n output values. The number of inputs m must be exactly one half the size of the domain. The number of outputs should match one half the size of the range.
      Specified by:
      doFunction in class PDFFunction
      Parameters:
      inputs - an array of m input values
      inputOffset - the offset into the inputs array to read from
      outputs - an array of size n which will be filled with the output values, or null to return a new array
      outputOffset - the offset into the output array to write to