% pdflatex -interaction nonstopmode pst-marble-commands-v1.6.tex
\documentclass{article}
\usepackage[margin=1cm]{geometry}
\usepackage{xcolor}
\usepackage{hyperref}
%\documentclass[
% 11pt,
% english,
% BCOR10mm,
% DIV12,
% bibliography=totoc,
% parskip=false,
% fleqn,
% smallheadings,
% headexclude,
% footexclude,
% oneside,
% dvipsnames,
% svgnames,
% x11names,
%]{pst-doc}
\pagestyle{empty}
\newcommand\mycmd[2]{
\smallskip
\qquad {#1} \texttt{#2}
}
\newcommand\myparam[2]{
\smallskip
\qquad \texttt{#1=} \texttt{#2}
}
\newcommand\myparamb[2]{
\smallskip
\qquad \texttt{#1=} \texttt{{\char`\{}#2{\char`\}}}
}
\definecolor{Mycolor2}{HTML}{008000}
\newcommand\rgb{\textit{\textcolor{red}{r}\textcolor{Mycolor2}{g}\textcolor{blue}{b}}
}
\newcommand\rgbs{\texttt{[}\rgb~...\texttt{]} }
\newcommand\Rs{\texttt{[}$R$~...\texttt{]} }
%% \parskip5pt
\parindent0pt
\begin{document}
\url{
http://people.csail.mit.edu/jaffer/Marbling/pst-marble-commands-v1.6.pdf}
\section*{PST-marble Commands and Parameters}
\subsection*{Colors}
RGB colors can be specified in three formats:
\mycmd{\texttt{[ 0.906 0.8 0.608 ]}}{}
Red, green, and blue color components between 0 and 1 in square
brackets.
\mycmd{\texttt{[ 231 204 155 ]}}{}
Red, green, and blue color components between 0 and 255 in square
brackets.
\mycmd{\texttt{(e7cc9b)}}{}
Red, green, and blue
(\textcolor{red}{Rr}\textcolor{Mycolor2}{Gg}\textcolor{blue}{Bb})
hexadecimal color components between \texttt{00} and \texttt{FF} (or
\texttt{ff}) in parentheses.
In the command arguments \rgbs indicates a bracketed sequence of
colors. For example:
\mycmd{\texttt{[(c28847) [231 204 155] [0.635 0.008 0.094]]}}{}
\mycmd{\rgb $\gamma$}{tint}
Returns the \rgb color as modified by $\gamma$. $0<\gamma<1$ darkens
the color; $1<\gamma$ lightens the color; and $\gamma=1$ leaves it
unchanged.
%% The original color is returned by ``\rgb~$\gamma${\tt~tint}~$2-\gamma${\tt~tint}''.
\mycmd{\rgb $\gamma$}{shade}
Returns the \rgb color as modified by $\gamma$. $0<\gamma<1$ lightens
the color; $1<\gamma$ darkens the color; and $\gamma=1$ leaves it
unchanged.
\mycmd{\rgb $\zeta$}{edgy-color}
Returns the \rgb color flagged so that in raster rendering the
boundary of each drop of that color is lightened while its center is
darkened. Where $a$ is the point's initial distance from the drop
center and $r$ is the drop's initial radius, the effective
$\gamma~=~\exp\left(\zeta\,a^2/r^2\right)\,{(\exp(\zeta)-1)/(\zeta\exp(\zeta))}$.
When $\zeta=0$, $\gamma=1$ and the drop has uniformly tone.
\subsection*{Parameters}
\texttt{{\char`\\}psMarble[}
\textit{parameter-assignment}\texttt{,}
\dots{}\texttt{,}
\textit{parameter-assignment}
\texttt{](}\textit{width}\texttt{,}\textit{height}\texttt{)}
\texttt{{\char`\\}psMarble[}
\textit{parameter-assignment}\texttt{,}
\dots{}\texttt{,}
\textit{parameter-assignment}
\texttt{]($x-$,$y-$)($x+$,$y+$)}
\medskip
The comma separated parameter assignments are part of the
\texttt{{\char`\\}psMarble} command. In the list below, the default
value for each parameter is shown to the right of the parameter name.
Note that the values assigned to \texttt{background=},
\texttt{colors=}, \texttt{seed=}, \texttt{actions=}, and
\texttt{spractions=} must be enclosed in curly braces
\texttt{{\char`\{}{\char`\}}}.
\myparamb{background}{[0~0~0]}
Specifies the color for regions where paint has not been dropped (or
moved to).
\myparam{bckg}{true}
When \texttt{bckg=false} the background color is not shown.
\myparamb{paper}{[1~1~1]}
Specifies whether tinting (brightening) or shading (darkening) occurs
when shading due to paper movement occurs from the {\tt jiggle-shade}
or {\tt wriggle-shade} commands. Default is white (brightening).
\myparamb{colors}{[0.275~0.569~0.796]
[0.965~0.882~0.302]
[0.176~0.353~0.129]
[0.635~0.008~0.094]
[0.078~0.165~0.518]
[0.824~0.592~0.031]
[0.059~0.522~0.392]
[0.816~0.333~0.475]
[0.365~0.153~0.435]
[0.624~0.588~0.439]}
Specifies a color sequence accessible in paint-dropping commands as
\texttt{colors}.
\myparam{drawcontours}{false}
When \texttt{drawcontours=true} paint contours are drawn with lines;
when \texttt{drawcontours=false} contours are filled;
\myparam{oversample}{0}
When \texttt{oversample=0} a resolution-independent image is produced
using contour-rendering. When the number of drops gets too large
($>150$) triangular artifacts start to appear. Changing to
\texttt{oversample=1} employs raster-rendering to more quickly compute
each image pixel individually. When \texttt{oversample=2} the
rendering takes four times as long, but each pixel is the averaged
over its four quarters, producing an image nearly as good as
\texttt{oversample=0}. When \texttt{oversample} is between 0 and
1, the rendering is on a coarser grid than \texttt{oversample=1},
speeding image production.
\myparam{overscan}{1}
When the \texttt{overscan} value is greater than 1, proportionally
more image (outside of the specified area) is shown, and the specified
area is outlined with a dashed rectangular border. This is a utility
for developing marblings.
\myparamb{seed}{Mathematical Marbling}
Specifies the random seed used for \texttt{normal-drops},
\texttt{uniform-drops}, \texttt{normal-spray}, and
\texttt{uniform-spray} commands. Changing the \texttt{seed} value
changes the positions of all drops from the \texttt{normal-drops},
\texttt{uniform-drops}, \texttt{normal-spray}, and
\texttt{uniform-spray} commands.
\myparam{viscosity}{1000}
Specifies the overall kinetic viscosity of the virtual tank fluid.
Its units are $\rm{mm^2/s}$; the default value of 1000, which is 1000
times more viscous than water, is a typical value for marbling.
Increasing \texttt{viscosity} reduces the fluid movement far from the
tines.
\myparamb{actions}{0 0 36 colors 35 concentric-rings}
Specifies the sequence of marbling commands to perform. The default
is a single command dropping 35 colors in the \texttt{colors}
sequence. The available commands are listed below.
\myparamb{shadings}{}
When \texttt{oversample}$>0$, specifies the sequence of shading
commands to perform after all marbling \texttt{actions} and
\texttt{spractions} are performed.
\myparamb{spractions}{}
Specifies the sequence of spray commands to perform. Spray commands
are performed after marbling and before shading.
%% \newpage
\subsection*{Dropping Paint}
\mycmd{$x$ $y$ $R_d$ \rgb}{drop}
Places a drop of color \rgb and radius $R_d$ centered at location
$x,y$.
\mycmd{$x$ $y$ $R_i$ \rgbs $n$}{concentric-rings}
Places $n$ rings in color sequence \rgbs centered at location $x,y$,
each ring having thickness $R_i$.
\mycmd{$x$ $y$ $\theta$ \Rs \rgbs $R_d$}{line-drops}
Places drops of colors \rgbs (in sequence) of radius $R_d$ in
a line through $x,y$ at $\theta$ degrees clockwise from upward
at distances \Rs from $x,y$.
\mycmd{$x$ $y$ {\texttt{[}$\Omega_\perp$~...\texttt{]} } {\texttt{[}$\Omega_\parallel$~...\texttt{]} } $\theta$ \rgbs $R_d$}{serpentine-drops}
Places drops of colors \rgbs of radius $R_d$ in a serpentine pattern
(starting lower left to right; right to left; left to right...) at
offsets $\Omega_\perp \times \Omega_\parallel$ centered at location
$x,y$ and rotated by $\theta$ degrees clockwise from upward. The
sequences $\Omega_\perp$ and $\Omega_\parallel$ control the serpentine
sequence.
\mycmd{$x$ $y$ $R$ $\theta$ $S$ $\delta$ \rgbs $n$ $R_d$}{coil-drops}
Places $n$ drops of colors \rgbs (in sequence) of radius
$R_d$ in an arc or spiral centered at $x,y$ starting at radius $R$
and $\theta$ degrees clockwise from upward,
moving $S$ along the arc and incrementing the arc radius
by $\delta$ after each drop.
\mycmd{$x$ $y$ $L_\perp$ $L_\parallel$ $\theta$ \rgbs $n$ $R_d$}{normal-drops}
Places $n$ drops of colors \rgbs of radius $R_d$ randomly in a
circular or elliptical disk centered at $x,y$ having diameters
$L_\perp$ and $L_\parallel$ respectively perpendicular and parallel to
$\theta$ degrees clockwise from upward. For a circular disk
($R=L_\parallel/2=L_\perp/2$), 63\,\% of drops are within radius $R$,
87\,\% of drops are within $R\,\sqrt{2}$, and 98\,\% of drops are
within radius $2\,R$.
\mycmd{$x$ $y$ $L_\perp$ $L_\parallel$ $\theta$ \rgbs $n$ $R_d$}{uniform-drops}
Places $n$ drops of colors \rgbs of radius $R_d$ randomly in a $L_\perp$
by $L_\parallel$ rectangle centered at location $x,y$ and rotated by $\theta$
degrees clockwise from upward.
\subsection*{Deformations}
\mycmd{$\theta$ \Rs $V$ $S$ $D$}{rake}
Pulls tines of diameter $D$ at $\theta$ degrees from the y-axis
through the virtual tank at velocity $V$, moving fluid on the tine
path a distance $S$. The tine paths are spaced \Rs from the tank
center at their nearest points.
\mycmd{$x_b$ $y_b$ $x_e$ $y_e$ $V$ $D$}{stylus}
Pulls a single tine of diameter $D$ from $x_b,y_b$ to $x_e,y_e$ at
velocity $V$.
\mycmd{$x$ $y$ \Rs $\omega$ $\theta$ $D$}{stir}
Pulls tines of diameter $D$ in circular tracks of radii \Rs (positive
$R$ is clockwise) around location $x,y$ at angular velocity $\omega$.
The maximum angle through which fluid is moved is $\theta$ degrees.
\mycmd{$x$ $y$ $\Gamma$ $t$}{vortex}
Rotates fluid clockwise around location $x,y$ as would result from an
impulse of circulation $\Gamma$ after time $t$. At small $t$ the
rotational shear is concentrated close to the center. As time passes
the shear propagates outward.
%% \mycmd{$\theta$ $\lambda$ $\Omega$ $S$}{wiggle}
%% Applies sinsusoidal wiggle with period $\lambda$ and maximum
%% displacement $S$ to whole tank. With $\theta=0$, a point at $x,y$ is
%% moved to $x+S\,\sin(360\,y/\lambda+\Omega),y$.
\mycmd{$\theta$ $\lambda$ $\Omega$ $A$ $B$}{jiggle}
Consider the tank as split into parallel infinitesimal strips
perpendicular to direction $\theta$ (degrees clockwise from upward).
Where $a$ is the distance in the $\theta$ direction, the strips are
displaced along their lengths by $0.5\,B\,\cos(360\,(a+\Omega)/\lambda)$
and in the $\theta$ direction by $0.5\,A\,\sin(360\,(a+\Omega)/\lambda)$.
Displacements in the $\theta$ direction squeeze and expand distances
between the strips. To prevent tears and tunnels $|\pi\,A|<|\lambda|$.
For area-preserving {\tt jiggle}s, use $A=0$.
\mycmd{$x$ $y$ $\lambda$ $A$ $B$}{wriggle}
{\tt wriggle} is to {\tt jiggle} as {\tt stir} is to {\tt rake}.
Consider the tank as split into concentric rings around $x,y$. Where
$r$ is the radial distance from $x,y$, rings are rotated by
$0.5\,B\,\cos(360\,r/\lambda)$, and expanded and contracted
$0.5\,A\,\sin(360\,r/\lambda)$. To prevent overlap
$|\pi\,A|<|\lambda|$. There is no offset parameter. When
$A/\lambda>0$, maximum compression is at $r$ equal to odd multiples of
$0.5\,\lambda$; otherwise maximum compression is at integer multiples
of $\lambda$.
\mycmd{$\theta$ $\Omega$}{shift}
Shifts tank by distance $\Omega$ in direction $\theta$ degrees
clockwise from upward.
\mycmd{$x$ $y$ $\theta$}{turn}
Turns tank around $x,y$ by $\theta$ degrees clockwise.
\mycmd{\texttt{[} $n$ $S$ $\Omega$}{tines} \texttt{]}
The {\tt tines} command and its arguments are replaced by a sequence
of $n$ numbers. The difference between adjacent numbers is $S$ and the
center number is $\Omega$ when $n$ is odd and $S/2-\Omega$ when $n$ is
even.
\subsection*{Spray Actions}
Spray actions are intended for drops small enough that they don't
noticeably move paint contours. The radii of spray droplets are the
cube roots of log-normal distributed values with mean $R_d$.
\mycmd{$x$ $y$ $L_\perp$ $L_\parallel$ $\theta$ \rgbs $n$ $R_d$}{normal-spray}
Places $n$ drops of colors \rgbs of radius $R_d$ randomly in a
circular or elliptical disk centered at $x,y$ having diameters
$L_\perp$ and $L_\parallel$ respectively perpendicular and parallel to
$\theta$ degrees clockwise from upward. For a circular disk
($R=L_\parallel/2=L_\perp/2$), 63\,\% of drops are within radius $R$,
87\,\% of drops are within $R\,\sqrt{2}$, and 98\,\% of drops are
within radius $2\,R$.
\mycmd{$x$ $y$ $L_\perp$ $L_\parallel$ $\theta$ \rgbs $n$ $R_d$}{uniform-spray}
Places $n$ drops of colors \rgbs of radius $R_d$ randomly in a $L_\perp$
by $L_\parallel$ rectangle centered at location $x,y$ and rotated by $\theta$
degrees clockwise from upward.
\subsection*{Shadings}
Shadings commands simulate the lightening and darkening of paint
transferred to paper caused by pulling the paper from the bath at
uneven rates. Shading is always performed for \texttt{spractions},
but only when \texttt{oversample}$>0$ for \texttt{actions}. Shading
commands are placed within the braces of the \texttt{shadings=\{\}}
parameter.
\mycmd{$\theta$ $\lambda$ $\Omega$ $A_s$}{jiggle-shade}
Applies darkening and lightening resulting from the squeezing and
expansion of a {\tt jiggle} command sharing its first four arguments:
``$\theta~\lambda~\Omega~A~B$~{\tt jiggle}''.
$A_s$ does not need to equal $A$ from the {\tt jiggle} command. When
$A_s$ is closer to zero, shading will be softer; when $A_s$ is further
from zero, shading will be darker. As with $A$ in the {\tt jiggle}
command, realistic shading requires $|\pi\,A_s|<|\lambda|$.
\mycmd{$x$ $y$ $\lambda$ $\Omega$ $A_s$}{wriggle-shade}
Applies darkening and lightening resulting from the squeezing and
expansion of a {\tt wriggle} command sharing its first three
arguments. Unlike {\tt wriggle}, {\tt wriggle-shade} takes an offset
argument $\Omega$. $A_s$ does not need to equal $A$ from the {\tt
wriggle} command. When $A_s$ is closer to zero, shading will be
softer; when $A_s$ is further from zero, shading will be darker. As
with $A$ in the {\tt wriggle} command, realistic shading requires
$|\pi\,A_s|<|\lambda|$. When $A/\lambda>0$ and $\Omega=0$, the
darkest rings are at $r$ equal to odd multiples of $0.5\,\lambda$;
otherwise the darkest rings are at integer multiples of $\lambda$ and
there is a dark spot at $x,y$.
\end{document}