formelsammlung/src/img_static/cm/bands_schematic.tex
2025-03-29 02:06:19 +01:00

88 lines
3.2 KiB
TeX

\begin{tikzpicture}
\pgfmathsetmacro{\lvlW}{1} % width
\pgfmathsetmacro{\lvlDst}{\lvlW*0.1} % line distance
\pgfmathsetmacro{\atmx}{0}
\pgfmathsetmacro{\molx}{3}
\pgfmathsetmacro{\cstx}{7}
\pgfmathsetmacro{\asy}{0}
\pgfmathsetmacro{\apy}{\asy+1.5}
\pgfmathsetmacro{\mss}{2.2} % s splitting
\pgfmathsetmacro{\mps}{2.2} % p splitting
\pgfmathsetmacro{\msby}{\asy-0.5*\mss} % molecule s bonding y
\pgfmathsetmacro{\msay}{\asy+0.5*\mss} % molecule s antibonding y
\pgfmathsetmacro{\mpby}{\apy-0.5*\mps}
\pgfmathsetmacro{\mpay}{\apy+0.5*\mps}
\pgfmathsetmacro{\textY}{\msby-1}
\tikzset{
atom/.style={fill=fg1,circle,minimum size=0.2cm,inner sep=0},
}
% 1: name
% 2: center pos
% 3: n lines
% 4: n atoms
\newcommand\drawLevel[4]{
% atoms
\foreach \i in {1,...,#3} {
\pgfmathsetmacro{\yy}{-\lvlDst*(#3+1)/2 + \i*\lvlDst }
% \pgfmathsetmacro{\yy}{0}
\draw ($#2 - (\lvlW/2,0) + (0,\yy)$) -- ($#2 + (\lvlW/2,0) + (0,\yy)$);
}
\path ($#2 - (\lvlW/2,0)$) coordinate (#1 left);
\path ($#2 + (\lvlW/2,0)$) coordinate (#1 right);
% \draw[color=red] ($#2 - (\lvlW/2,0)$) -- ($#2 + (\lvlW/2,0)$);
% atoms
\foreach \i in {1,...,#4} {
\ifnum #4=0
\else
\pgfmathsetmacro{\xx}{-\lvlW/2+\i*\lvlW/(#4+1)}
% \pgfmathsetmacro{\yy}{0}
\node[atom] at ($#2 + (\xx,0)$) {};
\fi
}
}
% 1:name
% 2: center pos
% 3: height
% 4: fill options
\newcommand\drawLevelFill[4]{
\path ($#2 - (\lvlW/2,0)$) coordinate (#1 left);
\path ($#2 + (\lvlW/2,0)$) coordinate (#1 right);
\draw[#4] ($(#1 left) + (0, #3/2)$) rectangle ($(#1 right) - (0, #3/2)$);
}
% atom
\drawLevel{as}{(\atmx,\asy)}{2}{2} \node[anchor=east] at (as left) {$s$};
\drawLevel{ap}{(\atmx,\apy)}{6}{3} \node[anchor=east] at (ap left) {$p$};
\node at (\atmx,\textY) {\GT{atom}};
% molecule
\drawLevel{msb}{(\molx,\msby)}{1}{1} \node[anchor=west] at (msb right) {$s$ \gt{binding}};
\drawLevel{msa}{(\molx,\msay)}{1}{0} \node[anchor=west] at (msa right) {$s$ \gt{antibinding}};
\drawLevel{mpb}{(\molx,\mpby)}{3}{3} \node[anchor=west] at (mpb right) {$p$ \gt{binding}};
\drawLevel{mpa}{(\molx,\mpay)}{3}{0} \node[anchor=west] at (mpa right) {$p$ \gt{antibinding}};
\node at (\molx,\textY) {\GT{molecule}};
\draw[dashed] (as right) -- (msb left);
\draw[dashed] (as right) -- (msa left);
\draw[dashed] (ap right) -- (mpb left);
\draw[dashed] (ap right) -- (mpa left);
\node at (\cstx,\textY) {\GT{crystal}};
\drawLevelFill{cv1}{(\cstx,\msby)}{0.3}{sc occupied,draw}
\drawLevelFill{cv2}{(\cstx,\mpby)}{0.5}{sc occupied,draw} \node[anchor=west] at (cv2 right) {\GT{valence band}};
\drawLevelFill{cc1}{(\cstx,\msay)}{0.3}{} \node[anchor=west] at (cc1 right) {\GT{conduction band}};
\drawLevelFill{cc2}{(\cstx,\mpay)}{0.5}{}
% 1: x1, 2: x2, 3: y
\newcommand\midwayArrow[3]{
\pgfmathsetmacro{\xxmid}{#1+(#2-#1)/2}
\draw[->] (\xxmid-0.5,#3) -- (\xxmid+0.5,#3);
}
\midwayArrow{\atmx}{\molx}{\textY}
\midwayArrow{\molx}{\cstx}{\textY}
\end{tikzpicture}