%!PS-Adobe-3.0 EPSF-3.0 http://farbe.li.tu-berlin.de/BEU0/BEU0L00XX.PS 2100301 %%BoundingBox: 14 08 828 584 /pdfmark where {pop} {userdict /pdfmark /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: http://farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark [ /View [ /Fit ] /DOCVIEW pdfmark %Y10E00NA.PS6 %line 20****************************************************** %BEG BEU0/OUTLIN10.PS Emty 20120301 %END BEU0/OUTLIN10.PS Emty 20120301 %BEG BEU0/OUTLIN1X.PS 20110801 %EMPTY %END BEU0/OUTLIN1X.PS 20110801 %BEG BEU0/OUTLIN1Y2.PS Emty 20101101 %END BEU0/OUTLIN1Y2.PS Emty 20101101 /BeginEPSF {% def % Prepare for EPS file /b4_Inc_state save def % Save state for cleanup /dict_count countdictstack def /op_count count 1 sub def % Count objects on op stack userdict begin % Make userdict current dict /showpage {} def 0 setgray 0 setlinecap 1 setlinewidth 0 setlinejoin 10 setmiterlimit [] 0 setdash newpath /languagelevel where % If level not equal to 1 then {pop languagelevel where % If level not equal to 1 then 1 ne {false setstrokeadjust false setoverprint } if } if } bind def /EndEPSF {% def % End for EPS file count op_count sub {pop} repeat countdictstack dict_count sub {end} repeat % Clean up dict stack b4_Inc_state restore } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def % !AUSTAUSCH Times-Roman -> Times-Roman-ISOLatin1=Times-I /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /TK {250 /Times-ISOL1 FS} bind def /TM {300 /Times-ISOL1 FS} bind def /TG {350 /Times-ISOL1 FS} bind def /TIK {250 /TimesI-ISOL1 FS} bind def /TIM {300 /TimesI-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TBK {250 /TimesB-ISOL1 FS} bind def /TBM {300 /TimesB-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBIK {250 /TimesBI-ISOL1 FS} bind def /TBIM {300 /TimesBI-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def %ANFA CMYKDEF %CMYKDEA0 (A0=Standard-Drucker-CMYKDEF) 15.3.97 /tzac [1.000 0.933 0.867 0.800 0.733 0.667 0.600 0.533 0.467 0.400 0.333 0.267 0.200 0.132 0.067 0.000 1.000 0.750 0.500 0.250 0.000] def /tzam [1.000 0.933 0.867 0.800 0.733 0.667 0.600 0.533 0.467 0.400 0.333 0.267 0.200 0.132 0.067 0.000 1.000 0.750 0.500 0.250 0.000] def /tzay [1.000 0.933 0.867 0.800 0.733 0.667 0.600 0.533 0.467 0.400 0.333 0.267 0.200 0.132 0.067 0.000 1.000 0.750 0.500 0.250 0.000] def /tzan [1.000 0.933 0.867 0.800 0.733 0.667 0.600 0.533 0.467 0.400 0.333 0.267 0.200 0.132 0.067 0.000 1.000 0.750 0.500 0.250 0.000] def /tza0 [0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000 0.000] def /tza1 [1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000 1.000] def %ENDE CMYKD /rec %x, y width heigth {/heigth exch def /width exch def moveto width 0 rlineto 0 heigth rlineto width neg 0 rlineto closepath } bind def /colrecfiLAB* %x y width heigth LAB* { setcolor rec fill} bind def /colrecstLAB* %x y width heigth LAB* { setcolor rec stroke} bind def /colrecficmyn* %x y width heigth cmy0* or 000n* { setcmykcolor rec fill} bind def /colrecstcmyn* %x y width heigth cmy0* or 000n* { setcmykcolor rec stroke} bind def /colrecfiw* %x y width heigth w* { setgray rec fill} bind def /colrecstw* %x y width heigth w* { setgray rec stroke} bind def /colrecfiolv* %x y width heigth olv* { setrgbcolor rec fill} bind def /colrecstolv* %x y width heigth olv* { setrgbcolor rec stroke} bind def /tzocmy0* {0.0 1.0 1.0 0.0} bind def %Reproduction colours /tzlcmy0* {1.0 0.0 1.0 0.0} bind def %cmyn* setcmykcolor /tzvcmy0* {1.0 1.0 0.0 0.0} bind def /tzccmy0* {1.0 0.0 0.0 0.0} bind def /tzmcmy0* {0.0 1.0 0.0 0.0} bind def /tzycmy0* {0.0 0.0 1.0 0.0} bind def /tzoolv* {1.0 0.0 0.0} bind def %Reproduction colours /tzlolv* {0.0 1.0 0.0} bind def %olv* setrgbcolor /tzvolv* {0.0 0.0 1.0} bind def /tzcolv* {0.0 1.0 1.0} bind def /tzmolv* {1.0 0.0 1.0} bind def /tzyolv* {1.0 1.0 0.0} bind def /tzoLAB* [53.34 72.46 50.66] def %Reproduction colours /tzlLAB* [84.93 -79.83 74.80] def %LAB* setcolor /tzvLAB* [32.20 24.88 -37.89] def /tzcLAB* [88.10 -44.88 -13.36] def /tzmLAB* [59.66 90.32 -19.65] def /tzyLAB* [93.76 -20.24 85.93] def /tzncmy0* {1.00 1.00 1.00 0.00} bind def %grey series /tzdcmy0* {0.75 0.75 0.75 0.00} bind def %cmy0* setcmykcolor /tzzcmy0* {0.50 0.50 0.50 0.00} bind def /tzhcmy0* {0.25 0.25 0.25 0.00} bind def /tzwcmy0* {0.00 0.00 0.00 0.00} bind def /tzn000n* {0.00 0.00 0.00 1.00} bind def %grey series 000n* /tzd000n* {0.00 0.00 0.00 0.75} bind def %000n* setcmykcolor /tzz000n* {0.00 0.00 0.00 0.50} bind def /tzh000n* {0.00 0.00 0.00 0.25} bind def /tzw000n* {0.00 0.00 0.00 0.00} bind def /tznw* {0.00} bind def %grey series /tzdw* {0.25} bind def %w* setgray /tzzw* {0.50} bind def /tzhw* {0.75} bind def /tzww* {1.00} bind def /tznolv* {0.00 0.00 0.00} bind def %grey series /tzdolv* {0.25 0.25 0.25} bind def %olv* setrgbcolor /tzzolv* {0.50 0.50 0.50} bind def /tzholv* {0.75 0.75 0.75} bind def /tzwolv* {1.00 1.00 1.00} bind def /tznLAB* [18.01 0.00 0.00] def %grey series /tzdLAB* [37.36 0.00 0.00] def %LAB* setcolor /tzzLAB* [56.71 0.00 0.00] def /tzhLAB* [76.06 0.00 0.00] def /tzwLAB* [95.41 0.00 0.00] def /tfn {0 setgray} bind def /tfw {1 setgray} bind def /A4quer {598 0 translate 90 rotate} def /cvishow {cvi 6 string cvs show} def /cvsshow1 {10 mul cvi 0.1 mul 7 string cvs show} def /cvsshow2 {100 mul cvi 0.01 mul 7 string cvs show} def /cvsshow3 {1000 mul cvi 0.001 mul 7 string cvs show} def %%EndProlog %*********************************************************** %%BeginPageSetup /#copies 1 def %A4querF 1.0 1.0 scale /pgsave save def %%EndPageSetup /SS$ [(G) (E) (S) (F) (I) (J) (M)] def /SC$ [(N) (F) (S) (D) (T) (E) (C)] def /SX$ [(0) (1) (2) (3) (4) (5) (6) (7) (8) (9) (A) (B) (C) (D) (E) (F)] def /SY$ [(0) (1) (2) (3) (4) (5) (6) (7) (8) (9) (A) (B) (C) (D) (E) (F)] def % 0 1 2 3 4 5 % 6 7 8 /EX$ [(A.TXT /.PS) (B.BMP /.PS) (G.GIF /.PS) (H.HTM /.PS) (I.HTM /.PS) (J.JPE /.PS) (P.PDF /.PS) (T.TIF /.PS)] def /EY$ [(A.DAT) (B.DAT) (G.DAT) (H.DAT) (I.DAT) (J.DAT) (P.DAT) (T.DAT)] def %******************************************************************* /lanind1f 01 def /lanind2f 01 def /laninddf 01 def /lanindmf 01 def /colorm1f 00 def /colorm2f 00 def /colormdf 01 def /colormmf 01 def /deintp1f 00 def /deintp2f 00 def /deintpdf 01 def /deintpmf 01 def /xcolor1f 00 def /xcolor2f 00 def /xcolordf 01 def /xcolormf 01 def %2/10degree /xchart1f 00 def /xchart2f 00 def /xchartdf 01 def /xchartmf 01 def /xchart3f 01 def /xchart4f 00 def /xchart5f 00 def /pchart1f 00 def /pchart2f 00 def /pchartdf 01 def /pchartmf 01 def %=3:sRGB,Lr /colsep1f 00 def /colsep2f 00 def /colsepdf 01 def /colsepmf 01 def /pmetam1f 00 def /pmetam2f 00 def /pmetamdf 01 def /pmetammf 01 def %/lanindf lanind1f def % /lanindf lanind1f def %lanind1f laninddf lanind2f {/lanindf exch def %/colormf colorm1f def % /colormf colorm1f def %colorm1f colormdf colorm2f {/colormf exch def %/deintpf deintp1f def % /deintpf deintp1f def %deintp1f deintpdf deintp2f {/deintpf exch def %/xcolorf xcolor1f def % /xcolorf xcolor1f def %xcolor1f xcolordf xcolor2f {/xcolorf exch def %/xchartf xchart1f def % /xchartf xchart1f def %xchart1f xchartdf xchart2f {/xchartf exch def %/pchartf pchart1f def % /pchartf pchart1f def %/pchartf pchart1f def %pchart1f pchartdf pchart2f {/pchartf exch def %/colsepf colsep1f def % /colsepf colsep1f def %colsep1f colsepdf colsep2f {/colsepf exch def /lanind lanindf def /colorm colormf def /deintp deintpf def /xcolor xcolorf def /xchart xchartf def /xchartm xchart2f xchart1f sub 1 add def /xchart3 xchart3f def /xchart4 xchart4f def /pchart pchartf def /colsep colsepf def %/pmetamf pmetam1f def % /pmetamf pmetam1f def %pmetam1f pmetamdf pmetam2f {/pmetamf exch def /pmetam pmetamf def %************************************************************* %/setgray {sfgray} bind def %/setrgbcolor {sfrgbcolor} bind def %/setcmykcolor {sfcmykcolor} bind def %72 90 translate %0.01 MM dup scale %0 0 moveto 24600 0 rlineto 0 17220 rlineto % -24600 0 rlineto closepath stroke %000 -240 moveto %240 /Times-ISOL1 FS %lanindf cvishow (-) show %colormf cvishow %deintpf cvishow %xcolorf cvishow %xchartf cvishow %pchartf cvishow %colsepf cvishow (-F) show pmetamf cvishow %grestore gsave /GSS$ SS$ lanind get def /GSC$ SC$ colorm get def /GSX$ SX$ xcolor xcolor 16 idiv 16 mul sub get def /GSY$ SY$ xchart xchart 16 idiv 16 mul sub get def /GEX$ EX$ 0 get def /GEY$ EY$ 0 get def %01 %02 %03 %04 %05 %06 %07 %08 %09 %10 /12RN {12 /Times-Roman FS} bind def /10RN {10 /Times-Roman FS} bind def /12RI {12 /Times-Italic FS} bind def /10RI {10 /Times-Italic FS} bind def /12RB {12 /Times-Bold FS} bind def /10RB {10 /Times-Bold FS} bind def /12RBI {12 /Times-BoldItalic FS} bind def /10RBI {10 /Times-BoldItalic FS} bind def /12TN {12 /Times-ISOL1 FS} bind def /10TN {10 /Times-ISOL1 FS} bind def /12TI {12 /TimesI-ISOL1 FS} bind def /10TI {10 /TimesI-ISOL1 FS} bind def /12TB {12 /TimesB-ISOL1 FS} bind def /10TB {10 /TimesB-ISOL1 FS} bind def /12TBI {12 /TimesBI-ISOL1 FS} bind def /10TBI {10 /TimesBI-ISOL1 FS} bind def %gsave BeginEPSF 28 MM 197 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto 1 1 scale -77 -91 translate %%BeginDocument: Bild 10 %line 329 %%EndDocument EndEPSF grestore gsave /SHSl 2 def /SHAl 2 def BeginEPSF 28 SHSl sub MM 152 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto 1 1 scale -77 -91 translate %%BeginDocument: Bild 11 %line 339 %!PS-Adobe-3.0 EPSF-3.0 BEU00-1N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-1N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-1N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 0 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-1N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 86 SHAl add MM 152 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 12 %line 349 %!PS-Adobe-3.0 EPSF-3.0 BEU00-2N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-2N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-2N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 0 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-2N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 28 SHSl sub MM 108 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 13 %line 359 %!PS-Adobe-3.0 EPSF-3.0 BEU00-3N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-3N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-3N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 1 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-3N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 86 SHAl add MM 108 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 14 %line 369 %!PS-Adobe-3.0 EPSF-3.0 BEU00-4N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-4N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-4N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 1 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-4N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 28 SHSl sub MM 064 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 15 %line 379 %!PS-Adobe-3.0 EPSF-3.0 BEU00-5N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-5N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-5N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 0 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-5N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 86 SHAl add MM 064 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 16 %line 389 %!PS-Adobe-3.0 EPSF-3.0 BEU00-6N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-6N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-6N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 0 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-6N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF /xc1 16 def /yc1 12 def /xt 1 def xchart 1 eq {/xt 1 def} if 28 SHSl sub MM 20 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 17 %line 399 %!PS-Adobe-3.0 EPSF-3.0 BEU00-7N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-7N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-7N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 1 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-7N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 86 SHAl add MM 020 MM translate 12 /Times-ISOL1 FS -9 MM -7 MM moveto ( ) show 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 18 %line 409 %!PS-Adobe-3.0 EPSF-3.0 BEU00-8N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark07 where {pop} {userdict /pdfmark07 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark07 [ /View [ /Fit ] /DOCVIEW pdfmark07 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE540-8N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE540-8N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 1 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU00-8N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 0 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 161 MM 197 MM translate 10 /Times-ISOL1 FS 1 1 scale -77 -91 translate %%BeginDocument: Bild 12 %line 419 %%EndDocument EndEPSF grestore gsave /SHSr 2 MM def /SHAr 2 MM def BeginEPSF 161 MM 06 MM sub SHSr sub 152 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 21 %line 429 %!PS-Adobe-3.0 EPSF-3.0 BEU01-1N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-1N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-1N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 0 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-1N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 219 MM 06 MM sub SHAr add 152 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 22 %line 439 %!PS-Adobe-3.0 EPSF-3.0 BEU01-2N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-2N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-2N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 0 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-2N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 161 MM 06 MM sub SHSr sub 108 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 23 %line 449 %!PS-Adobe-3.0 EPSF-3.0 BEU01-3N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-3N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-3N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 1 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-3N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 219 MM 06 MM sub SHAr add 108 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 24 %line 459 %!PS-Adobe-3.0 EPSF-3.0 BEU01-4N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-4N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-4N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 1 def /pYnam 0 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-4N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 161 MM 06 MM sub SHSr sub 064 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 25 %line 469 %!PS-Adobe-3.0 EPSF-3.0 BEU01-5N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-5N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-5N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 0 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-5N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 219 MM 06 MM sub SHAr add 064 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 26 %line 479 %!PS-Adobe-3.0 EPSF-3.0 BEU01-6N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-6N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-6N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 0 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-6N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 161 MM 06 MM sub SHSr sub 020 MM translate 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 27 %line 489 %!PS-Adobe-3.0 EPSF-3.0 BEU01-7N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-7N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-7N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 0 def /pWCGa 1 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-7N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 219 MM 06 MM sub SHAr add 020 MM translate 12 /Times-ISOL1 FS -9 MM -7 MM moveto ( ) show 10 /Times-ISOL1 FS 53 MM 1 MM moveto ( ) show 1 1 scale -77 -91 translate %%BeginDocument: Bild 28 %line 499 %!PS-Adobe-3.0 EPSF-3.0 BEU01-8N %%BoundingBox: 70 85 243 206 %START PDFDE011.EPS /pdfmark17 where {pop} {userdict /pdfmark17 /cleartomark load put} ifelse /languagelevel where {pop languagelevel} {1} ifelse 2 lt { userdict (<<) cvn ([) cvn load put userdict (>>) cvn (]) cvn load put} if [/Title (PostScript pictures: farbe.li.tu-berlin.de/BEU0/BEU0.HTM) /Author (compare K. Richter "Computergrafik ...": ISBN 3-8007-1775-1) /Subject (goto: http://farbe.li.tu-berlin.de or http://color.li.tu-berlin.de) /Keywords (image reproduction, colour devices) /Creator (klaus.richter@mac.com) /CreationDate (D:2021030112000) /ModDate (D:2021030112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 %SETCMYK_OLV.PS /setcmyk_olvcolor %transfer cmyk to olv {/ncolor exch def /ycolor exch def /mcolor exch def /ccolor exch def ncolor 0 eq {1 ccolor sub 1 mcolor sub 1 ycolor sub setrgbcolor } {ccolor 0 eq mcolor 0 eq and ycolor 0 eq and {%only black n 1 ncolor sub dup dup setrgbcolor } {%cmy and black n 1 ccolor sub 1 ncolor sub mul 1 mcolor sub 1 ncolor sub mul 1 ycolor sub 1 ncolor sub mul setrgbcolor } ifelse } ifelse } bind def /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /languagelevel where {pop languagelevel} {1} ifelse /PSL12 exch def /dictende {counttomark 2 idiv dup dict begin {def} repeat pop currentdict end} bind def /Times-Roman findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Times-ISOL1 exch definefont pop /Times-Italic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesI-ISOL1 exch definefont pop /Times-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesB-ISOL1 exch definefont pop /Times-BoldItalic findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /TimesBI-ISOL1 exch definefont pop /Courier findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /Courier-ISOL1 exch definefont pop /Courier-Oblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierI-ISOL1 exch definefont pop /Courier-Bold findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierB-ISOL1 exch definefont pop /Courier-BoldOblique findfont dup length dict begin {1 index /FID ne {def} {pop pop} ifelse }forall /Encoding ISOLatin1Encoding def currentdict end /CourierBI-ISOL1 exch definefont pop /TG {350 /Times-ISOL1 FS} bind def /TM {280 /Times-ISOL1 FS} bind def /TK {240 /Times-ISOL1 FS} bind def /TS {200 /Times-ISOL1 FS} bind def /TL {160 /Times-ISOL1 FS} bind def /TV {110 /Times-ISOL1 FS} bind def /TW {080 /Times-ISOL1 FS} bind def /TIG {350 /TimesI-ISOL1 FS} bind def /TIM {280 /TimesI-ISOL1 FS} bind def /TIK {240 /TimesI-ISOL1 FS} bind def /TIS {200 /TimesI-ISOL1 FS} bind def /TIL {160 /TimesI-ISOL1 FS} bind def /TIV {110 /TimesI-ISOL1 FS} bind def /TIW {080 /TimesI-ISOL1 FS} bind def /TBG {350 /TimesB-ISOL1 FS} bind def /TBM {280 /TimesB-ISOL1 FS} bind def /TBK {240 /TimesB-ISOL1 FS} bind def /TBS {200 /TimesB-ISOL1 FS} bind def /TBL {160 /TimesB-ISOL1 FS} bind def /TBV {110 /TimesB-ISOL1 FS} bind def /TBW {080 /TimesB-ISOL1 FS} bind def /TBIG {350 /TimesBI-ISOL1 FS} bind def /TBIM {280 /TimesBI-ISOL1 FS} bind def /TBIK {240 /TimesBI-ISOL1 FS} bind def /TBIS {200 /TimesBI-ISOL1 FS} bind def /TBIL {160 /TimesBI-ISOL1 FS} bind def /TBIV {110 /TimesBI-ISOL1 FS} bind def /TBIW {080 /TimesBI-ISOL1 FS} bind def /SG {350 /Symbol FS} bind def /SM {280 /Symbol FS} bind def /SK {240 /Symbol FS} bind def /SS {200 /Symbol FS} bind def /SL {160 /Symbol FS} bind def /SV {110 /Symbol FS} bind def /SW {080 /Symbol FS} bind def %********************************************************* %********************************************************* /proz_paramV {%proz_paramV %paramV not used for xchart4=0,1 %paramV used for xchart4=2 to 7 xchart4 2 eq xchart4 3 eq or {/yparam 0850 def} {/yparam 3850 def} ifelse /x0p 4600 def /y0d 200 def /y0d1 200 def x0p yparam 0 y0d mul sub moveto TBL (Parameter:) show x0p yparam 1 y0d mul sub moveto pYnam 1 eq {%pYnam=1 TBIL (Y) show xcol10_BL TBL ( & Name) show }%pYnam=1 {%pYnam=0 TBL (-) show } ifelse x0p yparam y0d 2 mul sub moveto TBL (Illuminant ) showea (Lichtart ) showde TELi xchartl get show x0p yparam y0d 3 mul sub moveto TBIL (Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 /x0pr 4600 def /y0p 1500 def pOstw 1 eq {%pOstw=1 1 0 0 setrgbcolor /x0pr x0p 70 add def /y0pr y0p y0d1 4 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (Ostw) show newpath } if %pOstw=1 psRGB 1 eq {%psRGB=1 0 1 0 setrgbcolor /y0pr y0p y0d1 5 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (sRGB) show newpath } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 0 0 1 setrgbcolor /y0pr y0p y0d1 6 mul sub def x0pr y0pr moveto 500 0 rlineto stroke 0 setgray x0pr y0pr 70 0 360 arc fill x0pr 500 add y0pr 70 0 360 arc fill 1 setgray x0pr y0pr 50 0 360 arc fill x0pr 500 add y0pr 50 0 360 arc fill 0 setgray x0pr 650 add y0pr 50 sub moveto (WCGa) show } if %pWCGa=1 /index2_7 {%index2_7 xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV () show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7 /index2_7n {%index2_7n xchart4 2 eq xchart4 3 eq or xchart4 7 eq or {0 -50 rmoveto TBV (2,n) show 0 50 rmoveto xcol10KBV } if xchart4 4 eq {0 -50 rmoveto TBV (n) show 0 50 rmoveto xcol10_BV } if xchart4 5 eq xchart4 6 eq or {0 -50 rmoveto TBV (1,n) show 0 50 rmoveto xcol10KBV } if } bind def %index2_7n /x0p 0050 def /y0p 3850 def /y0d 200 def x0p y0p y0d 0 mul sub moveto TBIL (XYZ) show 0 -50 rmoveto TBV (W) show 0 50 rmoveto xcol10KBV TBL (=) show XW cvsshow2 (, ) show YW cvsshow2 (, ) show ZW cvsshow2 x0p y0p y0d 1 mul sub moveto TBIL (A) show index2_7 TBL ( = 2,5 \050) show TBIL (a) show index2_7 TBL ( - ) show TBIL (a) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 2 mul sub moveto TBIL (B) show index2_7 TBL ( = 2,5 ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( \050) show TBIL (b) show index2_7 TBL ( - ) show TBIL (b) show index2_7n TBL (\051 ) show TBIL (Y) show xcol10_BV x0p y0p y0d 3 mul sub moveto TBIL (a) show index2_7 TBL ( = ) show TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [ ) show TBIL (\050 x) show xcol10_BV TBL ( - ) show TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBIL ( \051 / y) show xcol10_BV TBL (]) show x0p y0p y0d 4 mul sub moveto TBIL (b) show index2_7 TBL ( = ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( [) show TBIL ( z) show xcol10_BV TBIL ( / y) show xcol10_BV TBL (]) show x0p y0p y0d 5 mul sub moveto TBIL (a) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = 1, ) show TBIL (b) show 0 -50 rmoveto TBV (20) show 0 50 rmoveto TBL ( = -0,4) show x0p y0p y0d 6 mul sub moveto TBIL (x) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show xct show (, ) show TBIL (B) show 0 -50 rmoveto TBV (c) show 0 50 rmoveto TBL ( = ) show Bct show x0p y0p y0d 7 mul sub moveto TBIL (C) show TBV 0 -50 rmoveto (AB) show 0 50 rmoveto index2_7 TBL (=[) show TBIL (A) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (+) show TBIL (B) show index2_7 TBV -20 60 rmoveto (2) show 0 -60 rmoveto TBL (]) show TBV 0 60 rmoveto (1/2) show 0 -60 rmoveto %********************************************** /y0p y0p y0d 8 mul sub def /y0d 220 def 0 setgray x0p y0p y0d 0 mul sub moveto TBL (6 ) show TBIL (Ostwald) show TBL (\255Farben (o)) showde %0BEU00-2 02581 ( colours (o)) showen %1BEU00-2 02581 ( colores (o)) showes %2BEU00-2 02581 ( couleurs (o)) showfr %3BEU00-2 02581 ( colori (o)) showit %4BEU00-2 02581 ( colours (o)) showjp %5BEU00-2 02581 x0p y0p y0d 1 mul sub moveto (von maximalem (m)) showde %0BEU00-2 03581 (of maximum (m)) showen %1BEU00-2 03581 (de m\341ximo (m)) showes %2BEU00-2 03581 (de la maximum (m)) showfr %3BEU00-2 03581 (di massimo (m)) showit %4BEU00-2 03581 (of maximum (m)) showjp %5BEU00-2 03581 TBIL ( C) show TBV 0 -60 rmoveto (AB) show 0 60 rmoveto xcol10KBV TBL ( in) showen xchart4 3 ge {( im) showde} if x0p y0p y0d 2 mul sub moveto xchart4 0 eq xchart4 1 eq or {%xchart4=0,1 TBL (in der Normfarbtafel) showde %0BEU00-2 04581 (chromaticity diagram) showen %1BEU00-2 04581 (en el diagrama de chromaticidad) showes %2BEU00-2 04581 (dans le diagramme de chromaticit\351) showfr %3BEU00-2 04581 (nel diagramma di cromaticit\340) showit %4BEU00-2 04581 (the chromaticity diagram) showjp %5BEU00-2 04581 TBL ( \050) show TBIL (x) show xcol10_BV TBIL (, y) show xcol10_BV TBL (\051) show } if %xchart4=0,1 xchart4 2 eq xchart4 3 eq or {%xchart4=2,3 TBL (linearen Farbenraum ) showde %0BEU00-2 06581 (linear colour space ) showea %1BEU00-2 06581 TBL (\050) show TBIL (C) show TBV 0 -50 rmoveto (AB,2) show 0 50 rmoveto xcol10KBV TBIL (, Y) show xcol10_BV TBL (\051) show } if %xchart4=2,3 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 TBL (Buntwertdiagramm) showde %0BEU00-2 08581 (chromatic value diagram) showen %1BEU00-2 08581 (en el diagrama valor crom\341tico) showes %2BEU00-2 08581 (dans la valeur chromatique le diagramme) showfr %3BEU00-2 08581 (nel diagramma di valore cromatico) showit %4BEU00-2 08581 (chromatic value diagram) showjp %5BEU00-2 08581 TBL ( \050) show TBIL (A) show xcol10_BV TBL (, ) show TBIL (B) show xcol10_BV TBL (\051) show } if %xchart4=4,5 xchart4 6 eq {%xchart4=6 TBL (Buntwertdiagram) showde %0BEU00-2 10581 (chromatic value diagram) showen %1BEU00-2 10581 (en el diagrama croma) showes %2BEU00-2 10581 (dans le diagramme de chroma) showfr %3BEU00-2 10581 (nel diagramma di chroma) showit %4BEU00-2 10581 (chromactic value diagram) showjp %5BEU00-2 10581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (1) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=6 xchart4 7 eq {%xchart4=7 TBL (Buntwertdiagram) showde %0BEU00-2 11581 (chromatic value diagram) showen %1BEU00-2 11581 (en el diagrama croma) showes %2BEU00-2 11581 (dans le diagramme de chroma) showfr %3BEU00-2 11581 (nel diagramma di chroma) showit %4BEU00-2 11581 (chromatic value diagram) showjp %5BEU00-2 11581 TBL ( \050) show TBIL (A) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (, ) show TBIL (B) show 0 -50 rmoveto TBV (2) show 0 50 rmoveto xcol10KBV TBL (\051) show } if %xchart4=7 x0p y0p y0d 3 mul sub moveto TBL (Illumin. ) showea (Lichtart ) showde TELi xchartl get show TBIL (, Y) show TBV 0 -60 rmoveto (W) show 0 60 rmoveto xcol10KBV TBL (=) show ynorW1 100 mul cvishow0 TBIL (, Y) show TBV 0 -60 rmoveto (N) show 0 60 rmoveto xcol10KBV TBL (=) show ynorN1 100 mul cvishow0 } bind def %proz_paramV %************************************************************* /proz_table {%proz_table /ydt 150 def %output text RYGCBMd and WNd %output header TBV xti 0 get 050 sub ytax ydt add moveto (Name) show xti 1 get 100 add ytax ydt add moveto ( Range) showen (Bereich) showde xti 2 get 100 add ytax ydt add moveto TBIV (X) show TBWd xcol10KBW xti 3 get 100 add ytax ydt add moveto TBIV (Y) show TBWd xcol10KBW xti 4 get 100 add ytax ydt add moveto TBIV (Z) show TBWd xcol10KBW xti 5 get 050 add ytax ydt add moveto TBIV (x) show TBWd xcol10KBW xti 6 get 050 add ytax ydt add moveto TBIV (y) show TBWd xcol10KBW xti 7 get ytax ydt add moveto SV (l) show TBWd xti 8 get ytax ydt add moveto SV (l) show TBWc %output data 0 1 10 {/jp exch def %jp=0,9 %6 RYGCBM + 3 WZN TV /ytaxa ytax ydt jp mul sub def xti 0 get 50 sub ytaxa moveto TBV colnamei jp get show TBW 0 -50 rmoveto (d) show 0 50 rmoveto TV xti 1 get ytaxa moveto jp 0 eq {DOW1j 0 get 0.5 add cvishow0 (_775) show} if %rounded R jp 1 eq {DOW1j 1 get 0.5 add cvishow0 (_775) show} if %rounded Y jp 2 eq {DOW1j 1 get 0.5 add cvishow0 (_) show %rounded B DOW1j 0 get 0.5 add cvishow0 } if %+roundet R jp 3 eq {(380_) show DOW1j 0 get 0.5 add cvishow0} if %rounded C jp 4 eq {(380_) show DOW1j 1 get 0.5 add cvishow0} if %rounded B jp 5 eq {DOW1j 0 get 0.5 add cvishow0 (_) show %rounded R DOW1j 1 get 0.5 add cvishow0 } if %+rounded B jp 6 eq {(380_775) show} if jp 7 eq {(380_775) show} if jp 8 eq {(380_775) show} if jp 9 eq {(475_575) show} if jp 10 eq {(575_475) show} if xti 2 get ytaxa moveto colXi jp get cvsshow2 xti 3 get ytaxa moveto colYi jp get cvsshow2 xti 4 get ytaxa moveto colZi jp get cvsshow2 /SUM colXi jp get colYi jp get add colZi jp get add 0.0001 add def colXAi jp colXi jp get SUM div put colYAi jp colYi jp get SUM div put colZAi jp colZi jp get SUM div put xti 5 get ytaxa moveto colXAi jp get cvsshow4 xti 6 get ytaxa moveto colYAi jp get cvsshow4 jp 6 eq {xti 7 get ytaxa moveto ( ) show ynorW1 100 mul cvishow0 (%) show TV} if jp 7 eq {xti 7 get ytaxa moveto ( ) show ynorN1 100 mul cvishow0 (%) show TV} if jp 8 eq {xti 7 get ytaxa moveto ( ) show ynorZ1 100 mul cvishow0 (%) show TV} if jp 5 le {%jp<=5 RYGCBM /jp2 jp 2 add def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp<=5 RYGCBM jp 9 eq {%jp=9 RYGCBM /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show xti 8 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show } if %jp=9 RYGCBM jp 10 eq {%jp=10 RYGCBM %reverese compared to no. 9 /jp2 9 def %DOW(1/2)j started at jp=2 xti 7 get ytaxa moveto DOW2j jp2 get cvishow DOW2jc jp2 get show xti 8 get ytaxa moveto DOW1j jp2 get cvishow DOW1jc jp2 get show } if %jp=9 RYGCBM } for %jp=0,10 } bind def %proz_table %**************************************************************************** /proz_axis_scales4_7 {%proz_axis_scales4_7 %axis and scales 0 setgray -1600 0 moveto 3350 0 rlineto stroke 0 -1880 moveto 0 3600 rlineto stroke 1750 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto closepath fill 0 50 sub 1750 100 sub moveto 50 100 rlineto 50 -100 rlineto closepath fill /xt10x 5 array def /yt10x 5 array def /xt10x [(-100) ( ) ( ) ( ) ( 100)] def /yt10x [(-100) () ( ) ( ) ( 100)] def 0 setgray 0 1 4 {/i exch def %i=0,4 x-axis -1600 i 800 mul add -75 moveto 0 150 rlineto stroke -1800 i 800 mul add -250 moveto TBL xt10x i get show i 4 eq {-1600 i 800 mul add 0 moveto xchart4 4 eq { %xchart4=4 -200 150 rmoveto TBIS (A) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 -300 150 rmoveto TBIS (A) show 00 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 0 1 4 {/i exch def %i=0,4 y-axis -75 -1600 i 800 mul add moveto 150 0 rlineto stroke -450 -1650 i 800 mul add 000 sub moveto TBL yt10x i get show i 4 eq {0 -1650 i 800 mul add moveto xchart4 4 eq { %xchart4=4 150 050 rmoveto TBIS (B) show xcol10_BL } if %xchart4=4 xchart4 5 eq xchart4 6 eq or { %xchart4=5,6 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (1) show 0 50 rmoveto xcol10KBL } if %xchart4=5,6 xchart4 7 eq { %xchart4=7 150 050 rmoveto TBIS (B) show -20 -50 rmoveto TBL (2) show 0 50 rmoveto xcol10KBL } if %xchart4=7 } if } for %i=0,4 newpath 0 0 100 0 360 arc stroke -350 -200 moveto TBL TELi xchartl get show } bind def %proz_axis_scales4_7 %*********************************************************** /proz_chromaticity_lines {%BEG proz_chromaticity_lines %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx /DOW 82 array def %special for (x,y) diagrams /DOWZ 17 array def /F02EZ 51 array def %purple data /F10EZ 51 array def %TRISTIMULUS VALUES FOR PURPLE COLORS from 'dmyy'KRPROG.FOR %FOR 02- AND 10-DEGREE-OBSERVER, ILLUMINANT E 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 /DOWZ %17 data [700 -495 -500 -505 -510 -515 -520 -525 -530 -535 -540 -545 -550 -555 -560 -565 400] def /F02EZ %3x17 data 700 ... 400 [.01136 .01141 .01158 .01169 .01176 .01182 .01187 .01191 .01195 .01199 .01204 .01210 .01219 .01232 .01254 .01300 .01431 .00410 .00404 .00383 .00369 .00359 .00352 .00346 .00342 .00337 .00331 .00325 .00317 .00306 .00289 .00262 .00205 .00040 .00000 .00118 .00507 .00754 .00930 .01064 .01167 .01256 .01346 .01445 .01562 .01709 .01910 .02210 .02718 .03765 .06785] def /F10EZ %3x17 data 700 ... 400 [.00958 .01015 .01037 .01053 .01065 .01075 .01085 .01096 .01108 .01122 .01139 .01163 .01201 .01268 .01416 .02078 .01911 .00372 .00361 .00357 .00355 .00352 .00351 .00349 .00347 .00345 .00342 .00339 .00335 .00328 .00316 .00289 .00170 .00200 .00000 .00517 .00718 .00858 .00972 .01063 .01150 .01245 .01354 .01478 .01635 .01856 .02194 .02795 .04136 .10106 .08601] def %*************************************************** /XEZi 17 array def %to be defined /YEZi 17 array def /A.PSi 17 array def /XAEZi 17 array def /YAEZi 17 array def /ZAEZi 17 array def /YKSUM 0 def %for E00 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 16 {/i exch def %i=0,16 %for illuminant E: S(lamdda=100) XEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 00 i add get YKSUM div 100 mul put YEZi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 17 i add get YKSUM div 100 mul put A.PSi i xcolorl 0 eq {F02EZ} {F10EZ} ifelse 34 i add get YKSUM div 100 mul put /SUM XEZi i get YEZi i get add A.PSi i get add 0.0001 add def XAEZi i XEZi i get SUM div put YAEZi i YEZi i get SUM div put ZAEZi i A.PSi i get SUM div put } for %i=0,16 /xtrans8 600 def /ytrans8 400 def xtrans8 ytrans8 translate %for scala and graphic 0 0 moveto 4300 0 rlineto stroke 0 0 moveto 0 3500 rlineto stroke %arrows 4300 100 sub 50 moveto 100 -50 rlineto -100 -50 rlineto stroke -50 3400 moveto 50 100 rlineto 50 -100 rlineto stroke %! 100 S-Einheiten = 2000 Skalen-Einheiten TBS 0 -50 moveto 0 100 rlineto stroke 800 -50 moveto 0 100 rlineto stroke 1600 -50 moveto 0 100 rlineto stroke 2400 -50 moveto 0 100 rlineto stroke 3200 -50 moveto 0 100 rlineto stroke 4000 -50 moveto 0 100 rlineto stroke -100 -300 moveto (0,0) show 700 -300 moveto (0,2) show 1500 -300 moveto (0,4) show 2300 -300 moveto (0,6) show 3100 -300 moveto (0,8) show 3900 -300 moveto (1,0) show %! 100 S-Einheiten = 2000 Skalen-Einheiten -50 0 moveto 100 0 rlineto stroke -50 800 moveto 100 0 rlineto stroke -50 1600 moveto 100 0 rlineto stroke -50 2400 moveto 100 0 rlineto stroke -50 3200 moveto 100 0 rlineto stroke -450 -80 moveto (0,0) show -450 720 moveto (0,2) show -450 1520 moveto (0,4) show -450 2320 moveto (0,6) show -450 3120 moveto (0,8) show TBIS 4300 -250 moveto (x) show xcol10_BL -350 3400 moveto (y) show xcol10_BL TBS 2200 150 moveto xcolorl 0 eq {(CIE 1931) show} if xcolorl 1 eq {(CIE 1964) show} if %3950 100 moveto (P) show newpath /fakt 4000 def 4 1 64 {/i exch def %i=4,64 %400..700 XASi i get fakt mul YASi i get fakt mul i 05 eq {moveto} if i 06 ge i 63 le and {lineto} if i 64 eq {lineto closepath stroke} if } for %i=4,64 /xytshift 320 array def %min 4x65 /xytshift [ 0 000 000 (380) %0 0 000 000 (385) %1 0 000 000 (390) %2 0 000 000 (395) %3 1 -170 -170 (400) %4 0 000 000 (405) %5 0 000 000 (410) %6 0 000 000 (415) %7 0 000 000 (420) %8 0 000 000 (425) %9 0 000 000 (430) %10 0 000 000 (435) %11 0 000 000 (440) %12 0 000 000 (445) %13 1 -300 -050 (450) %14 S 0 000 000 (455) %15 0 000 000 (460) %16 1 -300 -030 (465) %17 0 000 000 ( ) %18 1 -300 -030 (475) %19 1 -300 -030 (480) %20 1 -300 -030 (485) %21 1 -330 -050 (490) %22 1 -270 000 (495) %23 M=S 1 -300 -050 (500) %24 1 -300 -050 (505) %25 1 -330 -050 (510) %26 L=S 1 000 000 ( ) %27 1 -100 070 (520) %28 1 060 000 (525) %29 1 000 000 ( ) %30 1 060 000 (535) %31 1 000 000 ( ) %32 M 1 000 000 ( ) %33 1 050 030 (550) %34 1 000 000 ( ) %35 1 050 030 (560) %36 1 000 000 ( ) %37 1 000 060 (570) %38 L 1 000 000 ( ) %39 1 050 030 (580) %40 1 050 050 ( ) %41 1 050 030 (590) %42 1 050 050 ( ) %43 1 050 060 (600) %44 0 000 000 ( ) %45 1 050 080 (610) %46 0 000 000 ( ) %47 1 050 050 (620) %48 0 000 000 ( ) %49 0 000 000 (630) %50 0 000 000 ( ) %51 1 050 030 (640) %52 0 000 000 (645) %53 0 000 000 (650) %54 0 000 000 (655) %55 0 000 000 (660) %56 0 000 000 (665) %57 0 000 000 (670) %58 0 000 000 (675) %59 0 000 000 (680) %60 0 000 000 (685) %61 0 000 000 (690) %62 0 000 000 (695) %63 1 100 -50 (700) %64 ] def %coorection for 510nm, 10 degree %actual: 1 -170 -170 (400) %4 %actual: 1 -050 -050 (510) %26 xcolorl 1 eq {/ix 4 4 mul 1 add def xytshift ix -200 put xytshift ix 1 add -220 put /ix 26 4 mul 1 add def xytshift ix -140 put xytshift ix 1 add 070 put } if 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def xytshift i40 get 1 eq {%xytshift=1 0 0 0 0 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc fill %400,425,...,700 0 0 0 1 setcmykcolor XASi i get fakt mul YASi i get fakt mul 30 0 360 arc stroke %400,425,...,700 } if %xytshift=1 } for %i=4,1,64 TBIL 4 1 64 {/i exch def %i=4,1,64 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshift i40 get 1 eq {%xytshift=1 XASi i get fakt mul xytshift i41 get add YASi i get fakt mul xytshift i42 get add moveto xytshift i43 get show } if %xytshift=1 } for %i=4,1,64 newpath /xytshiftZ 320 array def %min 4x65 /xytshiftZ [ 0 100 -50 (700) %0 see normal 1 050 -100 (495c,E) %1 1 050 -120 (500c,E) %2 0 050 -100 (505c,E) %3 0 100 -60 (510c,E) %4 0 050 -100 (515c,E) %5 0 050 -100 (520c,E) %6 1 050 -100 (525c,E) %7 0 050 -100 (530c,E) %8 0 050 -100 (535c,E) %9 0 050 -100 (540c,E) %10 0 050 -100 (545c,E) %11 1 050 -100 (550c,E) %12 0 050 -100 (555c,E) %13 0 050 -100 (560c,E) %14 S 0 050 -100 (565c,E) %15 0 -100 -150 (400) %16 see normal ] def 0 1 16 {/i exch def %i=5,5,60 /i40 i 4 mul def xytshiftZ i40 get 1 eq {%xytshiftZ=1 0 0 0 0 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc fill %400,405,...,700 0 0 0 1 setcmykcolor XAEZi i get fakt mul YAEZi i get fakt mul 30 0 360 arc stroke %400,405,...,700 } if %xytshiftZ=1 } for %i=0,1,16 TBIL 0 1 16 {/i exch def %i=0,16 /i40 i 4 mul def /i41 i40 1 add def /i42 i40 2 add def /i43 i40 3 add def xytshiftZ i40 get 1 eq {%xytshiftZ=1 XAEZi i get fakt mul xytshiftZ i41 get add YAEZi i get fakt mul xytshiftZ i42 get add moveto xytshiftZ i43 get show } if %xytshiftZ=1 } for %i=0,16 newpath xtrans8 neg ytrans8 neg translate %for scala and grafic } bind def %END proz_chromaticity_lines %***************************************************************** %%EndProlog gsave %lanindL2.EPS START 20000505 /lanind 0 def /lantex [(G) (E) (S) (F) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} {/lanind1 1 def /lanind2 1 def} ifelse /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} {/colorm1 0 def} ifelse /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} {/deintp1 0 def} ifelse /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} {/xcolor1 0 def} ifelse /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchart1 0 def /xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 0 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 7 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} {/pchart1 3 def} ifelse /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} {/colsep1 0 def} ifelse /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} {/pmetam1 0 def} ifelse %either defaul values for xchart=0 or values for xchart=1 /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % colorm 0 eq deintp 0 eq and {/Txx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def} if %always independent of intended output gsave %LANINDL2 END /cvishow {cvi 6 string cvs show ( ) show} def /cvsshow1 {10 mul cvi 0.1 mul 9 string cvs show ( ) show} def /cvsshow2 {100 mul cvi 0.01 mul 9 string cvs show ( ) show} def /cvsshow3 {1000 mul cvi 0.001 mul 9 string cvs show ( ) show} def /cvsshow4 {10000 mul cvi 0.0001 mul 9 string cvs show ( ) show} def /cvsshow5 {100000 mul cvi 0.00001 mul 9 string cvs show ( ) show} def /cvishow0 {cvi 6 string cvs show} def /TELi 8 array def /xchart8 1 def %0:Pxx, 1:Dxx xchart8 0 eq {%xchart8=0 Pxx /TELi [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. } if %xchart8=0 xchart8 1 eq {%xchart8=1 Dxx /TELi [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. } if %xchart8=1 /SD65 82 array def %380 bis 775 mit deltalambda=05 /SD50 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SA00 82 array def %380 bis 775 mit deltalambda=05 /SE00 82 array def %380 bis 775 mit deltalambda=05 /SC00 82 array def %380 bis 775 mit deltalambda=05 /SP00 82 array def %380 bis 775 mit deltalambda=05 /SQ00 82 array def %380 bis 775 mit deltalambda=05 /SDAK 82 array def %380 bis 775 mit deltalambda=05 /RA 82 array def %380 bis 770 nm /F2 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %/F2N 240 array def %normiert auf Y=100 fuer D65 und 10nm /F10 240 array def %3 x 80 Daten fuer Bereich 380 bis 770nm %C %C LITERATURQUELLEN LICHTARTEN %C SA,SC,SD65, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.1, SEITE 81 %C SD55,SD75, CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 1.1.4, SEITE 85 %C LINEAR INTERPOLIERT VON 5 ZU 5NM %C SG,SP,SXE, DIN 5033, BLATT 7 ,SEITE 8-9 %C AUSGABE 1966 /SD65 %80 data 5 nm [50.0 52.3 54.6 68.7 82.8 87.1 91.5 92.5 93.4 90.1 86.7 95.8 104.9 110.9 117.0 117.4 117.8 116.3 114.9 115.4 115.9 112.4 108.8 109.1 109.4 108.6 107.8 106.3 104.8 106.2 107.7 106.0 104.4 104.2 104.0 102.0 100.0 98.2 96.3 96.1 95.8 92.2 88.7 89.3 90.0 89.8 89.6 88.6 87.7 85.5 83.3 83.5 83.7 81.9 80.0 80.1 80.2 81.2 82.3 80.3 78.3 74.0 69.7 70.7 71.6 73.0 74.3 68.0 61.6 65.7 69.9 72.5 75.1 69.3 63.6 55.0 46.4 56.6 66.8 65.1] def /SD50 %80 data 5 nm CIE 15.3, Seite 30; aus JE541-8N.PS [24.5 27.2 29.9 39.6 49.3 52.9 56.5 58.3 60.0 58.9 57.8 66.3 74.8 81.0 87.2 88.9 90.6 91.0 91.4 93.2 95.1 93.5 92.0 93.8 95.7 96.2 96.6 96.8 97.1 99.6 102.1 101.4 100.8 101.5 102.3 101.2 100.0 98.9 97.7 98.3 98.9 96.2 93.5 95.6 97.7 98.5 99.3 99.2 99.0 97.4 95.7 97.3 98.9 97.3 95.7 96.9 98.2 100.6 103.0 101.1 99.1 93.3 87.4 89.5 91.6 92.2 92.9 84.9 76.9 81.7 86.5 89.5 92.6 85.4 78.2 68.0 57.7 70.3 82.9 0.0] def %0.0 not used /SA00 %80 data 5 nm CIE 15.3 Seite 30; aus JE541-8N.PS [9.80 10.90 12.09 13.35 14.71 16.15 17.68 19.29 20.99 22.79 24.67 26.64 28.70 30.85 33.09 35.41 37.81 40.30 42.87 45.52 48.24 51.04 53.91 56.85 59.86 62.93 66.06 69.25 72.50 75.79 79.13 82.52 85.95 89.41 92.91 96.44 100.00 103.58 107.18 110.80 114.44 118.08 121.73 125.39 129.04 132.70 136.35 139.99 143.62 147.24 150.84 154.42 157.98 161.52 165.03 168.51 171.96 175.38 178.77 182.12 185.43 188.70 191.93 195.12 198.26 201.36 204.41 207.41 210.36 213.27 216.12 218.92 221.67 224.36 227.00 229.59 232.12 234.59 237.01 239.37 0.0] def %0.0 not used % AUS BILDPLA.FOR aus vrbam/wrpos:KRPROG.FOR, 5987-6023 5.10.92 %C PROGRAMM ZUR BERECHNUNG DER RELATIVEN SPEKTRALEN STRAHLUNGSVERTEI- %C LUNG EINES HOHLRAUMSTRAHLERS ALS FUNKTION DER WELLENLAENGE LAMDA %C BEI GEGEBENER TEMPERATUR T %C VERWENDETE VARIABLE %C T TEMPERATUR %C C2 PLANCKSCHE KONSTANTE (=1.4388 CM K (1967)) %C LAMDA(I) WELLENLAENGE %C S(I) STRAHLUNGSVERTEILUNG DES HOHLRAUMSTRAHLERS %C %C LITERATUR OFFIZIELLE EMPFEHLUNGEN DER CIE,DEUTSCHE VERSION, %C CA. 1969, SEITE 21 UND TABELLE 1.1.1 %C %SDP4 82 array def %380 bis 775 mit deltalambda=05 % DO 50 I=1,54 % 50 S(I)=100. % 1*(560./FLOAT(LAMDA(I)))**5 % 2*(EXP(C2/(560.*10.**(-7)*T))-1.) % 3/(EXP(C2/(FLOAT(LAMDA(I))*10.**(-7)*T))-1.) %new CIE 15.3:2004, Eq. (3.1) page 2 %S(I) = [100{560/lambda}**5] [exp{(c2*10**7)/(TNC*560 )} - 1] % /[exp{(c2*10**7)/(TNC*lambda)} - 1] % exp = e {...} = 2.71 {...} %/TNC 2848 def %NLA /EE 2.718281 def %e=mac pocket calculator /C2 1.4350000 10 7 exp mul def /lamd 82 array def xchart8 1 eq {%xchart8=1 Dxx /TNC 4000 def %******************************************** 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNC 560 mul div def /E5 C2 TNC lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def SP40 i E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } if %xchart8=1 Dxx %****************************************** xchart8 0 eq {%xchart8=0 Pxx %defined only for xchart8=0 Pxx /TNCj 8 array def /TNCj [6000 5500 5000 4500 4000 3500 3000 2500] def /SP60 82 array def %380 bis 775 mit deltalambda=05 /SP55 82 array def %380 bis 775 mit deltalambda=05 /SP50 82 array def %380 bis 775 mit deltalambda=05 /SP45 82 array def %380 bis 775 mit deltalambda=05 /SP40 82 array def %380 bis 775 mit deltalambda=05 /SP35 82 array def %380 bis 775 mit deltalambda=05 /SP30 82 array def %380 bis 775 mit deltalambda=05 /SP25 82 array def %380 bis 775 mit deltalambda=05 0 1 7 {/j exch def %j=0,7 0 1 79 {%i=0,79 /i exch def /lambda 380 i 5 mul add def lamd i lambda put /E1 560 lambda div 5 exp def /E4 C2 TNCj j get 560 mul div def /E5 C2 TNCj j get lambda mul div def /E6 EE E4 exp def /E7 EE E5 exp def j 0 eq {SP60 i} if j 1 eq {SP55 i} if j 2 eq {SP50 i} if j 3 eq {SP45 i} if j 4 eq {SP40 i} if j 5 eq {SP35 i} if j 6 eq {SP30 i} if j 7 eq {SP25 i} if E1 100 mul E6 1 sub E7 1 sub div mul put } for %i=0,79 } for %j=0,7 } if %xchart8=0 %************************************************* /SE00 %80 data 5 nm [100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0 100.0] def %0.0 not used /SC00 %80 data 5 nm [ 33.00 39.92 47.40 55.17 63.30 71.81 80.60 89.53 98.10 105.80 112.40 117.75 121.50 123.45 124.00 123.60 123.10 123.30 123.80 124.09 123.90 122.92 120.70 116.90 112.10 106.98 102.30 98.81 96.90 96.78 98.00 99.94 102.10 103.95 105.20 105.67 105.30 104.11 102.30 100.15 97.80 95.43 93.20 91.22 89.70 88.83 88.40 88.19 88.10 88.06 88.00 87.86 87.80 87.99 88.20 88.20 87.90 87.22 86.30 85.30 84.00 82.21 80.20 78.24 76.30 74.36 72.40 70.40 68.30 66.30 64.40 62.80 61.50 60.20 59.20 58.50 58.10 58.00 58.20 58.50 ] def %0.0 not used 0 1 79 {/i exch def %i=0,79 /lamda 380 i 5 mul add def SP00 i SE00 i get lamda 560 div mul put SQ00 i SE00 i get 1120 lamda sub 560 div mul put } for %i=0,79 %C LITERATURQUELLEN SPEKTRALWERTE %C F2 CIE-DOKUMENT NR.15 FARBMESSUNG, 1971 %C TABELLE 2.1, SEITE 93-102 /F2 %3x80 data [.001368 .002236 .004243 .007650 .01431 .02319 .04351 .07763 .1344 .2148 .2839 .3285 .3483 .3481 .3362 .3187 .2908 .2511 .1954 .1421 .09564 .05795 .03201 .01470 .0049 .0024 .0093 .0291 .06327 .1096 .1655 .2257 .2904 .3597 .4334 .5121 .5945 .6784 .7621 .8425 .9163 .9786 1.0263 1.0567 1.0622 1.0456 1.0026 .9384 .8544 .7514 .6424 .5419 .4479 .3608 .2835 .2187 .1649 .1212 .0874 .0636 .04677 .03290 .02270 .01584 .01136 .00811 .00579 .004109 .002899 .002049 .001440 .0009999 .0006901 .000476 .0003323 .0002348 .0001662 .0001174 .00008308 .00005871 .000039 .000064 .00012 .000217 .000396 .00064 .00121 .00218 .004 .0073 .0116 .01684 .023 .0298 .0380 .048 .06 .0739 .09098 .1126 .139 .1693 .208 .2586 .323 .4073 .503 .6082 .71 .7932 .862 .9149 .954 .9803 .995 1.0 .995 .9786 .952 .9154 .870 .8163 .757 .6949 .631 .5668 .503 .4412 .381 .321 .265 .217 .175 .1382 .107 .0816 .061 .04458 .032 .0232 .017 .01192 .00821 .005723 .004102 .002929 .002091 .001484 .001047 .00074 .00052 .0003611 .0002492 .0001719 .00012 .0000848 .00006 .0000424 .00003 .0000212 .00645 .01055 .02005 .03621 .06785 .1102 .2074 .3713 .6456 1.0391 1.3856 1.623 1.7471 1.7826 1.7721 1.7441 1.6692 1.5281 1.2876 1.0419 .8130 .6162 .4652 .3533 .2720 .2123 .1582 .1117 .07825 .05725 .04216 .02984 .0203 .0134 .00875 .00575 .0039 .00275 .0021 .0018 .00165 .0014 .0011 .0010 .0008 .0006 .00034 .00024 .00019 .0001 .00005 .00003 .00002 .00001 % 26*0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 %26 ] def /F10 %3x80 data [.00016 .0006624 .002362 .007242 .01911 .0434 .08474 .1406 .2045 .2647 .3147 .3577 .3837 .3867 .3707 .343 .3023 .2541 .1956 .1323 .08051 .04107 .01617 .005132 .003816 .01544 .03746 .07136 .1177 .173 .2365 .3042 .3768 .4516 .5298 .6161 .7052 .7938 .8787 .9512 1.0142 1.0743 1.1185 1.1343 1.124 1.0891 1.0305 .9507 .8563 .7549 .6475 .5351 .4316 .3437 .2683 .2043 .1526 .1122 .08126 .05793 .04085 .02862 .019941 .01384 .0100 .006605 .004552 .003145 .002175 .001506 .001045 .0007274 .0005083 .0003564 .000251 .0001777 .0001264 .00009015 .00006453 .00004634 .00001736 .00007156 .0002534 .0007685 .002004 .004509 .008756 .01446 .02139 .0295 .03868 .0496 .06208 .0747 .08946 .1063 .1282 .1528 .1852 .2199 .2536 .2977 .3391 .3954 .4608 .5314 .6067 .6857 .7618 .8233 .8752 .9238 .962 .9822 .9918 .9991 .9973 .9824 .9555 .9152 .8689 .8256 .7774 .7203 .6583 .5939 .528 .4618 .3981 .3395 .2835 .2282 .1798 .1402 .1076 .08119 .06028 .0441 .0318 .0226 .0159 .01113 .007749 .0053751 .0037177 .002565 .001768 .001222 .0008462 .0005864 .0004074 .000284 .0001987 .0001395 .00009843 .00006982 .00004974 .00003554 .00002549 .00001834 .0007048 .002928 .01048 .03234 .08601 .1971 .3894 .6568 .9725 1.2825 1.5535 1.7985 1.9673 2.0273 1.9948 1.9007 1.7454 1.5549 1.3176 1.0302 .7721 .5701 .4152 .3024 .2185 .1592 .112 .08225 .06071 .04305 .03045 .02058 .01368 .007918 .003988 .001091 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %10 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %20 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %30 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 0.0 %40 0.0 0.0 0.0 0.0 %44 ] def /F_CIEi 240 array def %raw data F2 or F10 /XEi 82 array def %equal energy /YEi 82 array def /ZEi 82 array def /XAEi 82 array def %A=Anteil /YAEi 82 array def /ZAEi 82 array def /xcolorl xcolor def /xcolorl 0 def 0 1 0 {/xcolorl exch def %xcolorl=0,0 0 1 239 {/i exch def %i=0,239 F_CIEi i xcolorl 0 eq {F2}{F10} ifelse i get put } for %i=0,239 /YKSUM 0 def %For CIE Illuminant E 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM F_CIEi 80 i add get add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XEi i F_CIEi 00 i add get YKSUM div 100 mul put YEi i F_CIEi 80 i add get YKSUM div 100 mul put ZEi i F_CIEi 160 i add get YKSUM div 100 mul put /SUM XEi i get YEi i get add XEi i get add 0.0001 add def XAEi i XEi i get SUM div put YAEi i YEi i get SUM div put ZAEi i ZEi i get SUM div put } for %i=0,1,79 %********************************************************************* 20 setlinewidth /xdel 1005 def /ydel 395 def /x0 050 def /x1 -150 def /xchart90 0 def %0=default /ynorW0 1.000 def /ynorZ0 0.1800 def /ynorN0 0.001 def 0 1 0 {/xchart91 exch def %xchart91=0,4 xchart91 0 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.001 def /ycon (>288:1) def /yconsh 0.000 def} if xchart91 1 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.040 def /ycon (=25:1) def /yconsh 0.060 def} if xchart91 2 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.100 def /ycon (=10:1) def /yconsh 0.100 def} if xchart91 3 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.250 def /ycon (=4:1) def /yconsh 0.250 def} if xchart91 4 eq {/ynorW1 1.000 def /ynorZ1 0.1800 def /ynorN1 0.500 def /ycon (=2:1) def /yconsh 0.500 def} if gsave 72 90 translate 0.010 MM dup scale /xbtex0 0 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 12250 def 0.5 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath fill 0 setgray 0 0 moveto xmax1 0 rlineto 0 ymax1 rlineto xmax1 neg 0 rlineto closepath stroke TK 0 setgray 120 /Times-ISOL1 FS 050 -100 moveto (BEU00-2) show (R) show %R %xchart 1 add cvishow0 } if %xbtex0=1 /pOstw 1 def /psRGB 1 def /pWCGa 1 def /pYnam 1 def /kchartl 0 def /xchartl xchart def /xchartl 6 def 0 1 0 {/xchartl exch def %xchartl=0,7 20 setlinewidth % xchartl 0 eq { 100 13000 translate} if % xchartl 1 eq { 6150 13000 translate} if % xchartl 2 eq { 100 08740 translate} if % xchartl 3 eq { 6150 08740 translate} if % xchartl 4 eq { 100 04480 translate} if % xchartl 5 eq { 6150 04480 translate} if % xchartl 6 eq { 100 00220 translate} if % xchartl 7 eq { 6150 00220 translate} if 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (BEU01-8N) show gsave 5 /Times-ISOL1 FS /cvishow {cvi 6 string cvs show} def %75 85 moveto %lanind cvishow (-) show %colorm cvishow %deintp cvishow %xcolorl cvishow %xchart cvishow %pchart cvishow %colsep cvishow (-L) show pmetam cvishow %xchart4=2 default /xchart4 7 def %0,1:(x,y), 2,3:(CAB,Y), 4:(A,B), 5&6:(A1,B1), 7:(A2,B2) %72 90 translate %0.010 MM dup scale /xwidth 6000 def /ywidth 4000 def 25 setlinewidth 0 0 0 0 setcmyk_olvcolor 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke %calculation of XW,YW,ZW for 8 illuminants Dxx or Pxx 0 1 79 {/i exch def %i=0,79 SDAK i xchart8 0 eq {%xchart8=0 Pxx xchartl 0 eq {SP60 i get put} if xchartl 1 eq {SP55 i get put} if xchartl 2 eq {SP50 i get put} if xchartl 3 eq {SP45 i get put} if xchartl 4 eq {SP40 i get put} if xchartl 5 eq {SP35 i get put} if xchartl 6 eq {SP30 i get put} if xchartl 7 eq {SP25 i get put} if }%xchart8=0 Pxx {%xchart8=1 Dxx xchartl 0 eq {SD65 i get put} if xchartl 1 eq {SD50 i get put} if xchartl 2 eq {SP40 i get put} if xchartl 3 eq {SA00 i get put} if xchartl 4 eq {SE00 i get put} if xchartl 5 eq {SC00 i get put} if xchartl 6 eq {SP00 i get put} if xchartl 7 eq {SQ00 i get put} if } ifelse %xchart8=1 Dxx } for %i=0,79 /XSi 82 array def %any radiation /YSi 82 array def /ZSi 82 array def /XASi 82 array def %A=Anteil /YASi 82 array def /ZASi 82 array def /YKSUM 0 def 0 1 79 {/i exch def %i=0,1,79 /YKSUM YKSUM SDAK i get F_CIEi 80 i add get mul add def } for %i=0,1,79 0 1 79 {/i exch def %i=0,1,79 XSi i SDAK i get F_CIEi 00 i add get mul YKSUM div 100 mul put YSi i SDAK i get F_CIEi 80 i add get mul YKSUM div 100 mul put ZSi i SDAK i get F_CIEi 160 i add get mul YKSUM div 100 mul put /SUM XSi i get YSi i get add ZSi i get add 0.0001 add def XASi i XSi i get SUM div put YASi i YSi i get SUM div put ZASi i ZSi i get SUM div put } for %i=0,1,79 %XW,YW,ZW for white /XW 0 def /YW 0 def /ZW 0 def 0 1 079 {/i exch def %i=0,79 /XW XW XSi i get add def /YW YW YSi i get add def /ZW ZW ZSi i get add def } for %i=0,79 /XW100 XW def /YW100 YW def /ZW100 ZW def /SUM XW100 YW100 add ZW100 add 0.0001 add def /XAW100 XW100 SUM div def /YAW100 YW100 SUM div def /ZAW100 ZW100 SUM div def /XN100 XW 0.0001 mul def %100->0.01 /YN100 YW 0.0001 mul def /ZN100 ZW 0.0001 mul def /SUM XN100 YN100 add ZN100 add 0.0001 add def /XAN100 XN100 SUM div def /YAN100 YN100 SUM div def /ZAN100 ZN100 SUM div def %available %XEi, YEi, ZEi, XAEi, YAEi, ZAEi, 0..79 for 380 to 775nm for illuminant E %XSi, YSi, ZSi, XASi, YASi, ZASi, 0..79 for 380 to 775nm for illuminant (P/D)xx %purple colours in proz_chromaticity lines /DOW 82 array def %special for (x,y) diagrams 0 1 79 {/i exch def %i=0,79 = 380_775 DOW i 380 i 5 mul add put } for %i=0,79 %************************************************************** %calculation of wavelength %from ANR1 /proc_ABC_KNP_FWERTiX {%BEG proc_ABC_KNP_FWERT %input XSi,YSi,ZSi, kNP %output FWERTiX/Y/Z (i=1,4) kNP 1 ge {/FWERT1X XSi kNP 1 sub get def /FWERT1Y YSi kNP 1 sub get def /FWERT1Z ZSi kNP 1 sub get def} {/FWERT1X XSi 0 get def %again 400nm for i=0 /FWERT1Y YSi 0 get def /FWERT1Z ZSi 0 get def} ifelse /FWERT2X XSi kNP get def /FWERT2Y YSi kNP get def /FWERT2Z ZSi kNP get def /FWERT3X XSi kNP 1 add get def /FWERT3Y YSi kNP 1 add get def /FWERT3Z ZSi kNP 1 add get def /FWERT4X XSi kNP 2 add get def /FWERT4Y YSi kNP 2 add get def /FWERT4Z ZSi kNP 2 add get def } bind def %END proc_ABC_KNP_FWERTiX %********************************************************* /proc_XIE_TN1 {%BEG proc_XIE_TN1 %input XIE, FWERTiX/Y/Z (i=1,4) %output TN1 /A1N XIE 1 XIE sub mul XIE 2 sub mul 6 div def /A2N XIE 1 add XIE 1 sub mul XIE 2 sub mul 0.5 mul def /A3N XIE 1 add XIE mul 2 XIE sub mul 0.5 mul def /A4N XIE 1 add XIE mul XIE 1 sub mul 6 div def /FNX A1N FWERT1X mul A2N FWERT2X mul add A3N FWERT3X mul add A4N FWERT4X mul add def /FNY A1N FWERT1Y mul A2N FWERT2Y mul add A3N FWERT3Y mul add A4N FWERT4Y mul add def /FNZ A1N FWERT1Z mul A2N FWERT2Z mul add A3N FWERT3Z mul add A4N FWERT4Z mul add def /TNX FNX FXU1 mul FNY FXU2 mul add FNZ FXU3 mul add def } bind def %END proc_XIE_TN1 %********************************************************* /xxi 8 array def % 0 1 2 3 4 5 6 7 % INPi IPNi TN0i TP0i TN1i TP1i DO47 DO47c /xxi [1700 2000 2300 2800 3300 3800 4300 4800] def /ymax 1500 def /xti 13 array def % 0 1 2 3 4 5 6 7 8 % Name range Xti Yti Zti x y ld lp %/xti [2450 2575 3050 3350 3670 4150 4500 4900 5150] def /xti [2700 2875 3300 3600 3920 4250 4600 4960 5190] def /ytax 3700 def % 0 1 2 3 4 5 6 7 8 9 /FX1i 10 array def %lamda1,lambda2,C,R,B,Y,G,M,W,N /FY1i 10 array def /FZ1i 10 array def /XIE1j 10 array def /XIE2j 10 array def /DOW1j 10 array def /DOW2j 10 array def /DOW1jc 10 array def /DOW2jc 10 array def /colXi 13 array def /colYi 13 array def /colZi 13 array def /colXAi 13 array def /colYAi 13 array def /colZAi 13 array def /colfarbi 13 array def /colnamei 13 array def /colxsh1i 13 array def /colysh1i 13 array def /colxsh3i 13 array def /colysh3i 13 array def /colxsh5i 13 array def /colysh5i 13 array def /colxsh7i 13 array def /colysh7i 13 array def % R Y G C B M W N Z % 0 1 2 3 4 5 6 7 8 /colfarbi [%colfarbi 1 0 0 1 1 0 0 1 0 0 1 1 0 0 1 1 0 1 1 1 1 0 0 0 0.5 0.5 0.5 1 0 0 0 0 1 ] def %colfarbi /colnamei [%colnamei (R) (Y) (G) (C) (B) (M) (W) (N) (Z) (G2) (M2) ] def %colnamei %********************************************************************** /colxsh1i [%colxsh1i -100 -120 -420 -450 70 -300 -200 -200 -200 -500 080 ] def %colxsh1i /colysh1i [%colysh1i -250 100 -050 -000 -060 -200 -050 -050 -050 -050 -050 ] def %colysh1i %*********************************************************** /colxsh3i [%colxsh3i -000 -100 -200 -300 -380 -150 -200 -200 -200 -000 -380 ] def %colxsh3i /colysh3i [%colysh3i -200 120 -200 150 -050 110 -050 -050 -050 -200 -050 ] def %colysh3i %************************************************************ /colxsh5i [%colxsh5i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh5i /colysh5i [%colysh5i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh5i /colxsh7i [%colxsh7i 100 070 -450 -450 070 100 -200 -200 -200 100 070 ] def %colxsh7i /colysh7i [%colysh7i -050 070 -050 -050 -150 -050 -050 -050 -050 -050 -150 ] def %colysh7i 0 1 9 {/jq exch def %jq=0,1 jq 0 eq {/FF1 XW100 XSi 4 get sub def /FF2 YW100 YSi 4 get sub def /FF3 ZW100 ZSi 4 get sub def } if jq 1 eq {/FF1 XW100 XSi 64 get sub def /FF2 YW100 YSi 64 get sub def /FF3 ZW100 ZSi 64 get sub def } if jq 2 eq {%STOPA1 /FF1 colXi 0 get def %R(0) /FF2 colYi 0 get def /FF3 colZi 0 get def } if jq 3 eq {%STOPA2 /FF1 colXi 1 get def %Y(1) /FF2 colYi 1 get def /FF3 colZi 1 get def } if jq 4 eq {%STOPA3 /FF1 colXi 2 get def %G(2) /FF2 colYi 2 get def /FF3 colZi 2 get def } if jq 5 eq {%STOPA4 /FF1 colXi 3 get def %C(3) /FF2 colYi 3 get def /FF3 colZi 3 get def } if jq 6 eq {/FF1 colXi 4 get def %B(4) /FF2 colYi 4 get def /FF3 colZi 4 get def } if jq 7 eq {/FF1 colXi 5 get def %M(5) /FF2 colYi 5 get def /FF3 colZi 5 get def %STOPA7 } if jq 8 eq {/FF1 XSi 39 get def /FF2 YSi 39 get def /FF3 ZSi 39 get def } if jq 9 eq {/FF1 colXi 9 get def %G2 /FF2 colYi 9 get def /FF3 colZi 9 get def %STOPA7 } if /U1 XW100 def /U2 YW100 def /U3 ZW100 def /FXU1 FF2 U3 mul FF3 U2 mul sub def /FXU2 FF3 U1 mul FF1 U3 mul sub def /FXU3 FF1 U2 mul FF2 U1 mul sub def /INP -1 def /IPN -1 def %assumption jump from TN to TP from negativ to positiv 4 1 64 {/i exch def %i=4,64 /TN0 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add def /TP0 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add def TN0 0 le TP0 0 gt and {/INP i def exit} if } for %i=4,64 4 1 64 {/i exch def %i=4,64 /TN1 XSi i get FXU1 mul YSi i get FXU2 mul add ZSi i get FXU3 mul add neg def /TP1 XSi i 1 add get FXU1 mul YSi i 1 add get FXU2 mul add ZSi i 1 add get FXU3 mul add neg def TN1 0 le TP1 0 gt and {/IPN i def exit} if } for %i=4,64 /iout 0 def iout 1 eq {%iout=1 1800 3900 jq 200 mul sub moveto TV (jq,FFi: ) show jq cvishow0 (, ) show FF1 cvsshow2 (, ) show FF2 cvsshow2 (, ) show FF3 cvsshow2 } if %iout=1 jq 0 eq {%jq=0 TV /TN00 TN0 def /TP00 TP0 def /TN10 TN1 def /TP10 TP1 def /INP0 INP def /IPN0 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP0 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN0 cvishow0 (, ) show TN00 cvishow0 (, ) show TP00 cvishow0 (, ) show TN10 cvishow0 (, ) show TP10 cvishow0 } if %iout=1 } if %jq=0 jq 1 eq {%jq=1 /jqx jq 250 mul def /TN01 TN0 def /TP01 TP0 def /TN11 TN1 def /TP11 TP1 def /INP1 INP def /IPN1 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP1 cvishow0 (, ) show 380 INP1 5 mul add cvishow (, ) show IPN1 cvishow0 (, ) show TN01 cvishow0 (, ) show TP01 cvishow0 (, ) show TN11 cvishow0 (, ) show TP11 cvishow0 } if %iout=1 } if %jq=1 jq 8 eq {%jq=8 TV /TN02 TN0 def /TP02 TP0 def /TN12 TN1 def /TP12 TP1 def /INP2 INP def /IPN2 IPN def /iout 0 def iout 1 eq {%iout=1 4000 ymax jq 200 mul sub moveto INP2 cvishow0 (, ) show 380 INP0 5 mul add cvishow (, ) show IPN2 cvishow0 (, ) show TN02 cvishow0 (, ) show TP02 cvishow0 (, ) show TN12 cvishow0 (, ) show TP12 cvishow0 } if %iout=1 } if %jq=8 %********************************************************* /kNP INP def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE1 DOW INP get DOW INP 1 add get DOW INP get sub XIE mul add def XIE1j jq XIE put DOW1j jq DOWXIE1 put } if %kNP>=0 %********************************************************* /kNP IPN def kNP 0 ge {%kNP>=0 proc_ABC_KNP_FWERTiX %input XSi,KNP, output FWERTiXYZ (i=1,4) /XIE1 0 def %start values TN=0 for XIE1, TP>0 for XIE2 /XIE2 1 def /FXU1 FXU1 neg def /FXU2 FXU2 neg def /FXU3 FXU3 neg def 0 1 9 {/mk exch def %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def proc_XIE_TN1 %input XIE, ouput TN1 TNX 0 le {/XIE1 XIE def /TN1 TNX def} {/XIE2 XIE def /TP1 TNX def} ifelse } for %mk=0,9 /XIE XIE1 XIE2 add 0.5 mul def /DOWXIE2 DOW IPN get DOW IPN 1 add get DOW IPN get sub XIE mul add def XIE2j jq XIE put DOW2j jq DOWXIE2 put } if %kNP>=0 %********************************************************* INP 0 ge {%INP>=0,-1 /DOWEL1 DOWXIE1 def /DOWEL1c () def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put }%INP>=0 {%INP=-1 /DOWEL1 DOWXIE2 def /DOWEL1c (c) def DOW1j jq DOWEL1 put DOW1jc jq DOWEL1c put } ifelse %INP>=0,-1 IPN 0 ge {%IPN>=0,-1 /DOWEL2 DOWXIE2 def /DOWEL2c () def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put }%IPN>=0 {%IPN=-1 /DOWEL2 DOWXIE1 def /DOWEL2c (c) def DOW2j jq DOWEL2 put DOW2jc jq DOWEL2c put } ifelse %IPN>=0,-1 %********************************************************* jq 0 eq {%jq=0 calculation of FXi, FYi, FZi (i=0 t0 3) %C from 380nm to border between C(3) and R(0) /j0 0 def /j1 INP0 def % R Y G C B M R W N % 0 1 2 3 4 5 6 7 8 /iout 0 def iout 1 eq {%iout=1 TV /jx1 j1 1 sub def /jx2 j1 2 add def jx1 1 jx2 {/jx exch def %jx=jx1,jx2 /jx0 jx jx1 sub def 3700 2300 jx0 200 mul sub moveto jx cvishow (, ) show 380 jx 5 mul add cvishow (, ) show XSi jx get cvsshow2 (, ) show YSi jx get cvsshow2 (, ) show ZSi jx get cvsshow2 (, ) show XIE1j jq get cvsshow2 } for %jx=jx1,jx2 } if %iout=1 j0 1 j1 {/j exch def %j=j0,j1 j j0 eq {%j=j0 /colXC 0 def /colYC 0 def /colZC 0 def } if %j=j0 /colXC colXC XSi j get add def /colYC colYC YSi j get add def /colZC colZC ZSi j get add def } for %j=j0,j1 %correction for C /XIED XIE1j jq get 0.5 sub def XIED 0 le {%XIED<0 and -0,50 and 00 and 00 and 0=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 /jp3 jp 3 mul def 0 setgray colXAposi jp get Yfj jp get delY sub fakt mul 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get Yfj jp get delY sub fakt mul 50 0 360 arc fill newpath 0 setgray colXAposi jp get colxsh3i jp get add Yfj jp get delY sub fakt mul colysh3i jp get add moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL 0 setgray newpath } for %jp=0,5 } if %jnor=1 xchart4 2 eq {/jp1 1 def /jp2 4 def} if %Y_B xchart4 3 eq {/jp1 0 def /jp2 3 def} if %R_C jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[] 0 setdash} if 0 1 1 {/jp exch def %jp=0,1 jp 0 eq {/j jp1 def} if jp 1 eq {/j jp2 def} if jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 0 100 delY sub fakt mul moveto colXAposi j get Yfj j get delY sub fakt mul lineto 0 colYi 7 get delY sub fakt mul lineto stroke 0 setgray } for %jp=0,1 0 setgray jnor 0 eq {[100] 0 setdash} if jnor 1 eq {[50] 0 setdash} if 0 1 2 {/j exch def %j=0,2 start R,Y,G jnor 0 eq {%jnor=0 %always no shift /delY 0 def 1 0 0 setrgbcolor } if %jnor=0 jnor 1 eq {%jnor=1 xchart91 0 eq {%xchart91=0 %always no shift for jnor=1 /delY 0 def 1 0 0 setrgbcolor } if %xchart91=0 xchart91 1 ge {%xchart91>=1 %allways shift for jnor=1 0 1 0 setrgbcolor /delY 100 YZ sub yconsh mul def } if %xchart91>=1 xchart71 0 eq {%xchart71=0 xchart91 0 eq {0 1 0 setrgbcolor} {0 1 0 setrgbcolor} ifelse /delY 0 def } if %xchart71=0 } if %jnor=1 colXAposi j get Yfj j get delY sub fakt mul moveto colXAposi j 3 add get Yfj j 3 add get delY sub fakt mul lineto stroke 0 setgray } for %j=0,2 start R,Y,G [ ] 0 setdash 0 setgray xtrans2_3 neg ytrans2_3 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(CAB,Y) } if %jnor=1 } if %xchart4=2,3 only for (CAB,Y) %******************************************************************** %only for graphics xchart4=4,5 xchart4 4 eq xchart4 5 eq or {%xchart4=4,5 only for (A,B) and (A1,B1) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans4_5 3900 def /ytrans4_5 2100 def xtrans4_5 ytrans4_5 translate proz_axis_scales4_7 /ydt 150 def %xc=0, Bc=1 ? jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray jnor 0 eq {[] 0 setdash} if newpath TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam colXAposi jp get colxsh1i jp get add %special for Yellow colYAposi jp get colysh1i jp get add jp 1 eq {%jp=1 xchart91 2 le {-300 add} if } if %jp=1 moveto colYi jp get 0.5 add cvishow0 %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 } if %jnor=1 TL jnor 1 eq {%jnor=1 0 1 0 setrgbcolor 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill newpath 0 setgray pYnam 1 eq {%pYnam=1 colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam=1 newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans4_5 neg ytrans4_5 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A,A1) } if %jnor=1 } if %xchart4=4,5 only for (A,B) and (A1,B1) %******************************************************************** %only for graphics xchart4=6,7 xchart4 6 eq xchart4 7 eq or {%xchart4=6,7 %only for (A1,B1) & (A2,B2) /fakt 40 def /a2 1.00 def /b2 -0.4 def %section BEG for proz_paramV necessary proz_paramV /xtrans6_7 3900 def /ytrans6_7 2200 def xtrans6_7 ytrans6_7 translate %for text and grafic proz_axis_scales4_7 /ydt 150 def jnor 0 eq {[50] 0 setdash 1 0 0 setrgbcolor} if jnor 1 eq {[ ] 0 setdash xchart91 0 eq {1 0 0 setrgbcolor}{0 1 0 setrgbcolor} ifelse } if %jnor=1 0 1 6 {/j exch def %j=0,6 /i j def j 6 eq {/i 0 def} if /An colXAi i get xc sub colYAi i get 0.0001 add div def /Bn colZAi i get colYAi i get 0.0001 add div 0.4 mul neg Bc mul def /AnK XANK xc sub YANK 0.0001 add div def /BnK ZANK YANK 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub colYi i get mul def /BnY Bn BnK sub colYi i get mul def AnY fakt mul BnY fakt mul j 0 eq {moveto} if j 1 ge j 5 le and {lineto} if j 6 eq {lineto closepath stroke} if j 5 le {%j<=5 colXAposi j AnY fakt mul put colYAposi j BnY fakt mul put } if %i<=5 } for %j=0,6 0 setgray [] 0 setdash newpath jnor 1 eq {%jnor=1 %sRGB or WCGa /colxyYai 24 array def %a=actual /proz_AiBi {%BEG proz_AiBi /xank colxyYai 7 get def /yank colxyYai 15 get def /zank 1 xank sub yank sub def /Yk colxyYai 23 get def 0 1 6 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def jpx 0 eq {AnY fakt mul BnY fakt mul moveto} if jpx 1 ge jpx 6 le and {AnY fakt mul BnY fakt mul lineto} if jpx 6 eq {closepath stroke} if } for %jpx=0,6 TL 0 1 0 setrgbcolor 0 1 5 {/jpx exch def %jpx=0,6 /jpy jpx 08 add def /jpz jpx 16 add def /jp3x jpx 3 mul def /xan1 colxyYai jpx get def /yan1 colxyYai jpy get def /zan1 1. xan1 sub yan1 sub def /Y1 colxyYai jpz get def /An xan1 xc sub yan1 0.0001 add div def /Bn zan1 yan1 0.0001 add div 0.4 mul neg Bc mul def /AnK xank xc sub yank 0.0001 add div def /BnK zank yank 0.0001 add div 0.4 mul neg Bc mul def /AnY An AnK sub Y1 mul def /BnY Bn BnK sub Y1 mul def 0 setgray AnY fakt mul BnY fakt mul 70 0 360 arc fill colfarbi jp3x get colfarbi jp3x 1 add get colfarbi jp3x 2 add get setrgbcolor AnY fakt mul BnY fakt mul 50 0 360 arc fill newpath 0 setgray } for %jp=0,5 } bind def %END proz_AiBi psRGB 1 eq {%psRGB=1 /colxyYsRGBi 24 array def /colxyYsRGBi [%BEG colxyYsRGBi %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.640 0.419 0.300 0.224 0.150 0.320 0.640 0.3127 0.330 0.505 0.600 0.328 0.060 0.154 0.330 0.3290 21.26 92.78 71.52 78.74 07.22 28.48 21.26 100.00 ] def %END colxyYsRGBi 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYsRGBi i get put } for %i=0,23 0 setgray newpath 0 1 0 setrgbcolor proz_AiBi } if %psRGB=1 0 setgray newpath pWCGa 1 eq {%pWCGa=1 /colxyYWCGai 24 array def /colxyYWCGai [%BEG colxyYWCGai %0 1 2 3 4 5 6 7 %R Y G C B M R W 0.708 0.446 0.170 0.146 0.131 0.368 0.708 0.3127 0.292 0.537 0.797 0.344 0.046 0.147 0.292 0.3290 26.26 94.06 67.79 73.72 05.93 32.20 26.26 100.00 ] def %END colxyYWCGai 0 1 23 {/i exch def %i=0,23 colxyYai i colxyYWCGai i get put } for %i=0,23 0 setgray newpath 0 0 1 setrgbcolor proz_AiBi } if %pWCGa=1 } if %jnor=1 %sRGB,WCGa TL jnor 1 eq {%jnor=1 0 1 5 {/jp exch def %jp=0,5 /jp3 jp 3 mul def 0 setgray colXAposi jp get colYAposi jp get 70 0 360 arc fill colfarbi jp3 get colfarbi jp3 1 add get colfarbi jp3 2 add get setrgbcolor colXAposi jp get colYAposi jp get 50 0 360 arc fill pYnam 1 eq {%pYnam newpath 0 setgray colXAposi jp get colxsh7i jp get add colYAposi jp get colysh7i jp get add moveto xchart4 4 ge xchart4 7 le and {colYi jp get 0.5 add cvishow0} if %rounded colnamei jp get show TV 0 -50 rmoveto (d) show 0 50 rmoveto TL } if %pYnam newpath } for %jp=0,5 0 setgray } if %jnor=1 xtrans6_7 neg ytrans6_7 neg translate 0 1 8 {/i exch def %i=0,8 xti i xti i get 1300 sub put } for %i=0,8 /ytax 1280 def jnor 1 eq {%jnor=1 proz_table %(A1,A2) } if %jnor=1 } if %xchart4=6,7 %only for (A1,B1) & (A2,B2) %************************************************************** grestore %end because of clip } for %jnor=0,1 grestore % xchartl 0 eq { 100 neg 13000 neg translate} if % xchartl 1 eq { 6150 neg 13000 neg translate} if % xchartl 2 eq { 100 neg 08740 neg translate} if % xchartl 3 eq { 6150 neg 08740 neg translate} if % xchartl 4 eq { 100 neg 04480 neg translate} if % xchartl 5 eq { 6150 neg 04480 neg translate} if % xchartl 6 eq { 100 neg 00220 neg translate} if % xchartl 7 eq { 6150 neg 00220 neg translate} if } for %xchartl=0,7 } for %xcolorl=0,0 showpage grestore } for %xchart91=0,4 %%Trailer %%EndDocument EndEPSF grestore gsave BeginEPSF 219 MM 080 MM add 008 MM translate %80 MM Breite von TestStreifen 10 /Times-ISOL1 FS 53 MM 1 MM moveto () show 1 1 scale -77 21 MM sub -91 translate %%BeginDocument: Bild 29 Teststreifen Ueberlaenge %line 509 %%EndDocument EndEPSF grestore gsave BeginEPSF -0.0 MM -0.0 MM translate %xy-Verschiebung Rechteckrahmen nach innen% %%BeginDocument: Bild 30 %Rechteckrahmen %line 519 %!PS-Adobe-3.0 EPSF-3.0 Frame arround with Internet text DG02 20070101 %%BoundingBox: 0 0 598 845 %%EndProlog gsave /lanind 1 def /lantex [(G) (E) (S) (N) (I) (J) (M)] def /showde {0 lanind eq {show} {pop} ifelse} bind def /showen {1 lanind eq {show} {pop} ifelse} bind def /showes {2 lanind eq {show} {pop} ifelse} bind def /showfr {3 lanind eq {show} {pop} ifelse} bind def /showit {4 lanind eq {show} {pop} ifelse} bind def /showjp {5 lanind eq {show} {pop} ifelse} bind def /showea {1 lanind le {show} {pop} ifelse} bind def /lanind1 01 def /lanind2 01 def /lanindd 01 def /colorm1 00 def /colorm2 00 def /colormd 01 def /deintp1 00 def /deintp2 00 def /deintpd 01 def /xcolor1 03 def /xcolor2 03 def /xcolord 01 def /xchart1 00 def /xchart2 00 def /xchartd 01 def /pchart1 00 def /pchart2 00 def /pchartd 01 def /colsep1 00 def /colsep2 00 def /colsepd 01 def /pmetam1 00 def /pmetam2 00 def /pmetamd 01 def /lanindf where {pop /lanind1 lanindf def /lanind2 lanindf def /lanindd laninddf def} if /colormf where {pop /colorm1 colormf def /colorm2 colormf def /colormd colormdf def} if /deintpf where {pop /deintp1 deintpf def /deintp2 deintpf def /deintpd deintpdf def} if /xcolorf where {pop /xcolor1 xcolorf def /xcolor2 xcolorf def /xcolord xcolordf def} if /xchartf where {pop /xchart1 xchartf def /xchart2 xchartf def /xchartd xchartdf def /xchartm xchart2f xchart1f sub 1 add def} {/xchartm 1 def} ifelse /xchart3f where {pop /xchart3 xchart3f def} {/xchart3 1 def} ifelse /xchart4f where {pop /xchart4 xchart4f def} {/xchart4 0 def} ifelse /pchartf where {pop /pchart1 pchartf def /pchart2 pchartf def /pchartd pchartdf def} if /colsepf where {pop /colsep1 colsepf def /colsep2 colsepf def /colsepd colsepdf def} if /pmetamf where {pop /pmetam1 pmetamf def /pmetam2 pmetamf def /pmetamd pmetamdf def} if /lanind lanind1 def % /colorm colorm1 def % /deintp deintp1 def % /xcolor xcolor1 def % /xchart xchart1 def % /pchart pchart1 def % /colsep colsep1 def % /pmetam pmetam1 def % /GSS$ where {pop /LSS$ GSS$ def} {/LSS$ (1) def} ifelse /GSC$ where {pop /LSC$ GSC$ def} {/LSC$ (N) def} ifelse /GSX$ where {pop /LSX$ GSX$ def} {/LSX$ (0) def} ifelse /GSY$ where {pop /LSY$ GSY$ def} {/LSY$ (0) def} ifelse /GEX$ where {pop /LEX$ GEX$ def} {/LEX$ (P.PS./PDF) def} ifelse /GEY$ where {pop /LEY$ GEY$ def} {/LEY$ (P.DAT) def} ifelse /IMES 0 def /i*ptrsc 0 def gsave 0 setgray 1.0 1.0 scale 0.0 MM 0.0 MM translate 0.15 MM setlinewidth /x 20 array def /y 20 array def /d 20 array def /x [000 296 296 000 002 294 294 002 005 291 291 005 %speziell 006 290 290 006 008 288 288 008 ] def /y [000 000 210 210 002 002 208 208 005 005 205 205 %speziell 006 006 204 204 008 008 202 202 ] def /d [060 017 -60 -17 058 015 -58 -15 056 013 -56 -13 054 011 -54 -11 052 009 -52 -09 ] def colorm 0 eq deintp 0 eq and {/Txx (d) def /Fxx (d) def} if %colorm=0, deintp=0 colorm 0 eq deintp 1 eq and {/Txx (e) def /Fxx (e) def} if %colorm=0, deintp=1 colorm 1 eq deintp 0 eq and {/Txx (dd) def /Fxx (d) def} if %colorm=1, deintp=0 colorm 1 eq deintp 1 eq and {/Txx (de) def /Fxx (e) def} if %colorm=1, deintp=1 xchart 0 eq {/Txx (-) def /Fxx (-) def} if xchart 1 ge {%xchart>=1 /i0 12 def /i1 i0 1 add def /i2 i0 2 add def /i3 i0 3 add def 2.5 MM /Times-ISOL1 FS x i0 get MM 40 MM add y i0 get MM 1 MM sub moveto lanind cvishow (-) show colorm cvishow deintp cvishow xcolor cvishow xchart cvishow pchart cvishow colsep cvishow (-F) show pmetam cvishow } if %xchart>=1 /xt 1 def xchart 1 eq {/xt 1 def} if xt 0 eq {%xt=0,1 ifelse /i0 12 def /i1 i0 1 add def /i2 i0 2 add def /i3 i0 3 add def 2.5 MM /Times-ISOL1 FS x i0 get MM 110 MM add y i0 get MM 1 MM sub moveto (http://130.149.60.45/~farbmetrik/BEU0/BEU0) show colorm cvishow deintp cvishow colorm 0 eq {(N) show} {(F) show} ifelse (P.PDF & ) show (http://130.149.60.45/~farbmetrik/BEU0/BEU0) show colorm cvishow deintp cvishow colorm 0 eq {(N) show} {(F) show} ifelse (P.TXT & ) show (http://130.149.60.45/~farbmetrik/BEU0/BEU0.HTM) show } %xt=0 { %xt=1 /xlu 017 MM def /ylu 017 MM def /xro 279 MM def /yro 193 MM def /xlo 017 MM def /ylo 193 MM def /xru 279 MM def /yru 017 MM def /xmo xlo xro xlo sub 0.5 mul add def /ymo yro 1 MM sub def xmo 1 MM sub ymo moveto 2 MM 0 rlineto stroke xmo ymo 1 MM sub moveto 0 1 MM rlineto stroke xlu 8 MM sub ylu moveto 16 MM 0 rlineto stroke xlu ylu 8 MM sub moveto 0 16 MM rlineto stroke xro 8 MM add yro moveto -16 MM 0 rlineto stroke xro yro 8 MM add moveto 0 -16 MM rlineto stroke xru 8 MM sub yru moveto 16 MM 0 rlineto stroke xru yru 8 MM sub moveto 0 16 MM rlineto stroke xlo 8 MM add ylo moveto -16 MM 0 rlineto stroke xlo ylo 8 MM add moveto 0 -16 MM rlineto stroke 1 2 7 {/i exch def %Zentrierkreise xlu ylu i MM 0 360 arc stroke xro yro i MM 0 360 arc stroke xru yru i MM 0 360 arc stroke xlo ylo i MM 0 360 arc stroke } for %i 12 4 16 {/i exch def /i0 i def %i=0,16 %0 4 16 {/i exch def /i0 i def %i=0,16 /i1 i0 1 add def /i2 i0 2 add def /i3 i0 3 add def i 16 eq {0.30 MM setlinewidth} {0.15 MM setlinewidth} ifelse 0 setgray x i0 get MM y i0 get MM moveto x i1 get MM y i1 get MM lineto x i2 get MM y i2 get MM lineto x i3 get MM y i3 get MM lineto x i0 get MM y i0 get MM lineto stroke i 16 eq {6 /Times-ISOL1 FS /x00 67 def /xdif 32 def /y0o 202.3 def /y0u 6.3 def /x0l 6.1 def /x0r 288 def /y00 22 def /ydif 32 def x00 xdif 0 mul add MM y0o MM moveto (V) show x00 xdif 0 mul add MM y0u MM moveto (C) show x00 xdif 1 mul add MM y0o MM moveto (L) show x00 xdif 1 mul add MM y0u MM moveto (M) show x00 xdif 2 mul add MM y0o MM moveto (O) show x00 xdif 2 mul add MM y0u MM moveto (Y) show x00 xdif 3 mul add MM y0o MM moveto (Y) show x00 xdif 3 mul add MM y0u MM moveto (O) show x00 xdif 4 mul add MM y0o MM moveto (M) show x00 xdif 4 mul add MM y0u MM moveto (L) show x00 xdif 5 mul add MM y0o MM moveto (C) show x00 xdif 5 mul add MM y0u MM moveto (V) show x0l MM y00 ydif 0 mul add MM moveto (V) show x0r MM y00 ydif 0 mul add MM moveto (C) show x0l MM y00 ydif 1 mul add MM moveto (L) show x0r MM y00 ydif 1 mul add MM moveto (M) show x0l MM y00 ydif 2 mul add MM moveto (O) show x0r MM y00 ydif 2 mul add MM moveto (Y) show x0l MM y00 ydif 3 mul add MM moveto (Y) show x0r MM y00 ydif 3 mul add MM moveto (O) show x0l MM y00 ydif 4 mul add MM moveto (M) show x0r MM y00 ydif 4 mul add MM moveto (L) show x0l MM y00 ydif 5 mul add MM moveto (C) show x0r MM y00 ydif 5 mul add MM moveto (V) show } if } for %i=0,16 0 1 10 {/j0 exch def /j1 j0 1 add def %j0 j0 0 eq {tzccmy0* setcmykcolor} if j0 1 eq {0 setgray} if j0 2 eq {tzmcmy0* setcmykcolor} if j0 3 eq {0 setgray} if j0 4 eq {tzycmy0* setcmykcolor} if j0 5 eq {0 setgray} if j0 6 eq {tzocmy0* setcmykcolor} if j0 7 eq {0 setgray} if j0 8 eq {tzlcmy0* setcmykcolor} if j0 9 eq {0 setgray} if j0 10 eq {tzvcmy0* setcmykcolor} if 12 4 16 {/i exch def /i0 i def %i=0,16 %0 4 16 {/i exch def /i0 i def %i=0,16 /i1 i0 1 add def /i2 i0 2 add def /i3 i0 3 add def i 16 eq {0.30 MM setlinewidth} {0.15 MM setlinewidth} ifelse x i0 get d i0 get add 16 j0 mul add MM y i0 get MM moveto x i0 get d i0 get add 16 j1 mul add MM y i0 get MM lineto stroke x i1 get MM y i1 get d i1 get add 16 j0 mul add MM moveto x i1 get MM y i1 get d i1 get add 16 j1 mul add MM lineto stroke x i2 get d i2 get add 16 j0 mul sub MM y i2 get MM moveto x i2 get d i2 get add 16 j1 mul sub MM y i2 get MM lineto stroke x i3 get MM y i3 get d i3 get add 16 j0 mul sub MM moveto x i3 get MM y i3 get d i3 get add 16 j1 mul sub MM lineto stroke } for %i=0,16 } for %j0 0.15 MM setlinewidth /s 7 MM def /s1 8 MM def /s5 36 MM def 16 1 20 {/j exch def /j0 j 16 sub def %j=16,20 /ix0 xlu 8 MM add j0 7 MM mul add def /iy0 ylu 8 MM sub def 0 1 3 {/ij exch def %ij=0,3 ij 0 eq {/ix0 xlu 8 MM add j0 7 MM mul add def /iy0 ylu 8 MM sub def} if ij 1 eq {/ix0 xru 43 MM sub j0 7 MM mul add def /iy0 yru 8 MM sub def} if ij 2 eq {/ix0 xlo 8 MM add j0 7 MM mul add def /iy0 ylo 1 MM add def} if ij 3 eq {/ix0 xro 43 MM sub j0 7 MM mul add def /iy0 yro 1 MM add def} if i*ptrsc 0 eq i*ptrsc 2 eq or {%i*ptrsc=0,2 cmy0* setcmykcolor j 16 eq {tzan j get dup dup 0 setcmykcolor ix0 0.5 MM sub iy0 0.5 MM sub s5 s1 rec fill} if tzan j get dup dup 0 setcmykcolor ix0 iy0 s s rec fill } if %i*ptrsc=0,2 i*ptrsc 1 eq i*ptrsc 3 eq or {%i*ptrsc=1,3 www* setrgbcolor j 16 eq {1 tzan j get 1 sub dup dup setrgbcolor %N ix0 0.5 MM sub iy0 0.5 MM sub s5 s1 rec fill} if 1 tzan j get sub dup dup setrgbcolor %N ix0 iy0 s s rec fill } if %i*ptrsc=1,3 i*ptrsc 4 eq i*ptrsc 5 eq or {%i*ptrsc=4,5 [/CIEBasedABC << %Farbraum und Grenzen fuer D65 /RangeABC [0 100 -128 127 -128 127] /DecodeABC [{16 add 116 div} bind {500 div} bind {200 div} bind] /MatrixABC [1 1 1 1 0 0 0 0 -1] /DecodeLMN [{dup 6 29 div ge {dup dup mul mul} {4 29 div sub 108 841 div mul} ifelse 0.9505 mul} bind {dup 6 29 div ge {dup dup mul mul} {4 29 div sub 108 841 div mul} ifelse} bind {dup 6 29 div ge {dup dup mul mul} {4 29 div sub 108 841 div mul} ifelse 1.0890 mul} bind] /WhitePoint [0.9505 1 1.089] %CIEXYZ fuer D65 >>] setcolorspace j 16 eq {tznLAB* 0 get tzwLAB* 0 get tznLAB* 0 get sub 0.25 j0 mul mul add tznLAB* 1 get tzwLAB* 1 get tznLAB* 1 get sub 0.25 j0 mul mul add tznLAB* 2 get tzwLAB* 2 get tznLAB* 2 get sub 0.25 j0 mul mul add setcolor %N ix0 0.5 MM sub iy0 0.5 MM sub s5 s1 rec fill} if tznLAB* 0 get tzwLAB* 0 get tznLAB* 0 get sub 0.25 j0 mul mul add tznLAB* 1 get tzwLAB* 1 get tznLAB* 1 get sub 0.25 j0 mul mul add tznLAB* 2 get tzwLAB* 2 get tznLAB* 2 get sub 0.25 j0 mul mul add setcolor %N ix0 iy0 s s rec fill } if %i*ptrsc=4,5 i*ptrsc 6 eq {%i*ptrsc=6 000n* setcmykcolor j 16 eq {0 0 0 tzan j get setcmykcolor ix0 0.5 MM sub iy0 0.5 MM sub s5 s1 rec fill} if 0 0 0 tzan j get setcmykcolor ix0 iy0 s s rec fill } if %i*ptrsc=6 i*ptrsc 7 eq {%i*ptrsc=7 w* setgray j 16 eq {1 tzan j get sub setgray ix0 0.5 MM sub iy0 0.5 MM sub s5 s1 rec fill} if 1 tzan j get sub setgray ix0 iy0 s s rec fill } if %i*ptrsc=7 } for %ij=0,3 } for %j=16,20 0 setgray 018 MM 008.2 MM moveto 6 /Times-Roman FS (-8) show 018 MM 006.2 MM moveto 6 /Times-Roman FS (-6) show 276 MM 008.2 MM moveto 6 /Times-Roman FS (-8) show 276 MM 006.2 MM moveto 6 /Times-Roman FS (-6) show 018 MM 202.2 MM moveto 6 /Times-Roman FS (-8) show 018 MM 204.2 MM moveto 6 /Times-Roman FS (-6) show 276 MM 202.2 MM moveto 6 /Times-Roman FS (-8) show 276 MM 204.2 MM moveto 6 /Times-Roman FS (-6) show /10TIN {10 /Times-ISOL1 FS} def /10TRN {10 /Times-Roman FS} def /12TIN {12 /Times-ISOL1 FS} def /12TRN {12 /Times-Roman FS} def /10TII {10 /TimesI-ISOL1 FS} def /10TRI {10 /Times-Italic FS} def /12TII {12 /TimesI-ISOL1 FS} def /12TRI {12 /Times-Italic FS} def /10TIB {10 /TimesB-ISOL1 FS} def /10TRB {10 /Times-Bold FS} def /12TIB {12 /TimesB-ISOL1 FS} def /12TRB {12 /Times-Bold FS} def /10TIBI {10 /TimesBI-ISOL1 FS} def /10TRBI {10 /Times-BoldItalic FS} def /12TIBI {12 /TimesBI-ISOL1 FS} def /12TRBI {12 /Times-BoldItalic FS} def %special /10TIN10 {10TIN 0 -3 rmoveto xcolor 1 eq {(10) show} if 0 3 rmoveto} def /10TINi10 {10TIN 0 -3 rmoveto (i) show xcolor 1 eq {(,10) show} if 0 3 rmoveto} def /TELi0 8 array def /TELi1 8 array def /TELi 8 array def /TELi0 [(P60) (P55) (P50) (P45) (P40) (P35) (P30) (P25)] def %7 illumin. /TELi1 [(D65) (D50) (P40) (A00) (E00) (C00) (P00) (Q00)] def %7 illumin. /xchart8 1 def %xchart8=0: Pxx, xchart8=1: Dxx 0 1 7 {/i exch def %i=0,7 xchart8 0 eq {%xchart8=0 TELi i TELi0 i get put }%xchart8=0 {%xchart8=1 TELi i TELi1 i get put } ifelse %xchart8=1 } for %i=0,7 0 setgray 12TIN 61 MM 13.5 MM moveto (TUB\255Pr\374fvorlage BEU0; ) showde %0BEU0X-Y 0000# (TUB\255test chart BEU0; ) showen %1BEU0X-Y 0000# (gr\341fico TUB\255BEU0; ) showes %2BEU0X-Y 0000# (TUB\255test graphique BEU0; ) showfr %3BEU0X-Y 0000# (grafico TUB\255BEU0; ) showit %4BEU0X-Y 0000# (TUB\255test chart BEU0; ) showjp %5BEU0X-Y 0000# /xchart41 0 def %not used %default 12TII (Ostwald) show 12TIN ( colours in chromaticity diagram ) showen (\255Farben in Normfarbtafel ) showde 12TII (x, y) show /K 0 def /pOstw 1 def /psRGB 1 def /pWCGa 1 def 61 MM 09.5 MM moveto 12TIN (CIE\255Daten von 3 Grund\255 und Mischfarben von ) showde %0BEU0X-Y 0200# (CIE data of 3 basic and 3 mixture colours of ) showea %ABEU0X-Y 0200# pOstw 1 eq {%pOstw=1 12TII (Ostwald) show 12TIN ( colours, ) showen (\255Farben, ) showde } if %pOstw=1 psRGB 1 eq {%psRGB=1 (sRGB displays, ) showen (sRGB-Displays, ) showde } if %psRGB=1 pWCGa 1 eq {%pWCGa=1 (WCGa displays ) showen (WCGa-Displays ) showde } if %pWCGa=1 xchart 1 ge {%xchart>=1 12TIN (, 3D=) show colorm cvishow (, de=) show deintp cvishow 12TII xchart5f 0 eq {(, sRGB) show} if xchart5f 1 eq {(, cmyk) show} if xchart5f 2 eq {(, cmy0) show} if xchart5f 3 eq {(, cmyk) show} if colorm 1 eq {(*) show} if } if %xchart>=1 12TIN 184 MM 13.5 MM moveto (Eingabe: ) showde %0BEU0X-Y 0500# (input: ) showen %1BEU0X-Y 0500# (entrada: ) showes %2BEU0X-Y 0500# (entr\351e: ) showfr %3BEU0X-Y 0500# (immettere: ) showit %4BEU0X-Y 0500# (input: ) showjp %5BEU0X-Y 0500# 12TII (rgb/cmy0) show xchart41 0 eq {( (No 1MR)) show} {(->rgb ) show ((1MR)) show} ifelse %xchart xchart3 lt {(w/rgb/cmyk) show % } if %xchart xchart3 ge {%xchart>=xchart3 % (rgb) show % } if %xchart>=xchart3 %10 /Times-ISOL1 FS %0 -2 rmoveto Txx show 0 2 rmoveto %12TIN 12TIN %184 MM 9.5 MM moveto %(Ausgabe: ) showde %0BEU0X-Y 0600# %(output: ) showen %1BEU0X-Y 0600# %(salida: ) showes %2BEU0X-Y 0600# %(sortie: ) showfr %3BEU0X-Y 0600# %(uscita: ) showit %4BEU0X-Y 0600# %(output: ) showjp %5BEU0X-Y 0600# %colorm=0,1! %12TIN %xchart 0 eq {%xchart=0,#0 %xchart41 0 eq {12TIN % (no change) showen % (keine \304nderung) showde} % {12TIN % (change of gamma ) showen % (\304nderung Gamma ) showde % 12TII % (g) show % 10TIN % 0 -2 rmoveto (P) show 0 2 rmoveto} ifelse %12TIN %(rechts) showde %0BEU0X-Y 0700# %(right) showea %1BEU0X-Y 0700# %(ning\372n cambio) showes %2BEU0X-Y 0700# %(aucun changement) showfr %3BEU0X-Y 0700# %(nessun cambiamento) showit %4BEU0X-Y 0700# %(no change compared) showjp %5BEU0X-Y 0700# % }%xchart=0 % % {%xchart#0 % 12TIN % colorm 0 eq {%colorm=0 %(Transfer nach ) showde %0BEU0X-Y 0800# %(transfer to ) showen %1BEU0X-Y 0800# %(transfiera a ) showes %2BEU0X-Y 0800# %(transf\351rer \340 ) showfr %3BEU0X-Y 0800# %(trasferire a ) showit %4BEU0X-Y 0800# %(transfer to ) showjp %5BEU0X-Y 0800# % }%colorm=0 % {%colorm=1 %(3D\255Linearisierung ) showde %0BEU0X-Y 0900# %(3D\255linearization to ) showen %1BEU0X-Y 0900# %(3D\255linealizaci\363n a ) showes %2BEU0X-Y 0900# %(linearisation 3D selon ) showfr %3BEU0X-Y 0900# %(3D\255linearizzazione a ) showit %4BEU0X-Y 0900# %(3D\255linearization to ) showjp %5BEU0X-Y 0900# % } ifelse %colorm=1 %12TII %xchart5f 0 eq {(rgb) show} if %xchart5f 1 eq {(cmyk) show} if %xchart5f 2 eq {(cmy0) show} if %xchart5f 3 eq {(cmyk) show} if %colorm 1 eq {(*) show} if %10 /Times-ISOL1 FS %0 -2 rmoveto Txx show 0 2 rmoveto %12TIN %} ifelse %xchart=0,#0 %0 setgray %end white and unvisible 12TIN 62 MM 198.5 MM moveto 12TRN (http://farbe.li.tu-berlin.de/BEU0/BEU0L) show 12TIN (0) show % LSC$ show LEX$ show xchart41 4 le {(; only vector graphic VG) showen (; nur Vektorgrafik VG) showde} if % {(; VG with ISO\255PG image) showen % (; VG mit ISO\255PG\255Bild) showde} ifelse %1 setgray %start white and unvisible (; ) show xchart 0 eq { (Start\255Ausgabe) showde %0BEU0X-Y 1000# (start output) showen %1BEU0X-Y 1000# (comience salida) showes %2BEU0X-Y 1000# (sortie de production) showfr %3BEU0X-Y 1000# (cominciare l'uscita) showit %4BEU0X-Y 1000# (start output) showjp %5BEU0X-Y 1000# } if LSC$ (C) eq { (Start\255Ausgabe) showde %0BEU0X-Y 1100# (start output) showen %1BEU0X-Y 1100# (comience salida) showes %2BEU0X-Y 1100# (sortie de production) showfr %3BEU0X-Y 1100# (cominciare l'uscita) showit %4BEU0X-Y 1100# (start output) showjp %5BEU0X-Y 1100# } if xchart 1 ge {%xchart>=1 colorm 0 eq {%colorm=0,1 (Transfer Ausgabe) showde %0BEU0X-Y 1200# (transfer output) showen %1BEU0X-Y 1200# (salida de transferencia) showes %2BEU0X-Y 1200# (sortie de transfert) showfr %3BEU0X-Y 1200# (uscita di trasferimento) showit %4BEU0X-Y 1200# (transfer output) showjp %5BEU0X-Y 1200# }%colorm=0 {%colorm=1 (3D\255Linearisierung) showde %0BEU0X-Y 1300# (3D\255linearization) showen %1BEU0X-Y 1300# (3D\255linealizaci\363n) showes %2BEU0X-Y 1300# (linearisation 3D) showfr %3BEU0X-Y 1300# (3D\255linearizzzazione) showit %4BEU0X-Y 1300# (3D\255linearization) showjp %5BEU0X-Y 1300# } ifelse %colorm=0,1 } if %xchart>=1 62 MM 194 MM moveto LSC$ (N) eq LSC$ (C) eq or { (N: Keine 3D\255Linearisierung (OL) ) showde %0BEU0X-Y 1400# (N: no 3D\255linearization (OL) ) showen %1BEU0X-Y 1400# (N: ninguna 3D\255linealizaci\363n (OL) ) showes %2BEU0X-Y 1400# (N: aucun linearisation 3D (OL) ) showfr %3BEU0X-Y 1400# (N: nessun 3D\255linearizzazione (OL) ) showit %4BEU0X-Y 1400# (N: no 3D\255linearization (OL) ) showjp %5BEU0X-Y 1400# (in Datei (F) oder PS\255Startup (S)) showde %0BEU0X-Y 1500# (in file (F) or PS\255startup (S)) showen %1BEU0X-Y 1500# (en archivo (F) o PS\255startup (S)) showes %2BEU0X-Y 1500# (dans fichier (F) ou PS\255startup (S)) showfr %3BEU0X-Y 1500# (nel file (F) o PS\255startup (S)) showit %4BEU0X-Y 1500# (in file (F) or PS\255startup (S)) showjp %5BEU0X-Y 1500# } {LSC$ show (: ) show (3D\255Linearisierung) showde %0BEU0X-Y 1600# (3D\255linearization) showen %1BEU0X-Y 1600# (3D\255linealizaci\363n) showes %2BEU0X-Y 1600# (linearisation 3D) showfr %3BEU0X-Y 1600# (3D\255linearizzzazione) showit %4BEU0X-Y 1600# (3D\255linearization) showjp %5BEU0X-Y 1600# ( BEU0/BEU0L) show LSS$ show LSX$ show (0) show % LSC$ show LEY$ show } ifelse LSC$ (F) eq { ( in Datei (F)) showde %0BEU0X-Y 1700# ( in file (F)) showen %1BEU0X-Y 1700# ( en archivo (F)) showes %2BEU0X-Y 1700# ( dans fichier (F)) showfr %3BEU0X-Y 1700# ( nel file (F)) showit %4BEU0X-Y 1700# ( in file (F)) showjp %5BEU0X-Y 1700# } if LSC$ (S) eq { ( im Distiller Startup (S) Directory) showde %0BEU0X-Y 1800# ( in Distiller Startup (S) Directory) showen %1BEU0X-Y 1800# ( en el Distiller Startup (S) Directory) showes %2BEU0X-Y 1800# ( dans le Distiller Startup (S) Directory) showfr %3BEU0X-Y 1800# ( nel Distiller Startup (S) Directory) showit %4BEU0X-Y 1800# ( in Distiller Startup (S) Directory) showjp %5BEU0X-Y 1800# } if LSC$ (D) eq { ( in PS\255Device (D)) showde %0BEU0X-Y 1900# ( in PS\255device (D)) showen %1BEU0X-Y 1900# ( en el PS\255device (D)) showes %2BEU0X-Y 1900# ( dans l'appareil PS (D)) showfr %3BEU0X-Y 1900# ( nel PS\255dispositivo (D)) showit %4BEU0X-Y 1900# ( in PS\255Device (D)) showjp %5BEU0X-Y 1900# } if LSC$ (T) eq { ( im Distiller Startup (S) Directory) showde %0BEU0X-Y 2000# ( in Distiller Startup (S) Directory) showen %1BEU0X-Y 2000# ( en el Distiller Startup (S) Directory) showes %2BEU0X-Y 2000# ( dans le Distiller Startup (S) Directory) showfr %3BEU0X-Y 2000# ( nel Distiller Startup (S) Directory) showit %4BEU0X-Y 2000# ( in Distiller Startup (S) Directory) showjp %5BEU0X-Y 2000# } if LSC$ (E) eq { ( in PS\255Device (D)) showde %0BEU0X-Y 2100# ( in PS\255device (D)) showen %1BEU0X-Y 2100# ( en el PS\255device (D)) showes %2BEU0X-Y 2100# ( dans appareil PS (D)) showfr %3BEU0X-Y 2100# ( nel PS\255dispositivo (D)) showit %4BEU0X-Y 2100# ( in PS\255Device (D)) showjp %5BEU0X-Y 2100# } if %0 setgray %end white and unvisible (, Seite ) showde %0BEU0X-Y 2200# (, page ) showen %1BEU0X-Y 2200# (, p\341gina ) showes %2BEU0X-Y 2200# (, page ) showfr %3BEU0X-Y 2200# (, pagina ) showit %4BEU0X-Y 2200# (, page ) showjp %5BEU0X-Y 2200# xchart 1 add cvishow (/) show xchartm cvishow 16 MM 185 MM moveto -90 rotate (Siehe \344hnliche Dateien: ) showde %0BEU0X-Y 2300# (see similar files: ) showen %1BEU0X-Y 2300# (vea archivos semejantes: ) showes %2BEU0X-Y 2300# (voir des fichiers similaires: ) showfr %3BEU0X-Y 2300# (vedere dei file simili: ) showit %4BEU0X-Y 2300# (see similar files: ) showjp %5BEU0X-Y 2300# 12TRN (http://farbe.li.tu-berlin.de/BEU0/BEU0.HTM) show 12TIN %(0) show % %LSC$ show LEX$ show 90 rotate 12 MM 185 MM moveto -90 rotate (Technische Information: ) showde %0BEU0X-Y 2400# (technical information: ) showen %1BEU0X-Y 2400# (informaci\363n t\351cnica: ) showes %2BEU0X-Y 2400# (informations techniques: ) showfr %3BEU0X-Y 2400# (informazioni tecniche: ) showit %4BEU0X-Y 2400# (technical information: ) showjp %5BEU0X-Y 2400# 12TRN (http://farbe.li.tu-berlin.de) show 12TIN ( oder ) showde %0BEU0X-Y 2500# ( or ) showen %1BEU0X-Y 2500# ( o ) showes %2BEU0X-Y 2500# ( ou ) showfr %3BEU0X-Y 2500# ( o ) showit %4BEU0X-Y 2500# ( or ) showjp %5BEU0X-Y 2500# 12TRN (http://color.li.tu-berlin.de) show 12TIN 90 rotate 281 MM 185 MM moveto -90 rotate (TUB\255Registrierung: 20210301\255BEU0/BEU0L) showde %0BEU0X-Y 2600# (TUB registration: 20210301\255BEU0/BEU0L) showen %1BEU0X-Y 2600# (TUB matr\355cula: 20210301\255BEU0/BEU0L) showes %2BEU0X-Y 2600# (TUB enregistrement: 20210301\255BEU0/BEU0L) showfr %3BEU0X-Y 2600# (TUB iscrizione: 20210301\255BEU0/BEU0L) showit %4BEU0X-Y 2600# (TUB registration: 20210301\255BEU0/BEU0L) showjp %5BEU0X-Y 2600# (0) show % LSC$ show LEX$ show 90 rotate 281 MM 74 MM moveto -90 rotate (TUB\255Material: Code=rha4ta) showde %0BEU0X-Y 2700# (TUB material: code=rha4ta) showen %1BEU0X-Y 2700# (TUB material: code=rha4ta) showes %2BEU0X-Y 2700# (TUB mat\351riel: code=rha4ta) showfr %3BEU0X-Y 2700# (TUB materiale: code=rha4ta) showit %4BEU0X-Y 2700# (TUB material: code=rha4ta) showjp %5BEU0X-Y 2700# 90 rotate 277 MM 185 MM moveto -90 rotate /cvishow {cvi 6 string cvs show} def /cvsshow1 {10 mul cvi 0.1 mul 7 string cvs show} def ( Anwendung f\374r Beurteilung und Messung ) showde %0BEU0X-Y 2800# ( application for evaluation and measurement ) showen %1BEU0X-Y 2800# ( aplicaci\363n para la medida ) showes %2BEU0X-Y 2800# ( application pour la mesure ) showfr %3BEU0X-Y 2800# ( la domanda per la misura ) showit %4BEU0X-Y 2800# ( application for measurement ) showjp %5BEU0X-Y 2800# xchart5f 0 eq {%xchart5f=0 (von Display\255 oder Druck\255Ausgabe) showde %0BEU0X-Y 2900# (of display or print output) showen %1BEU0X-Y 2900# (de display output) showes %2BEU0X-Y 2900# (de sortie sur \350cran) showfr %3BEU0X-Y 2900# (di stampa di display) showit %4BEU0X-Y 2900# (of display output) showjp %5BEU0X-Y 2900# } if %xchart5f=0 xchart5f 1 eq xchart5f 2 eq or {%xchart5f=1,2 (von Offsetdruck\255Ausgabe) showde %0BEU0X-Y 3000# (of offset print output) showen %1BEU0X-Y 3000# (salida en la impressi\363n offset) showes %2BEU0X-Y 3000# (des sorties sur offset) showfr %3BEU0X-Y 3000# (uscita nella stampa di offset) showit %4BEU0X-Y 3000# (of offset print output) showjp %5BEU0X-Y 3000# } if %xchart5f=1,2 xchart5f 3 eq {%xchart5f=3 (von Laserdrucker\255Ausgabe) showde %0BEU0X-Y 3100# (of laser printer output) showen %1BEU0X-Y 3100# (salida de impresora l\341ser) showes %2BEU0X-Y 3100# (des sorties sur imprimante laser) showfr %3BEU0X-Y 3100# (di uscita della stampante laser) showit %4BEU0X-Y 3100# (of laser printer output) showjp %5BEU0X-Y 3100# } if %xchart5f=3 xchart 1 ge {%xchart>=1 xchart5f 0 eq {%xchart5f=0 (, keine Separation) showde %0BEU0X-Y 3200# (, no separation) showen %1BEU0X-Y 3200# (, ninguna separaci\363n) showes %2BEU0X-Y 3200# (, aucune s\351paration) showfr %3BEU0X-Y 3200# (, nessuna separazione) showit %4BEU0X-Y 3200# (, no separation) showjp %5BEU0X-Y 3200# } if %chart5f=0 xchart5f 1 ge {%xchart5f>=1 (, Separation) showde %0BEU0X-Y 3300# (, separation) showen %1BEU0X-Y 3300# (, separaci\363n) showes %2BEU0X-Y 3300# (, s\351paration) showfr %3BEU0X-Y 3300# (, separazione) showit %4BEU0X-Y 3300# (, separation) showjp %5BEU0X-Y 3300# xchart5f 1 eq xchart5f 3 eq or {(cmyn6) show} if xchart5f 2 eq {(cmy0) show} if colorm 1 eq {(*) show} if colsep 0 eq {( (CMYK))}{( (CMY0))} ifelse show } if %xchart5f>=1 } if %xchart>=1 IMES 1 eq LSC$ (N) ne and { %IMES=1 (, Yr=) show Yre cvsshow1 (, XYZ) show } if %IMES=1 90 rotate /i0 8 def /i1 i0 1 add def /i2 i0 2 add def /i3 i0 3 add def 0.30 MM setlinewidth 0 setgray x i0 get MM y i0 get MM moveto x i1 get MM y i1 get MM lineto x i2 get MM y i2 get MM lineto x i3 get MM y i3 get MM lineto x i0 get MM y i0 get MM lineto stroke %/xlu1 013 MM def /ylu1 010 MM def %/xro1 283 MM def /yro1 200 MM def %/xlo1 013 MM def /ylo1 200 MM def %/xru1 283 MM def /yru1 010 MM def %xlu1 4 MM sub ylu1 moveto 8 MM 0 rlineto stroke %xlu1 ylu1 4 MM sub moveto 0 8 MM rlineto stroke %xro1 4 MM add yro1 moveto -8 MM 0 rlineto stroke %xro1 yro1 4 MM add moveto 0 -8 MM rlineto stroke %xru1 4 MM sub yru1 moveto 8 MM 0 rlineto stroke %xru1 yru1 4 MM sub moveto 0 8 MM rlineto stroke %xlo1 4 MM add ylo1 moveto -8 MM 0 rlineto stroke %xlo1 ylo1 4 MM add moveto 0 -8 MM rlineto stroke } ifelse %xt=1 grestore gsave %********************************************************** %%Trailer %%EndDocument EndEPSF grestore gsave showpage grestore %} for %colsepf=0,1 %} for %pchartf=0,0 %} for %xchartf=0,0 %} for %xcolorf=0,1 %} for %deintpf=0,1 %} for %colormf=0,1 %} for %lanindf=0,0 %%Trailer