home *** CD-ROM | disk | FTP | other *** search
/ jppd.dyndns.org / jppd.dyndns.org.tar / jppd.dyndns.org / QUERYPRO / Impressora_PDF / converter.exe / GPLGS / docie.ps < prev    next >
Text File  |  2003-04-13  |  7KB  |  219 lines

  1. %    Copyright (C) 1995 Aladdin Enterprises.  All rights reserved.
  2. % This software is provided AS-IS with no warranty, either express or
  3. % implied.
  4. % This software is distributed under license and may not be copied,
  5. % modified or distributed except as expressly authorized under the terms
  6. % of the license contained in the file LICENSE in this distribution.
  7. % For more information about licensing, please refer to
  8. % http://www.ghostscript.com/licensing/. For information on
  9. % commercial licensing, go to http://www.artifex.com/licensing/ or
  10. % contact Artifex Software, Inc., 101 Lucas Valley Road #110,
  11. % San Rafael, CA  94903, U.S.A., +1(415)492-9861.
  12.  
  13. % $Id: docie.ps,v 1.5 2003/04/12 18:08:18 ray Exp $
  14. % docie.ps
  15. % Emulate CIE algorithms in PostScript.
  16.  
  17. % ---------------- Auxiliary procedures ---------------- %
  18.  
  19. /r1default [0 1] def
  20. /r3default [0 1 0 1 0 1] def
  21.  
  22. /apply3        % <u> <v> <w> [<pu> <pv> <pw>] apply3 <u'> <v'> <w'>
  23.  {  { 4 -1 roll exch exec } forall
  24.  } bind def
  25.  
  26. /restrict    % <u> <min> <max> restrict <u'>
  27.  { 3 1 roll .max .min
  28.  } bind def
  29.  
  30. /restrict3    % <u> <v> <w> [<minu> ... <maxw>] restrict3 <u'> <v'> <w'>
  31.  { aload pop
  32.    7 -1 roll 3 1 roll restrict 7 1 roll
  33.    5 -1 roll 3 1 roll restrict 5 1 roll
  34.    restrict 3 1 roll
  35.  } bind def
  36.  
  37. /rescale    % <u> <min> <max> rescale <u'>
  38.  { 1 index sub 3 1 roll sub exch div 0 .max 1 .min
  39.  } bind def
  40.  
  41. /rescale3    % <u> <v> <w> [<minu> ... <maxw>] rescale3 <u'> <v'> <w'>
  42.  { aload pop
  43.    7 -1 roll 3 1 roll rescale 7 1 roll
  44.    5 -1 roll 3 1 roll rescale 5 1 roll
  45.    rescale 3 1 roll
  46.  } bind def
  47.  
  48. /mmult3        % <u> <v> <w> [<uu> <uv> ... <wv> <ww>] mmult3
  49.         %   <u'> <v'> <w'>
  50.  { 4 -1 roll dup dup 6 -1 roll dup dup 8 -1 roll dup dup
  51.    10 -1 roll { 10 -1 roll mul } forall
  52.         % Stack: u1 v1 w1 u2 v2 w2 u3 v3 w3
  53.    4 -1 roll add 6 -1 roll add
  54.         % Stack: u1 v1 u2 v2 u3 v3 w'
  55.    7 1 roll 3 -1 roll add 4 -1 roll add
  56.         % Stack: w' u1 u2 u3 v'
  57.    5 1 roll add add 3 1 roll
  58.  } bind def
  59.  
  60. /minvert3    % [<uu> <uv> ... <wv> <ww>] minvert3
  61.         %   [<uu'> <uv'> ... <wv'> <ww'>]
  62.  { 16 dict begin
  63.    aload pop { I H G F E D C B A } { exch def } forall
  64.    /coa E I mul F H mul sub def
  65.    /cob F G mul D I mul sub def
  66.    /coc D H mul E G mul sub def
  67.    /det A coa mul B cob mul add C coc mul add def
  68.    [ coa det div
  69.      C H mul B I mul sub det div
  70.      B F mul C E mul sub det div
  71.      cob det div
  72.      A I mul C G mul sub det div
  73.      C D mul A F mul sub det div
  74.      coc det div
  75.      B G mul A H mul sub det div
  76.      A E mul B D mul sub det div
  77.    ]
  78.    end
  79.  } bind def
  80.  
  81. /print1
  82.  { print dup ==
  83.  } bind def
  84.  
  85. /print3
  86.  { print 3 array astore dup == aload pop
  87.  } bind def
  88.  
  89. % ---------------- Mapping to XYZ ---------------- %
  90.  
  91. /csmap        % <csdict> <l> <m> <n> csmap <csdict> <x> <y> <z>
  92.  { 3 index /RangeLMN .knownget not { r3default } if restrict3
  93. DOCIEDEBUG { (After RangeLMN Decode: ) print3 } if
  94.    3 index /DecodeLMN .knownget { apply3 } if
  95. DOCIEDEBUG { (After DecodeLMN Decode: ) print3 } if
  96.    3 index /MatrixLMN .knownget { mmult3 } if
  97. DOCIEDEBUG { (After MatrixLMN Decode: ) print3 } if
  98.  } bind def
  99.  
  100. /csciea        % <csdict> <a> csciea <csdict> <x> <y> <z>
  101.  { 1 index /RangeA .knownget not { r1default } if restrict
  102. DOCIEDEBUG { (After RangeA Decode: ) print1 } if
  103.    1 index /DecodeA .knownget { exec } if
  104. DOCIEDEBUG { (After DecodeA Decode: ) print1 } if
  105.    1 index /MatrixA .knownget
  106.     { { 1 index mul exch } forall pop }
  107.     { dup dup }
  108.    ifelse
  109. DOCIEDEBUG { (After MatrixA Decode: ) print3 } if
  110.    csmap
  111.  } bind def
  112.  
  113. /cscieabc    % <csdict> <a> <b> <c> cscieabc <csdict> <x> <y> <z>
  114.  { 3 index /RangeABC .knownget not { r3default } if restrict3
  115. DOCIEDEBUG { (After RangeABC Decode: ) print3 } if
  116.    3 index /DecodeABC .knownget { apply3 } if
  117. DOCIEDEBUG { (After DecodeABC Decode: ) print3 } if
  118.    3 index /MatrixABC .knownget { mmult3 } if
  119. DOCIEDEBUG { (After MatrixABC Decode: ) print3 } if
  120.    csmap
  121.  } bind def
  122.  
  123. % ---------------- Rendering from XYZ ---------------- %
  124.  
  125. /lookup3    % <rtable> <a[0..1]> <b[0..1]> <c[0..1]> lookup3
  126.         %   <rtable> <bytes>
  127.  { 3 -1 roll 3 index 0 get 1 sub mul
  128.    3 -1 roll 3 index 1 get 1 sub mul
  129.    3 -1 roll 3 index 2 get 1 sub mul
  130.         % Stack: rtable ia ib ic
  131. DOCIEDEBUG { (RenderTable indices: ) print3 mark 5 1 roll } if
  132.    3 -1 roll round cvi 3 index 3 get exch get
  133.         % Stack: rtable ib ic string
  134.    3 -1 roll round cvi 3 index 2 get mul
  135.         % Stack: rtable ic string ib*nc
  136.    3 -1 roll round cvi add 2 index 4 get mul
  137.         % Stack: rtable string index
  138.    2 index 4 get getinterval
  139.         % Stack: rtable bytes
  140. DOCIEDEBUG { (RenderTable values: ) print (<) print (%stdout) (w) file 1 index writehexstring (>) = } if
  141.  } bind def
  142.  
  143. /bpdefault [0 0 0] def
  144.  
  145. /crmap        % <csdict> <crdict> <x> <y> <z> crmap <v1> ...
  146.  {
  147. DOCIEDEBUG { (CIE XYZ = ) print3 } if
  148.    3 index /MatrixPQR .knownget { mmult3 } if
  149. DOCIEDEBUG { (After MatrixPQR: ) print3 } if
  150.    4 index /WhitePoint get
  151.    5 index /BlackPoint .knownget not { bpdefault } if
  152.    5 index /WhitePoint get
  153.    6 index /BlackPoint .knownget not { bpdefault } if
  154.    4
  155.      { 4 -1 roll aload pop
  156.             % Stack: csdict crdict x y z pt pt pt px py pz
  157.        3 copy 12 index /MatrixPQR .knownget { mmult3 } if 6 array astore
  158.      }
  159.    repeat
  160.             % Stack: csdict crdict x y z wps+ bps+ wpd+ bpd+
  161.    9 -1 roll pop        % get rid of csdict
  162.    7 4 roll
  163.    7 index /TransformPQR get
  164.     {            % Stack: crdict wps+ bps+ wpd+ bpd+ u v w proc
  165.       8 copy exch pop exch pop
  166.       exec exch pop 4 -1 roll pop
  167.     }
  168.    forall
  169.    7 3 roll pop pop pop pop    % get rid of White/BlackPoints
  170. DOCIEDEBUG { (After TransformPQR: ) print3 } if
  171.    3 index /MatrixPQR .knownget { minvert3 mmult3 } if
  172. DOCIEDEBUG { (After MatrixPQR': ) print3 } if
  173.    3 index /MatrixLMN .knownget { mmult3 } if
  174. DOCIEDEBUG { (After MatrixLMN Encode: ) print3 } if
  175.    3 index /EncodeLMN .knownget { apply3 } if
  176. DOCIEDEBUG { (After EncodeLMN Encode: ) print3 } if
  177.    3 index /RangeLMN .knownget not { r3default } if restrict3
  178. DOCIEDEBUG { (After RangeLMN Encode: ) print3 } if
  179.    3 index /MatrixABC .knownget { mmult3 } if
  180. DOCIEDEBUG { (After MatrixABC Encode: ) print3 } if
  181.    3 index /EncodeABC .knownget { apply3 } if
  182. DOCIEDEBUG { (After EncodeABC Encode: ) print3 } if
  183.    3 index /RangeABC .knownget not { r3default } if
  184.    5 -1 roll /RenderTable .knownget
  185.     {        % Stack: u v w ranges rtable
  186.       5 1 roll rescale3
  187. DOCIEDEBUG { (Rescaled ABC: ) print3 } if
  188.         % Stack: rtable a b c
  189.       lookup3
  190.         % Stack: rtable bytes
  191.       0 1 3 index 4 get 1 sub
  192.        {    % Stack: values rtable bytes c
  193.      2 copy get 255 div
  194.         % Stack: values rtable bytes c v
  195.      3 index 3 -1 roll 5 add get exec 3 1 roll
  196.        }
  197.       for pop pop
  198. DOCIEDEBUG { (After RenderTableT: ) print ] dup == aload pop } if
  199.     }
  200.     { restrict3
  201. DOCIEDEBUG { (After RangeABC Encode: ) print3 } if
  202.     }
  203.    ifelse
  204.  } bind def
  205.  
  206. % ---------------- Top level control ---------------- %
  207.  
  208. /mapdict mark
  209.   /CIEBasedA { 1 get exch csciea currentcolorrendering 4 1 roll crmap } bind
  210.   /CIEBasedABC { 1 get 4 1 roll cscieabc currentcolorrendering 4 1 roll crmap } bind
  211. .dicttomark def
  212. /mapcie        % <a> mapcie <v1> ...
  213.         % <a> <b> <c> mapcie <v1> ...
  214.  { currentcolorspace dup 0 get //mapdict exch get exec
  215.  } bind def
  216.