%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
%%                                                                   %%
%% This is file `pst-moire.tex'                                      %%
%%                                                                   %%
%% IMPORTANT NOTICE:                                                 %%
%%                                                                   %%
%% Package `pst-moire'                                               %%
%%                                                                   %%
%% Jürgen Gilg, Manuel Luque, Jean-Michel Sarlat                     %%
%%                                                                   %%
%% Copyright (C) 2018                                                %%
%%                                                                   %%
%% This program can redistributed and/or modified under              %%
%% the terms of the LaTeX Project Public License                     %%
%% Distributed from CTAN archives in directory                       %%
%% macros/latex/base/lppl.txt; either version 1.3c of                %%
%% the License, or (at your option) any later version.               %%
%%                                                                   %%
%% DESCRIPTION:                                                      %%
%%   `pst-moire' is a PSTricks package to draw moire patterns        %%
%%                                                                   %%
%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
\def\fileversion{2.2}%
\def\filedate{2021/09/03}%
\message{`PST-MOIRE v\fileversion, \filedate\space (ML)}%
\csname PSTMoireLoaded\endcsname
% Requires PSTricks, pst-xkey and pst-node packages
\ifx\PSTricksLoaded\endinput\else\input pstricks.tex\fi
\ifx\PSTXKeyLoaded\endinput\else\input pst-xkey \fi
\ifx\MultidoLoaded\endinput\else\input multido.tex \fi
%
\edef\PstAtCode{\the\catcode`\@} \catcode`\@=11\relax
%
\pstheader{pst-moire.pro}
%
\pst@addfams{pst-moire}
\define@key[psset]{pst-moire}{Rmax}{\edef\psk@moire@R{#1}} % en cm
\define@key[psset]{pst-moire}{scale}{\edef\psk@moire@scale{#1}} % echelle
\define@key[psset]{pst-moire}{Alpha}{\edef\psk@moire@Alpha{#1}} % pente des traits pour Gauss en degrés
\define@key[psset]{pst-moire}{rotate}{\edef\psk@moire@rot{#1 }} % rotation de la grille
\define@key[psset]{pst-moire}{E}{\edef\psk@moire@E{#1 }} % espacement entre 2 traits de Gauss
\define@key[psset]{pst-moire}{n}{\edef\psk@moire@n{#1 }} % nombre de cercles
\define@key[psset]{pst-moire}{T}{\edef\psk@moire@T{#1 }} % période : dr en mm
% random-dots parameters
\define@key[psset]{pst-moire}{r}{\edef\psk@moire@r{#1 }} % r des trous en pts
\define@key[psset]{pst-moire}{p}{\edef\psk@moire@p{#1 }} % pas de la grille
\define@key[psset]{pst-moire}{k}{\edef\psk@moire@k{#1 }} % k : facteur qui module la dispersion des trous
\define@key[psset]{pst-moire}{symbole}{\def\psk@moire@symbol{#1}} % motif (lettre ou chiffre)
\define@key[psset]{pst-moire}{PSfont}{\def\pst@moirage@PSfont{/#1 }}
\define@key[psset]{pst-moire}{fontsize}{\def\pst@moirage@fontsize{#1 }}
\define@key[psset]{pst-moire}{vadjust}{\def\pst@moirage@vadjust{#1 }}
\define@key[psset]{pst-moire}{hadjust}{\def\pst@moirage@hadjust{#1 }}
\define@key[psset]{pst-moire}{hole}{\def\pst@moirage@hole{#1}}
%
\psset[pst-moire]{Rmax=6,scale=1,Alpha=70,rotate=0,E=0.25,n=30,T=2}
\psset[pst-moire]{r=0.5,p=4,k=0.2,symbole=2,rotate=0,PSfont=Helvetica-Bold,fontsize=4.7,vadjust=-1.5,hadjust=0,hole=round}
%
\def\variablesMoirages{%
 /R \psk@moire@R\space def
 /reduction {\psk@moire@scale\space mul} def
 /unit {\pst@number\psunit mul reduction} def
 /moire  {\psk@moire@type} def
 /rot \psk@moire@rot def
 /Runit R unit def
 /E1 \psk@moire@E def
 /nr \psk@moire@n def
 /Tr \psk@moire@T \pst@number\psunit 10 div mul def
 /circle { newpath 0 0 radius 0 360 arc closepath} def
 /NombreTraits  Runit \pst@number\psrunit div 10 mul cvi def
 /NombreTraitsLinear Runit 2.845 div cvi def
 /reduc \psk@moire@scale\space def
 /Alpha \psk@moire@Alpha\space def
 /m Alpha dup sin exch cos div def % tan(Alpha)
 /linecolor {\pst@usecolor\pslinecolor} def
 /linewidth {\pst@number\pslinewidth SLW} def
 /mm {\pst@number\psunit 10 div} bind def % le millimetre
 /DotSize  {\psk@dotsize} def
 /DotStyle {\@nameuse{psds@\psk@dotstyle}} def
 }
%% Reservation des noms de macros
% adaptation de la macro de pst-solides3d
% #1=type de reservation associee a une liste qui
% doit forcement etre du type pst@moire@list@#1
\def\pst@moire@reservednames#1{%
\edef\@tempa{\csname pst@moire@list@#1\endcsname}
\@for \name:=\@tempa\do{%
  \expandafter\def\csname pst@moire@#1@\name\endcsname{}%
}}
% nature du moiré
\def\pst@moire@list@type{%
  circle,Fresnel,radial,square,Gauss,Newton,Bouasse,linear,dot,chess}
%
%% Reservation de macros correspondants aux types
\pst@moire@reservednames{type}
\define@key[psset]{pst-moire}{type}{%
 \ifcsname pst@moire@type@#1\endcsname
   \def\psk@moire@type{pst-#1}%
 \else
    \@pstrickserr{The moire #1 is not defined, the moire by default is
    drawn}{}%
 \fi}
% moiré par defaut
\psset[pst-moire]{type=Fresnel}%
%
%  01 novembre 2018
%% Ajout de moiré à  la liste des types
\def\addtomoirelisttype#1{%
% ajouter les nouveaux objets  la liste
\expandafter\def\expandafter\pst@moire@list@type\expandafter%
 {\pst@moire@list@type,#1}%
% Reserver le nom des nouveaux types
 \edef\@tempa{#1}%
 \@for \name:=\@tempa\do{%
  \expandafter\def\csname pst@moire@type@\name\endcsname{}%
 }}
%
\def\psmoire{\def\pst@par{}\pst@object{psmoire}}
\def\psmoire@i{\@ifnextchar({\psmoire@do}{\psmoire@do(0,0)}}
\def\psmoire@do(#1){%
\begingroup%
\use@par%
  \begin@SpecialObj%
  \pst@@getcoor{#1}%
    \addto@pscode{
 moireDict begin
  \variablesMoirages
  \pst@coor  translate
 rot rotate
  \psk@moire@type\space
 end
    }%
  \end@SpecialObj%
\endgroup%
}%
%
\def\psRandomDot{\def\pst@par{}\pst@object{psRandomDot}}
\def\psRandomDot@i{\@ifnextchar({\psRandomDot@ii}{\psRandomDot@ii(10,10)}}
\def\psRandomDot@ii(#1,#2){%
\begin@SpecialObj
\addto@pscode{%
/cm {\pst@number\psunit mul } bind def
/pagewidth #1 cm def % en cm
/pageheight #2 cm def % en cm
% pas de la grille
/gridwidth \psk@moire@p def
% rayon des trous
/holeradius \psk@moire@r def
/symbol (\psk@moire@symbol) def
/alpha \psk@moire@rot def
/PSfont {\pst@moirage@PSfont} def
/fontsize \pst@moirage@fontsize def
/vadjust \pst@moirage@vadjust def
/hadjust \pst@moirage@hadjust def
/hole (\pst@moirage@hole) def
PSfont findfont fontsize scalefont setfont
% nombre aléatoire compris entre 0.0000 et 1.0000
/rand01 {rand 10000 mod 10000 div} def
% holedispersion permet de choisir le rayon du disque où on placera aléatoirement le centre du trou
/holedispersion {gridwidth \psk@moire@k neg \psk@moire@k 2 mul rand01 mul add mul} def
/loy pageheight -2 div def
/hiy pageheight 2 div def
/hix pagewidth 2 div def
/lox pagewidth -2 div def
/squarehole {
  xi holeradius neg add
  yi holeradius neg add moveto
  0 holeradius 2 mul rlineto
  holeradius 2 mul 0 rlineto
  0 holeradius 2 mul neg rlineto
}
def
%
/revealer {
2 srand
  newpath
  lox gridwidth sub loy gridwidth sub moveto
 pagewidth  2 gridwidth mul add 0 rlineto
  0 pageheight 2 gridwidth mul add  rlineto
  pagewidth neg  2 gridwidth mul sub 0 rlineto
loy gridwidth hiy
  {
    /y exch def
lox gridwidth hix
    {
      /x exch def
      /xi x holedispersion add def
      /yi y holedispersion add def
hole (round) eq {
      xi holeradius add yi moveto
      xi yi holeradius 360 0 arcn
      }{
  squarehole
      } ifelse
    }
    for
  }
  for
  closepath
  fill
} def
symbol stringwidth /wy exch def /wx exch def
/baselayer
{
1 setgray
lox gridwidth sub loy gridwidth sub pagewidth 2 gridwidth mul add pageheight 2 gridwidth mul add rectstroke
% 0 setgray
\pst@usecolor\pslinecolor
2 srand
loy gridwidth hiy
  {
    /y exch def
lox gridwidth hix
    {
      /x exch def
      /xi x holedispersion add def
      /yi y holedispersion add def
   gsave
      xi yi moveto
      wx -2 div hadjust add wy -2 div vadjust add rmoveto
      symbol show
   grestore
    }
    for
  }
  for
} def
-90 rotate
baselayer
alpha rotate
revealer
 }% fin du code ps
 \end@SpecialObj
 }% % fin de la commande PSTricks
% https://lspwww.epfl.ch/publications/books/moire/figs1II.html
%
% Figure "star1" from the Moire Demonstration Kit accompanying the book:
%		"The Theory of the Moire Phenomenon"
% by I. Amidror, published by Springer, 2007.
%
%		* * *  Copyright (c) 2007 EPFL  * * *
%
% Author: I. Amidror
%
% Modified: March 30, 2007
%
% ********************************************************************************
%
% An aperiodic dot screen that has undergone a non-linear transformation
%
% ********************************************************************************
% adapted by Manuel Luque for PSTricks
% November 15, 2018
%
\define@key[psset]{pst-moire}{function}{\edef\psk@moire@function{#1 }} %  la fonction
\define@boolkey[psset]{pst-moire}[Pst@moire@]{layers}[true]{}
% Default values
\psset[pst-moire]{function=5 r mul t 5 mul sin neg 0.5 mul 1 add mul 2.5 sub,layers=true}
%
\def\psGlassPattern{\def\pst@par{}\pst@object{psGlassPattern}}
\def\psGlassPattern@i{%
\addbefore@par{dotsize=1pt,fillcolor=black}
\begin@SpecialObj
\addto@pscode{%
 \ifPst@algebraic
      /fonction (\psk@moire@function) tx@AlgToPs begin AlgToPs end cvx def
    \else
      /fonction  { \psk@moire@function } def
    \fi
  \psk@dotsize
  \@nameuse{psds@\psk@dotstyle}
   /dotcolor {\pst@usecolor\pslinecolor } def
   /dotcolor2  {\pst@usecolor\psfillcolor} def
\ifPst@moire@layers /layers true def \else /layers false def \fi
/star-shapped {
20 dict begin
/Atan { /atan load stopped { pop pop 0 } if } def % return 0 if atan not known
/cm {\pst@number\psunit mul} bind def
/dim 15 cm def
/dim2 7.5 cm def
/myrand {rand 2147483647 div 2 mul 1 sub} def	% random number between -1...1
/pr 2 def		% period for dot screen
% ************ Draw the dot-screen:
% draw first (reference) dot screen:
10 srand		% seed for rand
/y dim2 neg def
1 setgray
-7.5 cm -7.5 cm 15 cm 15 cm rectfill
%0 setgray
%-7.5 cm -7.5 cm 15 cm 15 cm rectstroke
gsave
-7.5 cm -7.5 cm 14.75 cm 14.75 cm rectclip
dotcolor
0 pr dim 	% draw horizontal lines of dots
{
	/x dim2 neg def
	/ysave exch dim2 sub def
	0 pr dim 		% draw a horizontal line of dots
		{/xsave exch dim2 sub def
		/x1 x dim2 div def
		/y1 y dim2 div def
		/r2 x1 x1 mul y1 y1 mul add def
		/r r2 sqrt def
		/t y1 x1  Atan def	% angle in degrees!
		/cost fonction  def
		xsave
		fonction t cos mul 		% g1(x,y)
		add
		myrand  sub
		ysave
		fonction t sin mul 		% g2(x,y)
		add
		myrand sub Dot
		/x x pr add def
	} for
	/y y pr add def
} for
grestore
layers {
gsave
-7.25 cm -7.25 cm 14.75 cm 14.75 cm rectclip
% draw second dot screen:
%0 setgray
dotcolor2
10 srand		% same seed for rand
/y dim2 neg def
0 pr dim		% draw horizontal lines of dots
{
	/x dim2 neg def
	/ysave exch dim2 sub def
	0 pr dim		
		{/xsave exch dim2 sub def
		xsave
		myrand sub
		ysave
		myrand sub Dot
		/x x pr add def
	} for
	/y y pr add def
} for
grestore
} if
end
 } def
star-shapped
 }% fin du code ps
 \end@SpecialObj
 }% % fin de la commande PSTricks
%
\define@key[psset]{pst-moire}{NumberDots}{\edef\psk@moire@NumberDots{#1 }} %  Number of dots
\define@key[psset]{pst-moire}{coefficients}{\edef\psk@moire@coefficients{#1 }} % [a b theta tx ty]
\define@key[psset]{pst-moire}{srand}{\edef\psk@moire@srand{#1 }} % graine aléatoire pour postscript
\define@boolkey[psset]{pst-moire}[Pst@moire@]{revlayer}[true]{}
\define@boolkey[psset]{pst-moire}[Pst@moire@]{layer}[true]{}
% Default values
\psset{NumberDots=2000,coefficients=1.05 1.05 0 0 0,revlayer=true,layer=true,srand=10}
%
\def\psRandomDotPatterns{\def\pst@par{}\pst@object{psRandomDotPatterns}}
\def\psRandomDotPatterns@i{%
\addbefore@par{dotsize=2pt,fillcolor=black}
\begin@SpecialObj
\addto@pscode{%
  /N_ \psk@moire@NumberDots def
  \psk@dotsize
  \@nameuse{psds@\psk@dotstyle}
  /dotcolor {\pst@usecolor\pslinecolor } def
  /dotcolor2  {\pst@usecolor\psfillcolor} def
  /DOT {r 0 360 arc fill} def
\ifPst@moire@revlayer /revealinglayer true def \else /revealinglayer false def \fi
\ifPst@moire@layer /layer true def \else /layer false def \fi
/cm {\pst@number\psunit mul} bind def
/xmax 5 cm round cvi def
/ymax xmax def
/GlassPattern {
7 dict begin
gsave  %%%%%%%%%%%%%% herbert
/ty exch def
/tx exch def
/t exch def % theta degrees
/b exch def
/a exch def
layer {
\psk@moire@srand srand
N_ {
    /x rand 2 xmax mul mod xmax sub def % -xmax<x<xmax
    /y rand 2 ymax mul mod ymax sub def % -ymax<y<ymax
    /r rand 2147483647 div 2 mul def
 dotcolor x y DOT
   } repeat
 } if
% transformation
a b scale t rotate tx ty translate
\psk@moire@srand srand
revealinglayer {
N_{
    /x rand 2 xmax mul mod xmax sub def % -xmax<x<xmax
    /y rand 2 ymax mul mod ymax sub def % -ymax<y<ymax
    /r rand 2147483647 div 2 mul def
 dotcolor2 x y DOT
    } repeat
 } if
grestore
end
 } def
[\psk@moire@coefficients] length 3 eq {\psk@moire@coefficients 0 0} {\psk@moire@coefficients} ifelse
GlassPattern
 }% fin du code ps
 \end@SpecialObj
 }% % fin de la commande PSTricks
 \catcode`\@=\PstAtCode\relax
%% END: pst-moire.tex
\endinput