%!PS-Adobe-3.0 EPSF-3.0 CEG01-7N %%BoundingBox: 70 82 395 580 %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/BEW4/BEW4.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:2022030112000) /ModDate (D:20220301112000) /DOCINFO pdfmark17 [ /View [ /Fit ] /DOCVIEW pdfmark17 %END PDFDE011 /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-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 /FS {findfont exch scalefont setfont} bind def /MM {72 25.4 div mul} def /str {8 string } bind def /TS {160 /Times-ISOL1 FS} bind def /TL {200 /Times-ISOL1 FS} bind def /TK {250 /Times-ISOL1 FS} bind def /TM {300 /Times-ISOL1 FS} bind def /TG {350 /Times-ISOL1 FS} bind def /TIS {160 /TimesI-ISOL1 FS} bind def /TIL {200 /TimesI-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 /TBS {160 /TimesB-ISOL1 FS} bind def /TBL {200 /TimesB-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 /TBIS {160 /TimesBI-ISOL1 FS} bind def /TBIL {200 /TimesBI-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 /SS {160 /Symbol FS} bind def /SL {200 1 sub /Symbol FS} bind def /SK {250 1 sub /Symbol FS} bind def /SM {300 1 sub /Symbol FS} bind def /SG {350 1 sub /Symbol FS} bind def /CS {160 /Courier-ISOL1 FS} bind def /CL {200 /Courier-ISOL1 FS} bind def /CK {250 /Courier-ISOL1 FS} bind def /CM {300 /Courier-ISOL1 FS} bind def /CG {350 /Courier-ISOL1 FS} bind def /CBS {160 /CourierB-ISOL1 FS} bind def /CBL {200 /CourierB-ISOL1 FS} bind def /CBK {250 /CourierB-ISOL1 FS} bind def /CBM {300 /CourierB-ISOL1 FS} bind def /CBG {350 /CourierB-ISOL1 FS} bind def /nGs {350 /Times-ISOL1 FS show} bind def /kGs {350 /TimesI-ISOL1 FS show} bind def /bGs {350 /TimesB-ISOL1 FS show} bind def /jGs {350 /TimesBI-ISOL1 FS show} bind def /sGs {350 /Symbol FS show} bind def /iGs {300 /Times-ISOL1 FS 0 -90 rmoveto show 0 90 rmoveto} bind def /eGs {300 /Times-ISOL1 FS 0 200 rmoveto show 0 -200 rmoveto} bind def /ibGb {300 /TimesB-ISOL1 FS 0 -90 rmoveto show 0 90 rmoveto} bind def /ebGb {300 /TimesB-ISOL1 FS 0 200 rmoveto show 0 -200 rmoveto} bind def /ipG {300 /Times-ISOL1 FS 50 50 rmoveto (\267) show 50 -50 rmoveto} bind def %20% kleiner /nMs {300 /Times-ISOL1 FS show TM} bind def /kM2 {300 /TimesI-ISOL1 FS show TM} bind def /bM2 {300 /TimesB-ISOL1 FS show TM} bind def /jM2 {300 /TimesBI-ISOL1 FS show TM} bind def /sMs {300 /Symbol FS show TM} bind def /iMs {250 /Times-ISOL1 FS 0 -70 rmoveto show 0 70 rmoveto TM} bind def /eMs {250 /Times-ISOL1 FS 0 160 rmoveto show 0 -160 rmoveto TM} bind def /ibMs {250 /TimesB-ISOL1 FS 0 -70 rmoveto show 0 70 rmoveto TM} bind def /ebMs {250 /TimesB-ISOL1 FS 0 160 rmoveto show 0 -160 rmoveto TM} bind def /ipM {250 /Times-ISOL1 FS 40 40 rmoveto (\267) show 40 -40 rmoveto TM} bind def %40% kleiner /nKs {250 /Times-ISOL1 FS show TK} bind def /kKs {250 /TimesI-ISOL1 FS show TK} bind def /bKs {250 /TimesB-ISOL1 FS show TK} bind def /jKs {250 /TimesBI-ISOL1 FS show TK} bind def /sKs {250 /Symbol FS show TK} bind def /iKs {200 /Times-ISOL1 FS 0 -60 rmoveto show 0 60 rmoveto TK} bind def /eKs {200 /Times-ISOL1 FS 0 130 rmoveto show 0 -130 rmoveto TK} bind def /ibKs {200 /TimesB-ISOL1 FS 0 -60 rmoveto show 0 60 rmoveto TK} bind def /ebKs {200 /TimesB-ISOL1 FS 0 130 rmoveto show 0 -130 rmoveto TK} bind def /ipK {200 /Times-ISOL1 FS 30 30 rmoveto (\267) show 30 -30 rmoveto TK} bind def %60% kleiner /nLs {200 /Times-ISOL1 FS show TS} bind def /kLs {200 /TimesI-ISOL1 FS show TS} bind def /bLs {200 /TimesB-ISOL1 FS show TS} bind def /jLs {200 /TimesBI-ISOL1 FS show TS} bind def /sLs {200 /Symbol FS show TS} bind def /iLs {160 /Times-ISOL1 FS 0 -50 rmoveto show 0 50 rmoveto TS} bind def /eLs {160 /Times-ISOL1 FS 0 110 rmoveto show 0 -110 rmoveto TS} bind def /ibLs {160 /TimesB-ISOL1 FS 0 -50 rmoveto show 0 50 rmoveto TS} bind def /ebLs {160 /TimesB-ISOL1 FS 0 080 rmoveto show 0 -080 rmoveto TS} bind def /ipL {160 /Times-ISOL1 FS 25 25 rmoveto (\267) show 25 -25 rmoveto TS} bind def /ibLm {160 /TimesB-ISOL1 FS -50 -50 rmoveto show 0 50 rmoveto TS} bind def /ibLn {160 /TimesB-ISOL1 FS -30 -50 rmoveto show 0 50 rmoveto TS} bind def %special for colour spaces based on Y/Yn and Y/Yu %o=out /nuo {ityp 2 le {(n) show} {(u) show} ifelse} bind def /nco {(nc) show} def /nLso {200 /Times-ISOL1 FS nuo show TS} bind def /kLso {200 /TimesI-ISOL1 FS nuo show TS} bind def /bLso {200 /TimesB-ISOL1 FS nuo show TS} bind def /jLso {200 /TimesBI-ISOL1 FS nuo show TS} bind def %s=* /iLnuo {160 /Times-ISOL1 FS 0 -50 rmoveto nuo 0 50 rmoveto TS} bind def /ibLnuo {160 /TimesB-ISOL1 FS 0 -50 rmoveto nuo 0 50 rmoveto TS} bind def /iLsnuo {160 /Times-ISOL1 FS -30 -50 rmoveto nuo 0 50 rmoveto TS} bind def /ibLsnuo {160 /TimesB-ISOL1 FS -30 -50 rmoveto nuo 0 50 rmoveto TS} bind def /iLsnco {160 /Times-ISOL1 FS -30 -50 rmoveto nco 0 50 rmoveto TS} bind def /ibLsnco {160 /TimesB-ISOL1 FS -30 -50 rmoveto nco 0 50 rmoveto TS} bind def %for Yn or Yu -> sub/(n) ibLnu/(u) ibLnu/w for ityp>=3 /ibLnu {160 /TimesB-ISOL1 FS -30 -50 rmoveto show 0 50 rmoveto TS} bind def /cvishow {cvi 10 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 /cvsshow4 {10000 mul cvi 0.0001 mul 7 string cvs show} def /cvsshow1x {/nxx exch def %example nxx=99.1/99.0 nxx 10 mul cvi /nxi exch def %nxi=991/990 nxi 10 idiv /nxa exch def %nxa=99 nxi nxa 10 mul sub /nxb exch def %nxb=1/0 nxa cvishow (,) show %nxa=99 nxb cvishow %nxb=1/0 } def /cvsshow2x {/nxx exch def %example nxx=99.12/99,02/99,00 nxx 100 mul cvi /nxi exch def %nxi=9912/9902/00 nxi 100 idiv /nxa exch def %nxa=99 nxi nxa 100 mul sub /nxb exch def %nxb=12/02/00 nxa cvishow (,) show %nxb=99, nxb 10 ge {nxb cvishow} if %nxb=12 nxb 1 ge nxb 9 le and {(0) show nxb cvishow} if %nxb=02 nxb 0 eq {(00) show} if %nxb=00 } def /cvsshow3x {/nxx exch def %example nxx=99.123/99.012/99.001/99.000 nxx 1000 mul cvi /nxi exch def %nxi=99123/99012/99001/99000 nxi 1000 idiv /nxa exch def %nxa=99 nxi nxa 1000 mul sub /nxb exch def %nxb=123/012/001/000 nxa cvishow (,) show %nxb=99, nxb 100 ge {nxb cvishow} if %nxb=123/012/001/000 nxb 10 ge nxb 99 le and {(0) show nxb cvishow} if %nxb=012 nxb 1 ge nxb 9 le and {(00) show nxb cvishow} if %nxb=001 nxb 0 eq {(000) show} if %nxb=000 } def /cvsshow2s {/nxx exch def %example nxx=99.12/99,02 nxx 0 le {(-) show} if nxx 100 mul cvi /nxi exch abs def %nxi=9912/9902/00 nxi 100 idiv /nxa exch def %nxa=99 nxi nxa 100 mul sub /nxb exch def %nxb=12/02/00 nxa cvishow (,) show %nxb=99, nxb 10 ge {nxb cvishow} if %nxb=12 nxb 1 ge nxb 9 le and {(0) show nxb cvishow} if %nxb=02 nxb 0 eq {(00) show} if %nxb=00 } def /cvsshow3s {/nxx exch def %example nxx=-0,123 nxx 0 lt {(-0,) show} {(0,) show} ifelse /nxi nxx 1000 mul cvi abs def %nxi=123 nxi 100 ge {nxi cvishow} if %nxb=123/012/001/000 nxi 10 ge nxi 99 le and {(0) show nxi cvishow} if %nxb=012/001/000 nxi 1 ge nxi 9 le and {(00) show nxi cvishow} if %nxb=001/000 nxi 0 eq {(000) show} if %nxb=000 } def /cvsshow4s {/nxx exch def %example nxx=-0,1234 nxx 0 lt {(-0,) show} {(0,) show} ifelse /nxi nxx 10000 mul cvi abs def %nxi=1234 nxi 1000 ge {nxi cvishow} if %nxb=123/012/001/000 nxi 100 ge nxi 999 le and {(0) show nxi cvishow} if %nxb=123/012/001/000 nxi 10 ge nxi 99 le and {(00) show nxi cvishow} if %nxb=012 nxi 1 ge nxi 9 le and {(000) show nxi cvishow} if %nxb=001 nxi 0 eq {(0000) show} if %nxb=000 } def /tdw {1 1 1 setrgbcolor} bind def /tdr {1 0 0 setrgbcolor} bind def /tdy {1 1 0 setrgbcolor} bind def /tdg {0 1 0 setrgbcolor} bind def /tdc {0 1 1 setrgbcolor} bind def /tdb {0 0 1 setrgbcolor} bind def /tdm {1 0 1 setrgbcolor} bind def /tdn {0 0 0 setrgbcolor} bind def /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 %*************************************************************** /Yi 404 array def %101(W)+3*101(R,G,B) /dYi 404 array def /L*i 404 array def /L*iW 404 array def %needed? /L*iR 404 array def /L*iG 404 array def /L*iB 404 array def /T*i 404 array def /T*iW 404 array def %needed? /T*iR 404 array def /T*iG 404 array def /T*iB 404 array def /Yn 100 def /Yu 018 def /YnW 100 def /iu 18 def /YnWL 100 def %L=Linear /YnRL 21 def /YnGL 72 def /YnBL 07 def /YnW 100 def %L=Linear /YnR 21 def /YnG 72 def /YnB 07 def %allways %Cn=CIELAB /Ynx 100 def /Cn 116 def /Cd 016 def /c30 3.0 def /c30k 1 c30 div def /1Mc30k 1 c30k sub def %=1Mc30k=1-1/3.0 /c30t (3,0) def /c30kt (1/3,0) def /1Mc30kt (1-(1/3,0)) def /L*WCn YnW YnW div c30k exp Cn mul Cd sub def %7=3:FWRGB=0,18 ityp 2 le {/fWRGB 1.00 def} if ityp 3 ge {/fWRGB 0.18 def} if iLABx 4 le {%iLABx<=4 /Yxf YnW fWRGB mul def /YnWRGB YnW def }%iLABx<=4 {%iLABx>=5 k 0 eq {/Yxf YnW fWRGB mul def /YnWRGB YnW def} if k 1 eq {/Yxf YnG fWRGB mul def /YnWRGB YnG def} if k 2 eq {/Yxf YnR fWRGB mul def /YnWRGB YnR def} if k 3 eq {/Yxf YnB fWRGB mul def /YnWRGB YnB def} if } ifelse %iLABx<=4 or >5 } bind def %END proz_YnWRGB %*************************************************** /proz_Yi_Yxf_T*i_dYi_LABJND {%BEG proz_Yi_Yxf_T*i_dYi_LABJND proz_YnWRGB %***************************************************** %f1(x)=f(x)/f(x=1) % =[1/ln(1+b)]*ln(x+b) %x=Y/Yu, dx/dY=1/Yu %df1/dx=[1/ln(1+b)]/[x+b] %df1/dx*dx/dY=(1/Yu)*[1/ln(1+b)]/[x+b] %df1/dY=(1/Yu)*[1/ln(1+b)]/[x+b] % =[1/{Yu*ln(1+b)}]/[x+b] % =[1/{Yu*ln(1+b)*(x+b)}] %for df1=1: %1/dY=[1/{Yu*ln(1+b)*(x+b)}] %dY=Yu*ln(1+b)*(x+b) % =Yu*ln(1+b)*x+Yu*ln(1+b)*b % =ln(1+b)*Y +Yu*ln(1+b)*b %compare %dY =s+d*Y with s=0,017, d=0,0058, Yu=18 %dYu=s+d*Yu %for ratio: %dY/dYu=(s+d*Y)/(s+d*Yu) % =[s/(s+d*Yu)] + [d/(s+d*Yu)]*Y %comparison: %s/(s+d*Yu)=Yu*ln(1+b)*b %d/(s+d*Yu)=ln(1+b) %->s/d=Yu*b %b=s/(d*Yu) % =0,017/(0,0058*18) % =0,017/0,1044 % =0,1628 %for b=0,1628: %-> d=ln(1,16)=, cx*a=0,0058, a=0,0058/cx %for cx=1,000 -> a=0,0058 =172,41 %for cx=0,86 -> a=0,0058/0,86 =200,48 %for cx=0,66 -> a=0,0058/0,66 =261,23 %for cx=0,44 -> a=0,0058/0,44 =400,95 /a 0.0058 def %allways cx*a=0,0058 %b=s/[(cx*a)*Yu] % =0,017/[0,0058*Yu] % =0,017/[0,1044]=0,1628 %f(x)=(cx*a)*ln(x+b) %for cx=1: %f(x)=172,41*ln(x+b) %f(1)=172,41*ln(1) %f(1)=172,41*0.0=0 %f(5)=172,41*ln(5+b) %f(5)=172,41*1,609=277,89 %f(0,2)=172,41*ln(0,2+b) %f(0,2)=172,41*(-1,609)=-277,89 %for cx=0,6666 %f(5)=258,65*ln(5+b) %f(5)=258,65*1,609=416,17 %f(0,2)=258,65*ln(0,2+b) %f(0,2)=258,65*(-1,609)=-416,17 /Sdx 0 def /bx 0.1628 def /Snx 1 1 bx add ln div def %f1(x)=f(x)/f(x=1) % =[1/ln(1+b)]*ln(x+b) % =Snx*ln(Y/Yu + bx) %dY=Yu*ln(1+b)*(x+b) % =Yu*ln(1+b)*x+Yu*ln(1+b)*b % =ln(1+b)*Y +Yu*ln(1+b)*b %dY =s+c*Y with s=0,017 and c=0,0058 % =[sv+cv*Y] %dY1=s+c*Yu*x with x=Y/Yu %dYu=s+c*Yu for Y=Yu or x=1 % =[sv+cv*Yu] %/fakj 2.3026 def %ln(10)=2,3026 %/fakj 1 def %/A0 1 def %for ln=2.3036*log %/A0D65 0.6667 def %1/1,5 or 1 %/A0n A0 A0D65 mul def %/sv 0.017 fakj mul def %/cv 0.0058 fakj mul def %/cvYu cv Yu mul def %0,1044 %/scPcvYu sv cvYu add def %0,1214 %dY =s+c*Y with s=0,017 and c=0,0058 % =[sv+cv*Y] %Integralformel: %F(x)=Integral[f'(x)/f(x)] % %F(Y)=Integral{[1/cv]*(cv)/[sv+cv*Y]} % =A0n*[1/cv]*Integral{cv/[sv+cv*Y]} % =A0n*[1/cv]*ln[sv+cv*Y] % =A0n*[1/cv]*ln[sv+cv*Yu*(Y/Yu)] % =A0n*[1/cv]*ln[fYi1] %F(x)=A0n*[1/cv]*ln[fYi1] % /fYi1 Yi ik get Yxf div Yu mul cv mul sv add def % T*i ik fYi1 ln cv div A0n mul put %=A0n*ln[A1+A2*cx*Yu(Y/Yu)]/(A2*cx) %F(x)=A0n*ln[cvYu*(Y/Yu)+sv]/cv % =A0n*ln[A1+A2*Y]/A2 % =A0n*ln[A1+A2*Yu*(Y/Yu)]/A2 %dY1=sv+cv*Yu*x with x=Y/Yu %dY1=sv+cvYu*x %F(x)=A0n*ln[A1+A2*Y]/A2 % =A0n*ln[A1+A2*Yu*(Y/Yu)]/A2 %dY1=A0n*[A1+A2*Y] %dY1=A0n*[A1+A2*Yu*(Y/Yu)] % =A0n*[A1+A21*(Y/Yu)] %A2=cv, A21=A2*Yu=cvYu %A1=sv %A2K=1/A2 %cx=1,00 1,00 0,84, 0,67, 0,42 %/A1 sv def %A1 %/A2 cv def %A2 %/A2k 1 A2 div def %A2k %/A1n sv cx mul def %A1n %/A2n cv def %A2n %/A2nk 1 A2n div def %A2nk %[A1n+A2n*Y]/A2n=[A1+A2*Y]/A2 or delta y-threshold independent! %F(x)=[1/cv]*ln[fYi1] % /fYi1 Yi ik get Yxf div Yu mul cv mul sv add def % T*i ik fYi1 ln cv div put %=A0n*ln[A1n+A2n*Yu(Y/Yu)]/A2n % /fYi1 Yi ik get Yxf div Yu mul A2n mul A1n add def % i 1 eq {/T*1 fYi1 ln A2n div A0n mul def} if % i 1 eq {/T*1 fYi1 ln A2n A0n mul div def} if %% T*i ik fYi1 ln A2n A0n mul div put % T*i ik Yi ik get ln A2n A0n mul div put % T*1 sub 0.001 add put %=ln[A1n+A2n*Y]/(A2n*A0n) % 0.001 add put %=ln[A1n+A2n*Yu(Y/Yu)]/(A2n*A0n) %dT*i/dYi=1/(A1n+A2n*Y)*A2n*[1/(A2n*A0n)] % =1/(A1n+A2n*Y)*(1/A0n)=1/[A0n*(A1n+A2n*Y)] %dYi=A0n*(A1n+A2n*Y), compare CIE 230:219 with A0nD65=1,5 % dYi ik Yi ik get Yxf div % A2n mul Yu mul A1n add A0n mul put %=A2n*Y+A1n=A21n*x+A1n %defined on start %cx=1,00-LOG, 1,00-LIN, 0,84, 0,67, 0.42, % 1,00-LOG, 1,00-LIN, 0,84, 0,67, 0.42, /sv 0.0170 def /cv 0.0058 def /A0n 1.5 def /A1n sv cx mul def %/A1n 0.0170 (1.00, 1.00, 0.84, 0.67, 0.42) mul def /A2n cv def %/A2n 0.0058 (1.00, 1.00, 0.84, 0.67, 0.42) mul def %0=2 /Y003DYu Y003DYu log def /Y090DYu Y090DYu log def } if %xchartl>=2 0 Y003DYu ytrl add MULY mul moveto %1 add because y-cero point=+1000 0 Y090DYu ytrl add MULY mul lineto stroke tdg [100] 0 setdash 0 Y003DYu ytrl add MULY mul moveto 0 Y090DYu ytrl add MULY mul lineto stroke [ ] 0 setdash tdw } bind def %END proz_Y003_Y090 %************************************************** %%EndProlog gsave /lanind 1 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 3 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 % gsave %XCHA01.PS END /xbtex1 1 def %for more data output within any figure 72 90 translate 0.01 MM dup scale /MULY 1000 def /xbild 0 def %xbild=0 to x for series C(E/G)(1B,2C,3D,4E,5F,6G,7H)(0..7) /xbid 9 def %d=9 array difference=values per line %xbild 0 eq {%xbild=0 /xbildi 72 array def /xbild00i 72 array def /xbild00i [%series C(G/E)B0..9 %0 1 2 3 4 5 6 7 8 %n xytr xyte xyta xyma iy1 iy2 xtyl xtyr 0 -1000 0900 2750 0750 4 7 0 0 1 1000 2150 2750 0750 2 5 0 0 2 2000 2000 2750 0750 1 4 0 0 3 1000 2150 2750 0750 2 5 0 0 4 3000 2150 2750 1200 0 3 0 0 5 1000 2150 2750 0750 2 5 0 0 6 -1000 2150 2750 0750 4 7 0 0 7 1000 2150 2750 0750 2 5 0 0 ] def /xbild10i 18 array def /xbild10i [%series C(G/E)B0..9 %0 1 2 3 4 5 6 % xytr xyte xyta xyma iy1 iy2 xtyl xtyr 0 0000 0900 2750 0750 3 6 3 3 1 0000 2150 2750 0850 3 6 2 2 ] def %default 0 1 71 {/i exch def %i=0,71 xbildi i xbild00i i get put } for %i=0,71 iLABx 1 eq iLABx 6 eq or {%iLABx=1 or 6 0 1 17 {/i exch def %i=0,17 xbildi i xbild10i i get put } for %i=0,17 } if %iLABx=1 or 6 %} if %xbild=0 /xbtex0 1 def %xbtex=0 for files Y1(0/1)-(1..8)A.EPS xbtex0 1 eq {%xbtex0=1 40 setlinewidth /ymax1 17100 def /xmax1 11200 def 1 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 0 setgray 150 /Times-ISOL1 FS 050 -140 moveto (CEG01-7N) show %xchart 1 add cvishow0 } if %xbtex0=1 /xchartl xchart def 0 1 7 {/xchartl exch def %xchartl=0,15 gsave xchartl 0 eq { 100 13000 translate} if xchartl 1 eq { 5700 13000 translate} if xchartl 2 eq { 100 08750 translate} if xchartl 3 eq { 5700 08750 translate} if xchartl 4 eq { 100 4500 translate} if xchartl 5 eq { 5700 4500 translate} if xchartl 6 eq { 100 0250 translate} if xchartl 7 eq { 5700 0250 translate} if 150 /Times-ISOL1 FS 0 setgray 050 -140 moveto xchartl 7 le {(CEG01-) show} {(CEG01-) show} ifelse xchartl 0 ge xchartl 7 le and {xchartl 1 add cvishow} if xchartl 8 ge xchartl 15 le and {xchartl 7 sub cvishow} if (A) show %A /xwidth 5400 def /ywidth 4000 def 0.5 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath fill 0 setlinewidth 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath clip 40 setlinewidth 0.0 setgray 0 0 moveto xwidth 0 rlineto 0 ywidth rlineto xwidth neg 0 rlineto closepath stroke tdw /xtr0 400 def /ytr0 280 def xtr0 ytr0 translate 50 setlinewidth 0 0 moveto 4500 0 rlineto stroke 0 0 moveto 0 3000 rlineto stroke 40 setlinewidth /cvishow {cvi 10 string cvs show} def /cvsshow1 {10 mul cvi 0.1 mul 10 string cvs show} def /cvsshow2 {100 mul cvi 0.01 mul 10 string cvs show} def /cvsshow3 {1000 mul cvi 0.001 mul 10 string cvs show} def %********************************************************************* 40 setlinewidth tdn 0 0 moveto 4000 500 add 0 rlineto stroke 0 0 moveto 0 3000 250 add rlineto stroke 4000 550 add 0 moveto -100 50 rlineto 0 -100 rlineto closepath fill 0 3000 300 add moveto -50 -100 rlineto 100 0 rlineto closepath fill /MULX 1000 def TBL /tx [(-2) (-1) ( 0) ( 1) ( 2)] def /txl [( ) (0,1) ( 1) ( 10) (100)] def %!x-Achse: 100 Einheiten = 0600 Skalen-Einheiten 0 1 4 {/i exch def /ixt {-150 i 1000 mul add} def /ixl { 000 i 1000 mul add} def ixt -250 moveto tx i get exec show i 1 ge {ixt 100 moveto txl i get exec show} if ixl 60 moveto 0 -120 rlineto stroke } for tdw 3300 100 moveto TBIL (Y) show (u) ibLn TBL (=) show Yu cvishow tdn /ixtt 4 1000 mul def /iytt -200 def ixtt 200 add iytt moveto TBL (log\050) show TBIL (Y) show TBL (\051) show /iytt 050 def ixtt 200 add iytt moveto TBIL (Y) show tdw 2600 0 moveto 1300 0 rlineto stroke tdg [100] 0 setdash 2600 0 moveto 1300 0 rlineto stroke [ ] 0 setdash tdw 2600 50 moveto 0 -100 rlineto stroke 3900 50 moveto 0 -100 rlineto stroke 2300 -200 moveto TBIL (Y) show (N) ibLs TBL (=3,6) show 3350 -200 moveto TBIL (Y) show (W) ibLs TBL (=90) show tdn %!y-Achse: 100 S-Einheiten = 1000 Skalen-Einheiten %yshift -1000 0 1000 2000 3000 4000 5000 /xtyl 8 array def /xtyr 8 array def /0tyl [( -3)( -2)( -1) ( 0) ( 1) ( 2) ( 3) ( 4)] def /0tyr [(0,001)(0,01)(0,1) (1) (10) (100) (1000) (10000)] def /1tyl [( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ] def /1tyr [(-200)(-100)(-50) ( 0) ( 50) ( 100) ( 150) ( 200)] def /2tyl [( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ] def /2tyr [(-3) (-2) (-1) ( 0) ( 1) ( 2) ( 3) ( 4) ] def %special for wide range /3tyl [( ) ( ) ( ) ( ) ( ) ( ) ( ) ( ) ] def /3tyr [(-800)(-400)(-200)( 0) ( 200) ( 400) ( 600) ( 400)] def %default 0 1 7 {/j exch def %j=0,7 xtyl j 0tyl j get put xtyr j 0tyr j get put } for %j=0,7 /j1y xbildi xchartl xbid mul 5 add get def /j2y xbildi xchartl xbid mul 6 add get def /j3y xbildi xchartl xbid mul 7 add get def /j4y xbildi xchartl xbid mul 8 add get def j1y 1 j2y {/j exch def xtyl j j1y sub j3y 0 eq {0tyl j get put} if j3y 1 eq {1tyl j get put} if j3y 2 eq {2tyl j get put} if j3y 3 eq {3tyl j get put} if } for j1y 1 j2y {/j exch def xtyr j j1y sub j4y 0 eq {0tyr j get put} if j4y 1 eq {1tyr j get put} if j4y 2 eq {2tyr j get put} if j4y 3 eq {3tyr j get put} if } for %special new linear scale (times 4) for thresholds %for xchartl=0 and iLABx=1 and =6 xchartl 0 eq iLABx 1 eq iLABx 6 eq or and {%xchartl=0, iLABx=1 or 8 j1y 1 j2y {/j exch def xtyr j j1y sub j4y 3 eq {3tyr j get put} if } for } if %xchartl=0, iLABx=1 or 8 0 1 3 {/j exch def /jyt {-50 j 1000 mul add} def /jyl {000 j 1000 mul add} def -370 jyt moveto xtyl j get show j 1 ge {050 jyt moveto xtyr j get show} if -60 jyl moveto 120 0 rlineto stroke } for %******************************************************** %BEG S01_S08 ******************************************** tdw /ytit 3520 def 050 xtr0 sub ytit moveto %allways output term xchartl 00 eq {%xchartl=00 TBL iLABx 0 eq iLABx 5 eq or {(log \050) show TBIL itT*t show TBL (\051) show} {TBIL itT*t show} ifelse TBL 1500 xtr0 sub ytit 000 sub moveto NameSt show iLABx 4 le {( standard lightness ) showen (\255Normhelligkeit ) showde} %iLABx<=4 {( triangle lightness ) showen (\255Dreieckshelligkeit ) showde} ifelse %iLABx>=5 TBIL itT*t show 1500 xtr0 sub ytit 200 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=00 xchartl 01 eq {%xchartl=01 TBL iLABx 0 eq iLABx 5 eq or {(log \050) show TBIL itT*t show (/) show itT*t show (u) ibLs TBL (\051) show} {TBIL itT*t show (/) show itT*t show (u) ibLs} ifelse TBL 1300 xtr0 sub ytit 000 sub moveto NameSt show iLABx 4 le {( relative standard lightness ) showen ( relative Normhelligkeit ) showde} {( relative triangle lightness ) showen ( relative Dreieckshelligkeit ) showde} ifelse TBIL itT*t show (/) show itT*t show ibLsnuo 1300 xtr0 sub ytit 200 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=01 xchartl 02 eq {%xchartl=02 TBL (log\050) show SK (D) show 20 0 rmoveto TBIL (Y) show TBL (\051) show 2000 xtr0 sub ytit 000 sub moveto TBL NameSt show 2000 xtr0 sub ytit 200 sub moveto TBL (tristimulus value difference) showen (Normfarbwertdifferenz) showde 2000 xtr0 sub ytit 400 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=02 xchartl 03 eq {%xchartl=03 TBL (log\050) show SK (D) show 20 0 rmoveto TBIL (Y) show TBL (/) show SK (D) show TBIL (Y) show ibLsnuo TBL (\051 ) show 2000 xtr0 sub ytit 000 sub moveto TBL NameSt show ( relative ) showen ( relative ) showde 2000 xtr0 sub ytit 200 sub moveto TBL (tristimulus value difference) showen (Normfarbwertdifferenz) showde 2000 xtr0 sub ytit 400 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=03 xchartl 04 eq {%xchartl=04 TBL (log \050) show SK (D) show TBIL (Y/Y\051 ) show TBL 2500 xtr0 sub ytit 000 sub moveto TBL NameSt show 2500 xtr0 sub ytit 200 sub moveto TBL (tristimulus value sensitivity) showen (Normfarbwertemfindlichkeit) showde 2500 xtr0 sub ytit 400 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=04 xchartl 05 eq {%xchartl=05 TBL (log [\050) show SK (D) show TBIL (Y/Y) show TBL (\051 / \050) show SK (D) show TBIL (Y) show TBL (/) show TBIL (Y) show TBL (\051) show (u) ibLs TBL (] ) show 2500 xtr0 sub ytit 000 sub moveto TBL NameSt show ( relative ) showen ( relative ) showde 2500 xtr0 sub ytit 200 sub moveto TBL (tistimulus value sensitivity) showen (Normfarbwertempfindlichkeit) showde 2500 xtr0 sub ytit 400 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=05 xchartl 06 eq {%xchartl=06 TBL (log \050) show TBIL (Y/) show SK (D) show TBIL (Y) show TBL (\051 ) show 2500 xtr0 sub ytit 000 sub moveto TBL NameSt show 2500 xtr0 sub ytit 200 sub moveto TBL (tristimulus value contrast) showen (Normfarbwertkontrast) showde 2500 xtr0 sub ytit 400 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=06 xchartl 07 eq {%xchartl=07 TBL (log [\050) show TBIL (Y/) show SK (D) show TBIL (Y) show (\051 / \050) show TBIL (Y) show TBL (/) show SK (D) show TBIL (Y) show TBL (\051) show ibLnuo TBL (]) show 2500 xtr0 sub ytit 000 sub moveto TBL NameSt show ( relative) showen ( relativer) showde 2500 xtr0 sub ytit 200 sub moveto TBL (tistimulus value contrast) showen (Normfarbwertkontrast) showde 2500 xtr0 sub ytit 400 sub moveto TBIL (Y) show ibLsnco TBL (=) show TBIL iYL* 0 eq {(Y) show}{(L*) show} ifelse WRGBnibLs WRGBdaten } if %xchartl=07 tdw %********************************************************************* /proz_T* {%BEG proz_T* TBIL itT*t show NameSt ibLs TBL (=[ln) show TBL ([\050A) show (1n) ibLs TBL (+A) show (2n) ibLs TBIL (Y) show TBL (\051]/\050) show TBL (A) show (2n) ibLs TBL (A) show (0n) ibLs TBL (\051]) show 40 0 rmoveto TBL (\050) show %TBIL (Y) show %ityp 2 le {(n) ibLs}{(u) ibLs} ifelse %TBL (=) show %ityp 2 le {100 cvishow}{18 cvishow} ifelse %(, ) show TBIL (Y) show ibLsnco TBL (/100<) show TBIL (Y) show TBL (<=) show TBIL (Y) show ibLsnco TBL (\051) show } bind def %END proz_T* %********************************************************************* /S01_ALOG_T* {%BEG S01_ALOG_T* /MULY 1000 def /xtr 2000 def %/ytr -1000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point %STOPA /k 0 def 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res T*i ik get def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res T*i ik get def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S01 /x0 0300 def /x0 x0 200 add def %special 200 add for Y1(0/1)-(1,3,5,7) /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL itT*t show (90) iLs TL (=) show T*i 90 get cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL itT*t show (18) iLs TL (=) show T*i 18 get cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL itT*t show (3,6) iLs TL (=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add cvsshow2s proz_constout21 } if %xbtex1=1 x1 T*i iu get log ytrl add MULY mul 100 add moveto TBL (log[) show TBIL itT*t show TBL (/) show TBIL itT*t show (u) ibLs TBL (]) show TBL (=0) show /FY20 T*i 20 get def /FYiu T*i iu get def TBIL (, m) show (u) ibLs TBL (=) show FY20 log FYiu log sub Yi 20 get log Yi iu get log sub div cvsshow2s x1 T*i iu get log ytrl add MULY mul 250 sub moveto TBIL (L*) show (u) ibLs TBL (=) show L*u 0.5 add cvishow TBL (, ) show TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow xtr ytr translate %new cero point } if %k=0 } for %k=0,3 /i1 18 def [100] 0 setdash -2. MULX mul T*i i1 get log MULY mul moveto i1 log MULX mul T*i i1 get log MULY mul lineto i1 log MULX mul -1. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 050 def /xyta xbildi xchartl xbid mul 3 add get def /x1 800 def /y1 2700 def %3000? /xdel 800 def /ydel 270 def %300? x0 xyta moveto proz_T* x0 xyta 0.9 ydel mul sub moveto TBIL itT*t show (N) ibLs TBL ((3,6)=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add 0.5 add cvishow (, ) show TBIL itT*t show (u) ibLs TBL ((18)=) show T*i 18 get 0.5 add cvishow (, ) show TBIL itT*t show (W) ibLs TBL ((90)=) show T*i 90 get 0.5 add cvishow tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S01_ALOG_T* %********************************************************************* /S01_ALIN_T* {%BEG S01_ALIN_T* %/MULY 20 def %Special instead 1000 /MULY 5 def %very special for thresholds instead 1000 /xtr 2000 def %/ytr 0000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul T*i ik get MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul T*i ik get MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S01 /x0 0300 def /x0 x0 200 add def %special 200 add for Y1(0/1)-(1,3,5,7) /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL itT*t show (90) iLs TL (=) show T*i 90 get cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL itT*t show (18) iLs TL (=) show T*i 18 get cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL itT*t show (3,6) iLs TL (=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add cvsshow2s proz_constout21 } if %xbtex1=1 x1 T*i iu get ytrl add MULY mul 100 add moveto TBIL itT*t show (u) ibLs TBL (=) show T*i iu get cvsshow2s TBIL (, m) show (u) ibLs TBL (=) show T*i iu 1 add get T*i iu 1 sub get sub Yi iu 1 add get log Yi iu 1 sub get log sub div cvsshow2s x1 T*i iu get ytrl add MULY mul 250 sub moveto TBIL (L*) show (u) ibLs TBL (=) show L*u 0.5 add cvishow TBL (, ) show TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow xtr ytr translate %new cero point } if %k=0 } for %k=0,3 tdw [100] 0 setdash -2. MULX mul T*u MULY mul moveto iu log MULX mul T*u MULY mul lineto iu log MULX mul 0. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /x1 800 def /y1 2700 def /xdel 800 def /ydel 300 def x0 xyta moveto proz_T* x0 xyta 0.9 ydel mul sub moveto TBIL itT*t show (N) ibLs TBL ((3,6)=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add 0.5 add cvishow (, ) show TBIL itT*t show (u) ibLs TBL ((18)=) show T*i 18 get 0.5 add cvishow (, ) show TBIL itT*t show (W) ibLs TBL ((90)=) show T*i 90 get 0.5 add cvishow tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde /MULY 1000 def %standard 1000 } def %END S01_ALIN_T* %********************************************************************* /S02_ALOG_T*n {%BEG S02_ALOG_T*n /MULY 1000 def /xtr 2000 def %/ytr 1000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res T*i ik get T*u div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res T*i ik get T*u div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S02 /x0 0300 def /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL itT*t show (90) iLs TL (/) show TIL itT*t show (u) iLs TL (=) show T*i 90 get T*u div cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL itT*t show (18) iLs TL (/) show TIL itT*t show (u) iLs TL (=) show T*i 18 get T*u div cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL itT*t show (3,6) iLs TL (/) show TIL itT*t show (u) iLs TL (=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add T*u div cvsshow2s proz_constout21 } if %xbtex1=1 x1 ytr 100 add moveto TBL (log[) show TBIL itT*t show TBL (/) show TBIL itT*t show (u) ibLs TBL (]) show TBL (=0) show /FY20 T*i 20 get T*i iu get div def /FYiu 1 def TBIL (, m) show (u) ibLs TBL (=) show FY20 log FYiu log sub Yi 20 get log Yi iu get log sub div cvsshow2s x1 ytr 250 sub moveto TBIL (L*) show (u) ibLs TBL (=) show L*u 0.5 add cvishow TBL (, ) show TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow xtr ytr translate %new cero point } if %k=0 } for %k=0,0 /i1 18 def [100] 0 setdash -2. MULX mul 1. log MULY mul moveto i1 log MULX mul 1. log MULY mul lineto i1 log MULX mul -1. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /x1 800 def /y1 2700 def %3000? /xdel 800 def /ydel 270 def %300? %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* x0 xyta 0.9 ydel mul sub moveto TBIL itT*t show (N) ibLs TBL ((3,6)=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add 0.5 add cvishow (, ) show TBIL itT*t show (u) ibLs TBL ((18)=) show T*i 18 get 0.5 add cvishow (, ) show TBIL itT*t show (W) ibLs TBL ((90)=) show T*i 90 get 0.5 add cvishow tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S02_ALOG_T*n %********************************************************************* /S02_ALIN_T*n {%BEG S02_ALIN_T*n /MULY 1000 def /xtr 2000 def %/ytr 0000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul T*i ik get T*u div MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul T*i ik get T*u div MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S02 /x0 0300 def /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL itT*t show (90) iLs TL (/) show TIL itT*t show (u) iLs TL (=) show T*i 90 get T*u div cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL itT*t show (18) iLs TL (/) show TIL itT*t show (u) iLs TL (=) show T*i 18 get T*u div cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL itT*t show (3,6) iLs TL (/) show itT*t show (u) iLs TL (=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add T*u div cvsshow2s proz_constout21 } if %xbtex1=1 % x1 ytr 100 add moveto x1 ytr 1000 add 100 add moveto %special shift TBIL itT*t show TBL (/) show TBIL itT*t show (u) ibLs TBL (=1) show TBIL (, m) show (u) ibLs TBL (=) show T*i iu 1 add get T*i iu get div T*i iu 1 sub get T*i iu get div sub Yi iu 1 add get log Yi iu 1 sub get log sub div cvsshow2s % x1 ytr 250 sub moveto x1 ytr 1000 add 250 sub moveto %special shift TBIL (L*) show (u) ibLs TBL (=) show L*u 0.5 add cvishow TBL (, ) show TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow xtr ytr translate %new cero point } if %k=0 } for %k=0,3 tdw /i1 18 def [100] 0 setdash -2. MULX mul 1. MULY mul moveto i1 log MULX mul 1. MULY mul lineto i1 log MULX mul 0. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /x1 800 def /y1 2700 def /xdel 800 def /ydel 300 def %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* x0 xyta 0.9 ydel mul sub moveto TBIL itT*t show (N) ibLs TBL ((3,6)=) show T*i 3 get 0.4 mul T*i 4 get 0.6 mul add 0.5 add cvishow (, ) show TBIL itT*t show (u) ibLs TBL ((18)=) show T*i 18 get 0.5 add cvishow (, ) show TBIL itT*t show (W) ibLs TBL ((90)=) show T*i 90 get 0.5 add cvishow tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde /MULY 1000 def %standard 1000 } def %END S02_ALIN_T*n %********************************************************************* /S03_ALOG_DL {%BEG S03_ALOG_DL /xtr 2000 def %ytr 1000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw /x0 0300 def /x0 x0 200 add def %special 200 add for Y1(0/1)-(1,3,5,7) /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL (dY) show (90) iLs TL (=) show dYi 90 get cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL (dY) show (18) iLs TL (=) show dYi 18 get cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL (dY) show (3,6) iLs TL (=) show dYi 3 get 0.4 mul dYi 4 get 0.6 mul add cvsshow2s proz_constout22 } if %xbtex1=1 x1 dYi iu get log ytrl add MULY mul 250 sub moveto TBL (log) show TBIL ((dY)) show TBL (=) show dYi iu get cvsshow2s /FYiu1a dYi iu 1 add get def /FYiu1s dYi iu 1 sub get def TBIL (, m) show (u) ibLs TBL (=) show FYiu1a log FYiu1s log sub Yi iu 1 add get log Yi iu 1 sub get log sub div cvsshow2s x1 dYi iu get log ytrl add MULY mul 100 add moveto TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow TBIL (, dY) show (u) ibLs TBL (=) show dYu cvsshow2s TBIL (, dY) show (u) ibLs TBIL (/Y) show (u) ibLs TBL (=) show dYu Yu div cvsshow4s xtr ytr translate %new cero point } if %k=0 } for %k=0,0 tdw [100] 0 setdash -2. MULX mul dYi iu get log MULY mul moveto iu log MULX mul dYi iu get log MULY mul lineto iu log MULX mul -2. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /ydel 300 def tdw %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* x0 xyta ydel 0.9 mul sub moveto TBIL (dY) show TBL (=A) show (0n) ibLs TBL (\050A) show (1n) ibLs TBL (+A) show (2n) ibLs TBIL (Y) show TBL (\051) show TBL ( A) show (1n) ibLs TBL (=0,017, ) show TBL (A) show (2n) ibLs TBL (=0,0058) show x0 xyta ydel 1.8 mul sub moveto TBL (A) show (0n,D65) ibLs TBL (=1,5, ) show TBL (A) show (0n,A) ibLs TBL (=1,0, ) show TBL (see ) showen (siehe ) showde TBL (CIE 230:2019) show tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S03_ALOG_DL %********************************************************************* /S04_ALOG_DLn {%BEG S04_ALOG_DLn /xtr 2000 def %/ytr 1000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point %L*=116*(Y/100)**(1/3)-16. %delta_L*/delta_Y=116*(1/3)*(Y/100)**(-2/3)*(1/100) %delta_Y=1/[116*(1/3)*(Y/100)**(-2/3)*(1/100)]=3*100/116*(Y/100)**(2/3) %delta_Y=3*100/116*(Y/Yn)**(2/3) 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get dYu div def % Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get dYu div def % Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S04 /x0 0300 def /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL (dY) show (90) iLs TIL (/dY) show (u) iLs TL (=) show dYi 90 get dYu div cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL (dY) show (18) iLs TIL (/dY) show (u) iLs TL (=) show dYi 18 get dYu div cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL (dY) show (3,6) iLs TIL (/dY) show (u) iLs TL (=) show dYi 3 get 0.4 mul dYi 4 get 0.6 mul add dYu div cvsshow2s proz_constout22 } if %xbtex1=1 x1 ytr 250 sub moveto TBL (log[) show TBIL ((dY)) show TBL (/\050) show TBIL (dY) show TBL (\051) show (u) ibLs TBL (]) show TBL (=0) show /FY20 dYi 20 get dYi iu get div def /FYiu 1 def TBIL (, m) show (u) ibLs TBL (=) show FY20 log FYiu log sub Yi 20 get log Yi iu get log sub div cvsshow2s x1 ytr 100 add moveto TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow TBIL (, dY) show (u) ibLs TBL (=) show dYu cvsshow2s TBIL (, dY) show (u) ibLs TBIL (/Y) show (u) ibLs TBL (=) show dYu Yu div cvsshow4s xtr ytr translate %new cero point } if %k=0 } for %k=0,0 tdw [100] 0 setdash -2. MULX mul 1. log MULY mul moveto iu log MULX mul 1. log MULY mul lineto iu log MULX mul -1. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %new cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /ydel 300 def tdw %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* x0 xyta ydel 0.9 mul sub moveto TBIL (dY) show TBL (/) show TBIL (dY) show (u) ibLs TBL (=A) show (0n) ibLs TBL ([A) show (1n) ibLs TBL (+A) show (2n) ibLs TBIL (Y) show TBL (]/) show TBIL (dY) show (u) ibLs tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S04_ALOG_DLn %********************************************************************* /S05_ALOG_DL_L {%BEG S05_ALOG_DL_L /xtr 2000 def %/ytr 3000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get Yi ik get div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get Yi ik get div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S05 %S05 /x0 0300 def /x0 x0 200 add def %special 200 add for Y1(0/1)-(1,3,5,7) /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL ((dY/Y)) show (90) iLs TL (=) show TL dYi 90 get Yi 90 get div cvsshow4s proz_constout x0 xyte 0200 sub moveto TIL ((dY/Y)) show (18) iLs TL (=) show TL dYi 18 get Yi 18 get div cvsshow4s proz_constout1 x0 xyte 0400 sub moveto TIL ((dY/Y)) show (3,6) iLs TL (=) show dYi 3 get 0.4 mul dYi 4 get 0.6 mul add Yi 3 get 0.4 mul Yi 4 get 0.6 mul add div cvsshow4s proz_constout22 } if %xbtex1=1 x1 dYi iu get Yi iu get div log ytrl add MULY mul 100 add moveto TBL (log) show TBIL ((dY/Y)) show TBL (=) show dYi iu get Yi iu get div log cvsshow2s /FY20 dYi 20 get Yi 20 get div def /FYiu dYi iu get Yi iu get div def TBIL (, m) show (u) ibLs TBL (=) show FY20 log FYiu log sub Yi 20 get log Yi iu get log sub div cvsshow2s x1 dYi iu get Yi iu get div log ytrl add MULY mul 250 sub moveto TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow TBIL (, dY) show (u) ibLs TBL (=) show dYu cvsshow2s TBIL (, dY) show (u) ibLs TBIL (/Y) show (u) ibLs TBL (=) show dYu Yu div cvsshow4s xtr ytr translate %new cero point } if %k=0 } for %k=0,0 tdw /i1 18 def [100] 0 setdash /rYdY dYi i1 get Yi i1 get div def -2. MULX mul rYdY log MULY mul moveto i1 log MULX mul rYdY log MULY mul lineto i1 log MULX mul -3. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /ydel 300 def tdw %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* %Sr=dY/Y x0 xyta 0.9 ydel mul sub moveto TBIL (dY/Y) show TBL (=A) show (0n) ibLs TBL ([A) show (1n) ibLs TBL (+A) show (2n) ibLs TBIL (Y) show TBL (]/) show TBIL (Y) show tdw /x0 3800 def %/y0 1750 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S05_ALOG_DL_L %********************************************************************* /S06_ALOG_DL_Ln {%BEG S06_ALOG_DL_Ln /xtr 2000 def %/ytr 1000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get Yi ik get div dYu Yu div div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res dYi ik get Yi ik get div dYu Yu div div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S06 /x0 0300 def /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL ((dY/Y)) show (90) iLs TIL (/(dY/Y)) show (u) iLs TL (=) show dYi 90 get Yi 90 get div dYu Yu div div cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL ((dY/Y)) show (18) iLs TIL (/(dY/Y)) show (u) iLs TL (=) show dYi 18 get Yi 18 get div dYu Yu div div cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL ((dY/Y)) show (3,6) iLs TIL (/(dY/Y)) show (u) iLs TL (=) show dYi 3 get 0.4 mul dYi 4 get 0.6 mul add Yi 3 get 0.4 mul Yi 4 get 0.6 mul add div dYu Yu div div cvsshow2s proz_constout22 } if %xbtex1=1 x1 ytr 250 sub moveto TBL (log[) show TBIL ((dY/Y)) show TBL (/) show TBIL ((dY/Y)) show (u) ibLs TBL (]) show TBL (=0) show /FY20 dYi 20 get Yi 20 get div dYi iu get Yi iu get div div def /FYiu 1 def TBIL (, m) show (u) ibLs TBL (=) show FY20 log FYiu log sub Yi 20 get log Yi iu get log sub div cvsshow2s x1 ytr 550 sub moveto TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow TBIL (, dY) show (u) ibLs TBL (=) show dYu cvsshow2s TBIL (, dY) show (u) ibLs TBIL (/Y) show (u) ibLs TBL (=) show dYu Yu div cvsshow4s xtr ytr translate %new cero point } if %k=0 } for %k=0,0 tdw /i1 18 def [100] 0 setdash /rYdY Yi i1 get dYi i1 get div Yu dYu div div def -2. MULX mul rYdY log MULY mul moveto iu log MULX mul rYdY log MULY mul lineto iu log MULX mul -1. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /ydel 300 def tdw %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* %Sr= (dY/Y)/(dY/Y)u x0 xyta ydel 0.9 mul sub moveto TBIL ((dY/Y)) show TBL (/) show TBIL (dY/Y) show (u) ibLs TBL (=) show TBL (\050A) show (1n) ibLs TBL (+A) show (2n) ibLs TBIL (Y) show TBL (\051/[) show TBIL (Y) show TBIL ((dY/Y)) show (u) ibLs TBL (]) show tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S06_ALOG_DL_Ln %********************************************************************* /S07_ALOG_L_DL {%BEG S07_ALOG_L_DL /xtr 2000 def %/ytr 1000 def %/ytr -1000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point %L*=116*(Y/Yn)**(1/3)-16. %delta_L*/delta_Y=116*(1/3)*(Y/Yn)**(-2/3)*(1/Yn) %delta_Y=1/[116*(1/3)*(Y/Yn)**(-2/3)*(1/Yn)]=3*Yn/116*(Y/Yn)**(2/3) %delta_Y=3*Yn/116*(Y/Yn)**(2/3) 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res Yi ik get dYi ik get div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res Yi ik get dYi ik get div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S07 /x0 0300 def /x0 x0 200 add def %special 200 add for Y1(0/1)-(1,3,5,7) /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL ((Y/dY)) show (90) iLs TL (=) show Yi 90 get dYi 90 get div cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL ((Y/dY)) show (18) iLs TL (=) show Yi 18 get dYi 18 get div cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL ((Y/dY)) show (3,6) iLs TL (=) show Yi 3 get 0.4 mul Yi 4 get 0.6 mul add dYi 3 get 0.4 mul dYi 4 get 0.6 mul add div cvsshow2s proz_constout22 } if %xbtex1=1 tdw x1 Yi iu get dYi iu get div log ytrl add MULY mul 250 sub moveto TBL (log) show TBIL ((Y/dY)) show TBL (=) show Yi iu get dYi iu get div log cvsshow2s /FY20 Yi 20 get dYi 20 get div def /FYiu Yi iu get dYi iu get div def TBIL (, m) show (u) ibLs TBL (=) show FY20 log FYiu log sub Yi 20 get log Yi iu get log sub div cvsshow2s x1 Yi iu get dYi iu get div log ytrl add MULY mul 100 add moveto TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow TBIL (, dY) show (u) ibLs TBL (=) show dYu cvsshow2s TBIL (, Y) show (u) ibLs TBIL (/dY) show (u) ibLs TBL (=) show Yu dYu div cvishow xtr ytr translate %new cero point } if %k=0 } for %k=0,0 tdw /i1 18 def [100] 0 setdash /rYdY Yi i1 get dYi i1 get div def -2. MULX mul rYdY log MULY mul moveto i1 log MULX mul rYdY log MULY mul lineto i1 log MULX mul -1. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /ydel 300 def tdw %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* %Cr=Y/dY x0 xyta ydel 0.9 mul sub moveto TBIL (Y/dY) show TBL (=) show TBIL (Y) show TBL (/[A) show (0n) ibLs TBL (\050A) show (1n) ibLs TBL (+A) show (2n) ibLs TBIL (Y) show TBL (\051]) show tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S07_ALOG_L_DL %********************************************************************* /S08_ALOG_L_DLn {%BEG S08_ALOG_L_DLn /xtr 2000 def %/ytr 1000 def /ytr xbildi xchartl xbid mul 1 add get def /ytrl ytr 1000 div def %log shift xtr ytr translate %new cero point 0 1 3 {/k exch def %k=0,0:W,R,G,B proz_Yi_T*i_dYi_T*u_dYu /i1 001 def /i2 100 def k 0 eq {%k=0 %50 setlinewidth 0 1 1 {/j exch def %j=0,1 j 0 eq {1 1 1 setrgbcolor} if j 1 eq {0 0 0 setrgbcolor [100] 0 setdash} if i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res Yi ik get dYi ik get div Yu dYu div div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } for %j=0,1 [ ] 0 setdash %40 setlinewidth 1 1 1 setrgbcolor } if %k=0 k 1 ge {%k=1,2,3 i1 1 i2 {/i exch def %i=i1,i2 /ik i k 101 mul add def Yi ik get log MULX mul /Res Yi ik get dYi ik get div Yu dYu div div def Res 0.001 le {/Res 0.001 def} if Res log MULY mul i i1 eq {moveto} if i i1 1 add ge i i2 1 sub le and {lineto} if i i2 eq {stroke} if } for %i=i1,i2 } if %k=1,2,3 tdw %S08 /x0 0300 def /x1 0250 def /xyte xbildi xchartl xbid mul 2 add get def k 0 eq {%k=0 xtr neg ytr neg translate %new cero point xbtex1 1 eq {%xbtex1=1 x0 xyte 0000 sub moveto TIL ((Y/dY)) show (90) iLs TIL (/(Y/dY)) show (u) iLs TL (=) show Yi 90 get dYi 90 get div Yu dYu div div cvsshow2s proz_constout x0 xyte 0200 sub moveto TIL ((Y/dY)) show (18) iLs TIL (/(Y/dY)) show (u) iLs TL (=) show Yi 18 get dYi 18 get div Yu dYu div div cvsshow2s proz_constout1 x0 xyte 0400 sub moveto TIL ((Y/dY)) show (3,6) iLs TIL (/(Y/dY)) show (u) iLs TL (=) show Yi 3 get 0.4 mul Yi 4 get 0.6 mul add dYi 3 get 0.4 mul dYi 4 get 0.6 mul add div Yu dYu div div cvsshow2s proz_constout22 } if %xbtex1=1 x1 ytr 100 add moveto TBL (log[) show TBIL ((Y/dY)) show TBL (/) show TBIL ((Y/dY)) show (u) ibLs TBL (]) show TBL (=0) show /FY20 Yi 20 get dYi 20 get div Yi iu get dYi iu get div div def /FYiu 1 def TBIL (, m) show (u) ibLs TBL (=) show FY20 log FYiu log sub Yi 20 get log Yi iu get log sub div cvsshow2s x1 ytr 250 sub moveto TBIL itT*t show (u) ibLs TBL (=) show T*u 0.5 add cvishow TBIL (, dY) show (u) ibLs TBL (=) show dYu cvsshow2s TBIL (, Y) show (u) ibLs TBIL (/dY) show (u) ibLs TBL (=) show Yu dYu div cvishow xtr ytr translate %new cero point } if %k=0 } for %k=0,0 tdw [100] 0 setdash -2. MULX mul 1. log MULY mul moveto iu log MULX mul 1. log MULY mul lineto iu log MULX mul -1. MULY mul lineto stroke [ ] 0 setdash ioutc 1 eq {cero_line} if xtr neg ytr neg translate %old cero point proz_Y003_Y090 /x0 0100 def /xyta xbildi xchartl xbid mul 3 add get def /ydel 300 def tdw %L*= 50(Y/Yn)**cxkt x0 xyta moveto proz_T* %Cr= (Y/dY)/(Y/dY)u x0 xyta ydel 0.9 mul sub moveto TBIL ((Y/dY)) show TBL (/) show TBIL ((Y/dY)) show (u) ibLs TBL (=) show TBIL (\050Y/(Y/dY)) show (u) ibLs TBL (\051) show TBL (/[A) show (0n) ibLs TBL (\050A) show (1n) ibLs TBL (+A) show (2n) ibLs TBIL (Y) show TBL (\051]) show TBL (/) show TBIL ((Y/dY)) show (u) ibLs tdw /x0 3800 def /xyma xbildi xchartl xbid mul 4 add get def x0 xyma moveto 1000 0 rlineto stroke tdg [100] 0 setdash x0 xyma moveto 1000 0 rlineto stroke [ ] 0 setdash tdw x0 xyma 0.7 ydel mul sub moveto TBL (application) showen TBL (Anwendungs\255) showde x0 xyma 1.3 ydel mul sub moveto TBL (range) showen TBL (bereich) showde } def %END S08_ALOG_L_DL %**************************************************************** xchartl 00 eq {100 3200 moveto TBIL itT*t show } if xchartl 01 eq {100 3200 moveto TBIL itT*t show (/) show itT*t show (u) ibLs } if xchartl 02 eq {100 3200 moveto SL (D) show TBIL (Y) show } if xchartl 03 eq {100 3200 moveto SL (D) show TBIL (Y) show TBL (/) show SL (D) show TBIL (Y) show (u) ibLs } if xchartl 04 eq {100 3200 moveto TBIL (S) show (r) ibLs TBL (=\050) show SL (D) show TBIL (Y/Y) show TBL (\051) show } if xchartl 05 eq {100 3200 moveto TBIL (S) show (r) ibLs TBL (/) show TBIL (S) show (ru) ibLs TBL (=\050) show SL (D) show TBIL (Y/Y) show TBL (\051/\050) show SL (D) show TBIL (Y/Y) show TBL (\051) show (u) ibLs } if xchartl 06 eq {100 3200 moveto TBIL (C) show (r) ibLs TBL (=\050) show TBIL (Y/) show SL (D) show TBIL (Y) show TBL (\051) show } if xchartl 07 eq {100 3200 moveto TBIL (C) show (r) ibLs TBL (/) show TBIL (C) show (ru) ibLs TBL (=\050) show TBIL (Y/) show SL (D) show TBIL (Y) show TBL (\051/\050) show TBIL (Y) show TBL (/) show SL (D) show TBIL (Y) show TBL (\051) show (u) ibLs } if %************************************************************** xchartl 00 eq {iLABx 1 eq iLABx 6 eq or {S01_ALIN_T*} {S01_ALOG_T*} ifelse } if xchartl 01 eq {iLABx 1 eq iLABx 6 eq or {S02_ALIN_T*n} {S02_ALOG_T*n} ifelse } if xchartl 02 eq {S03_ALOG_DL} if xchartl 03 eq {S04_ALOG_DLn} if xchartl 04 eq {S05_ALOG_DL_L} if xchartl 05 eq {S06_ALOG_DL_Ln} if xchartl 06 eq {S07_ALOG_L_DL} if xchartl 07 eq {S08_ALOG_L_DLn} if %END S01_S08********************************************** %******************************************************** xtr0 neg ytr0 neg translate %************************************************************** %special space for 'xm03'PROZ0.COM 2x before/after xchartl xchartl 0 eq { 100 neg 13000 neg translate} if xchartl 1 eq { 5700 neg 13000 neg translate} if xchartl 2 eq { 100 neg 08750 neg translate} if xchartl 3 eq { 5700 neg 08750 neg translate} if xchartl 4 eq { 100 neg 4500 neg translate} if xchartl 5 eq { 5700 neg 4500 neg translate} if xchartl 6 eq { 100 neg 0250 neg translate} if xchartl 7 eq { 5700 neg 0250 neg translate} if grestore } for %xchartl=0,07 showpage grestore %%Trailer