process many comments
[phd-thesis.git] / top / mtask_integration.tex
index f0f32d8..1b0a22e 100644 (file)
@@ -1,15 +1,75 @@
 \documentclass[tikz]{standalone}
-\usetikzlibrary{positioning}
+\usetikzlibrary{positioning,shapes.geometric,shapes.symbols,shadows,fit}
 \begin{document}
-\begin{tikzpicture}[nodes={draw,minimum width=7.5em}]
-       \node (dsl)  {domain-specific language};
-       \node (sta) [below=of dsl,xshift=-3.75em] {standalone};
-       \node (emb) [right=of sta] {embedded};
-       \node (het) [below=of emb,xshift=-3.75em] {heterogeneous};
-       \node (hom) [right=of het] {homogeneous};
-       \draw [->] (dsl) -- (sta);
-       \draw [->] (dsl) -- (emb);
-       \draw [->] (emb) -- (het);
-       \draw [->] (emb) -- (hom);
+\begin{tikzpicture}[%
+               node distance=1em,
+               task/.style={regular polygon,regular polygon sides=3,text width=2.5em,draw},
+               share/.style={cylinder,shape border rotate=90,aspect=.3,text width=2.5em,text height=1em,draw},
+               client/.style={cloud,aspect=2}
+               ]
+       \node (C1) [client,inner sep=0pt,draw] {Client\textsubscript{1}};
+       \node (C2) [client,inner sep=0pt,draw,right=of C1] {Client\textsubscript{2}};
+       \node (CD) [right=of C2] {\ldots};
+       \node (CN) [client,inner sep=0pt,draw,right=of CD] {Client\textsubscript{n}};
+
+       % line between server and browser
+       \draw [dotted] ([xshift=-5em,yshift=-.8em]C1.south west) node[left,above]{presentation} node[left,below]{application} -- ([xshift=5em,yshift=-.8em]CN.south east);
+
+       \node[task,inner sep=-4.5pt,below=of C1,fill=white,xshift=6.5em,yshift=-4.5em] (Tn) {Task\textsubscript{n}};
+       \node[task,inner sep=-4.5pt,below=of C1,fill=white,xshift=5em,yshift=-3.0em] (Td) {\ldots};
+       \node[task,inner sep=-4.5pt,below=of C1,fill=white,xshift=3.5em,yshift=-1.5em] (T2) {Task\textsubscript{2}};
+       \node[task,inner sep=-4.5pt,below=of C1,fill=white,xshift=2em] (T1) {Task\textsubscript{1}};
+
+       \node[share,node distance=6em,right=of T1,fill=white,xshift=4.5em,yshift=-4.5em] (Sn) {SDS\textsubscript{n}};
+       \node[share,node distance=6em,right=of T1,fill=white,xshift=3em,yshift=-3.0em] (Sd) {\ldots};
+       \node[share,node distance=6em,right=of T1,fill=white,xshift=1.5em,yshift=-1.5em] (S2) {SDS\textsubscript{2}};
+       \node[share,node distance=6em,right=of T1,fill=white] (S1) {SDS\textsubscript{1}};
+
+       \node[fit={(T1)(Sn)},draw] (TS) {};
+
+       % line between client and server
+       \draw [dotted] ([xshift=-5em,yshift=-11em]C1.south west) node[left,above]{application} node[left,below]{perception} -- ([xshift=5em,yshift=-11em]CN.south east);
+
+       % device 1
+       \node[task,text width=1.5em,inner sep=-4.5pt,node distance=12em,below=of C1,double copy shadow={shadow xshift=.4em,shadow yshift=-.4em},fill=white] (D1T1) {};
+       \node[share,text width=.3em,text height=.8ex,right=of D1T1,double copy shadow={shadow xshift=.4em,shadow yshift=-.4em},fill=white] (D1S1) {};
+
+       \node[draw,fit={(D1S1)(D1T1)([shift={(1.2em,-1.2em)}]D1S1.south east)},label=below:{\scriptsize mTask device\textsubscript{1}}] (D1) {};
+
+       % device 2
+       \node[task,text width=1.5em,inner sep=-4.5pt,node distance=12em,below=of C2,double copy shadow={shadow xshift=.4em,shadow yshift=-.4em},fill=white] (D2T1) {};
+       \node[share,text width=.3em,text height=.8ex,right=of D2T1,double copy shadow={shadow xshift=.4em,shadow yshift=-.4em},fill=white] (D2S1) {};
+
+       \node[draw,fit={(D2S1)(D2T1)([shift={(1.2em,-1.2em)}]D2S1.south east)},label=below:{\scriptsize mTask device\textsubscript{2}}] (D2) {};
+
+       % device ...
+       \node[right=of D2] {\ldots};
+
+       % device n
+       \node[task,text width=1.5em,inner sep=-4.5pt,node distance=12em,below=of CN,double copy shadow={shadow xshift=.4em,shadow yshift=-.4em},fill=white] (DNT1) {};
+       \node[share,text width=.3em,text height=.8ex,right=of DNT1,double copy shadow={shadow xshift=.4em,shadow yshift=-.4em},fill=white] (DNS1) {};
+
+       \node[draw,fit={(DNS1)(DNT1)([shift={(1.2em,-1.2em)}]DNS1.south east)},label=below:{\scriptsize mTask device\textsubscript{n}}] (DN) {};
+
+       % iTask server
+       \node[fit={(C1)([shift={(1em,-1.2em)}]DN.south east)},draw,label={IoT application}] {};
+
+       % Arrows
+       \draw [<->,shorten <=2pt,shorten >=2pt] (C1) -- (T1);
+       \draw [<->,shorten <=2pt,shorten >=2pt] (C2) -- (T1);
+       \draw [<->,shorten <=2pt,shorten >=2pt] (CN) -- (T1);
+
+       \draw [<->,shorten <=2pt,shorten >=2pt] (T1) -- (S1);
+       \draw [<->,shorten <=2pt,shorten >=2pt] (T1) -- (S2);
+       \draw [<->,shorten <=2pt,shorten >=2pt] (T1) -- (Sn);
+
+       \draw [<->,shorten >=2pt] (Tn) -- node [midway,above,fill=white] {\texttt{liftmTask}} (D2T1);
+       \draw [<->,shorten >=2pt] (Sn) -- node [midway,above,fill=white] {\texttt{lowerSds}} (D2S1);
+
+       \draw [<->,shorten <=4pt] (D1T1) -- (D1S1);
+       \draw [<->,shorten <=4pt] (D2T1) -- (D2S1);
+       \draw [<->,shorten <=4pt] (DNT1) -- (DNS1);
+
+       \draw [<->,shorten <=2pt,shorten >=2pt] (D1.north) to [in=180,out=135] node [midway,above,fill=white] {\texttt{withDevice}} (TS.west);
 \end{tikzpicture}
 \end{document}