diff options
Relayout cylinder2d coefficient section
-rw-r--r-- | content.tex | 52 | ||||
-rw-r--r-- | img/cylinder2d_deltap_comparison.tikz | 5 | ||||
-rw-r--r-- | img/cylinder2d_drag_lift_comparison.tikz (renamed from img/cylinder2d_drag_comparison.tikz) | 46 | ||||
-rw-r--r-- | img/cylinder2d_high_res_drag_comparison.tikz | 33 | ||||
-rw-r--r-- | img/cylinder2d_high_res_lift_deltap_comparison.tikz (renamed from img/cylinder2d_high_res_comparsion.tikz) | 29 | ||||
-rw-r--r-- | img/cylinder2d_lift_comparison.tikz | 41 |
6 files changed, 106 insertions, 100 deletions
diff --git a/content.tex b/content.tex index a1286b6..b66bf64 100644 --- a/content.tex +++ b/content.tex @@ -1080,6 +1080,7 @@ Klar zu erkennen ist die in der verfeinerten Variante deutlich bessere Diskretis Bevor wir dazu kommen, bemerken wir, dass sich mit dieser flexibleren Verteilung der Knotenfreiheitsgrade hier auch ein, bis jetzt lediglich in der Einführung erwähnter, Vorteil von Gitterverfeinerung illustriert: Selbst wenn ein Verfeinerungsverfahren bezogen auf den Fehler im Vergleich mit analytischen Lösungen keine Verbesserungen oder sogar leichte Einbußen produziert, kann es doch potenziell eingesetzt werden, um Probleme zu behandeln, welche anderweitig nicht oder nur mit deutlich höherem Speicher- und Rechenaufwand zugänglich wären.
+\newpage
\subsubsection{Vergleich von Widerstands- und Auftriebskoeffizienten}
Bis hier haben wir die den Einfluss von Gitterverfeinerung auf die Zylinderumströmung entweder subjektiv, durch Vergleich der Strömungsbilder, oder grob, durch einfachen Vergleich der für eine divergenzfreie Simulation benötigten Knotenanzahl, bewertet. Wie eingangs erwähnt, existiert für die vorliegende Strömungssituation keine analytische Lösung, weshalb wir uns für eine formal belastbarere Bewertung auf vertrauenswürdige aber ebenfalls simulierte Referenzwerte stützen wollen.
@@ -1094,7 +1095,6 @@ F_a &= - \int_S \left( \rho_c \nu \frac{\partial v_t}{\partial n} n_0 + P n_1 \r \end{align*}
\end{Definition}
-\newpage
\begin{Definition}[Strömungswiderstands- und Auftriebskoeffizient]
Sei \(D\) der Zylinderdurchmesser, \(\overline{U}\) die durchschnittliche Fluidgeschwindigkeit und \(\rho_c\) die charakteristische Dichte. Dann sind die Widerstands- und Auftriebskoeffizienten gegeben als~\cite[Kap.~2.2]{SchaeferTurek96}:
\begin{align*}
@@ -1105,20 +1105,15 @@ c_a &= \frac{2F_a}{\rho_c \overline{U}^2 D} && \text{Auftriebskoeffizient} Vergleichen wollen wir diese Koeffizienten nun im Rahmen des unstetigen Testfalls \cite[2.2b]{SchaeferTurek96} mit Reynolds-Zahl \(\text{Re}=100\), maximaler Einflussgeschwindigkeit \(U = 1.5 \,\text{m}/\text{s}\) und charakteristischer Dichte \(\rho_c = 1.0 \,\text{kg}/\text{m}^3\). Dieses Ziel hatten wir dabei schon zu Beginn dieses Kapitels im Blick, so dass die OpenLB-basierende Modellierung der Zylinderumströmung inklusive des optimierten Gitters in Abbildung~\ref{fig:CylinderOptimizedGridComparison} direkt verwendet werden kann. Für die Berechnung der Koeffizienten stellt OpenLB dabei in Form des \class{SuperLatticePhysDrag2D} Funktors bereits ein passendes \emph{Messinstrument} bereit.
-\bigskip
-
+\newpage
Die folgenden Abbildungen zeichnen demnach den zeitlichen Verlauf der durch das uniform mit \(N=12\) aufgelöste Gitter berechneten Charakteristiken zusammen mit den Resultaten des problembewusst verfeinerten \(N=5\) Gitters mit näherungsweise gleicher Anzahl Freiheitsgraden. Der anzustrebende formale Referenzwert ist dabei jeweils das Mittel der oberen und unteren Grenzwerte \cite[Tabelle~4]{SchaeferTurek96}.
-\begin{figure}[H]
-\centering
-\input{img/cylinder2d_drag_comparison.tikz}
-\caption{Zeitlicher Verlauf des Strömungswiderstandskoeffizients}
-\end{figure}
+\bigskip
\begin{figure}[H]
\centering
-\input{img/cylinder2d_lift_comparison.tikz}
-\caption{Zeitlicher Verlauf des Auftriebskoeffizients}
+\input{img/cylinder2d_drag_lift_comparison.tikz}
+\caption{Zeitlicher Verlauf des Strömungswiderstands- und Auftriebskoeffizienten}
\end{figure}
\begin{figure}[H]
@@ -1127,16 +1122,9 @@ Die folgenden Abbildungen zeichnen demnach den zeitlichen Verlauf der durch das \caption{Zeitlicher Verlauf der Druckdifferenz}
\end{figure}
-\newpage
Klar zu erkennen ist, dass die Simulation auf dem verfeinerten Gitter über alle drei Kriterien sowohl die Referenzwerte besser trifft als auch unabhängig davon eine bessere Qualität bezogen auf Fluktuation und Konsistenz in der periodischen Strömungsphase aufweist. Da diese Ergebnisse bei näherungsweise beibehaltener Anzahl von Gitterknoten erzielt wurden -- tatsächlich verwendet das verfeinerte Gitter sogar 46 Knoten weniger als das uniform aufgelöste -- ist somit auch bei formaler Betrachtung der positive Nutzen von Gitterverfeinerung zur Simulation der Zylinderumströmung klar demonstriert. Wir erhalten bei leicht geringerer Anzahl von Knoten und damit näherungsweise gleichem Speicherbedarf ein deutlich besseres Simulationsergebnis.
-\bigskip
-
-Das diesen Resultaten zugrundeliegende Gitter orientiert sich in der Anzahl seiner Zellen an einem uniform aufgelösten Gitter, welches knapp an der Grenze zur Divergenz im Ausflussgebiet arbeitet. Die im Vergleich dazu sehr guten Ergebnisse des optimierten Gitters sind also nicht zu überraschend.
-Als weiteren Vergleich betrachten wir deshalb die entscheidenden maximalen Widerstands- und Auftriebskoeffizienten \(\widehat{c_w}\) bzw. \(\widehat{c_a}\) eines uniform mit \(N=40\), d. h. der maximalen lokalen Auflösung unseres problembewusst verfeinerten Gitters entsprechend, aufgelösten Gitters.
-Auch im Vergleich mit diesem 145314 Knoten umfassenden Gitter bewähren sich die, mit nur etwa einem Zehntel der Knoten gewonnenen, Ergebnisse der verfeinerten Simulation:
-
-\begin{table}[h]
+\begin{table}[H]
\centering
\sisetup{round-precision=4}
\begin{tabular}{l l l l l}
@@ -1160,23 +1148,38 @@ Knotenanzahl & \num{145314} & \num{13454} & \\ \label{tab:cylinder2dComparison}
\end{table}
-\noindent
+\newpage
+Das diesen Resultaten zugrundeliegende Gitter orientiert sich in der Anzahl seiner Zellen an einem uniform aufgelösten Gitter, welches knapp an der Grenze zur Divergenz im Ausflussgebiet arbeitet. Die im Vergleich dazu sehr guten Ergebnisse des optimierten Gitters sind also nicht zu überraschend.
+Als weiteren Vergleich betrachten wir deshalb in Tabelle~\ref{tab:cylinder2dComparison} die entscheidenden maximalen Widerstands- und Auftriebskoeffizienten \(\widehat{c_w}\) bzw. \(\widehat{c_a}\) einer uniform mit \(N=40\), d. h. der maximalen lokalen Auflösung unseres problembewusst verfeinerten Gitters entsprechend, aufgelösten Simulation.
+
+Auch im Vergleich mit diesem \num{145314} Knoten umfassenden Gitter bewähren sich die, mit nur etwa einem Zehntel der Knoten gewonnenen, Ergebnisse der verfeinerten Simulation.
Tatsächlich ist der Fehler des verfeinerten Gitters für Widerstandskoeffizient und Druckdifferenz sogar kleiner als der des uniformen Gitters mit ungleich mehr Knoten.
\bigskip
Wir haben an dieser Stelle also auch im formalen Vergleich bestätigt, dass sich Gitterverfeinerung zur besseren Verteilung beschränkter Rechenressourcen einsetzen lässt.
Die bestimmten Vergleichswerte bestehen bei geeigneter Variation der lokalen Gitterweiten auch in Konkurrenz mit uniformen Gittern, die auf der ganzen Simulationsdomäne der feinsten Gitterweite des heterogenen Gitters entsprechend aufgelöst sind. Es stellt sich daher die Frage, ob dieser klare Vorteil auch auf höher aufgelöste Gitter übertragen werden kann und sich die Ergebnisse in vergleichbarem Maße verbessern.
-Dazu sehen wir in Abbildung~\ref{fig:cylinder2dHighResComparison} und zugehöriger Tabelle~\ref{tab:cylinder2dHighResComparison} die aerodynamischen Kennzahlen der uniformen \(N=48\) und \(N=80\) Gitter sowie eines problembezogen varierten \(N=20\) Gitters entsprechend der Struktur in Abbildung~\ref{fig:CylinderOptimizedGridComparison} ohne Ausflussverfeinerung.
+Dazu sehen wir in Abbildungen~\ref{fig:cylinder2dHighResDragComparison} und \ref{fig:cylinder2dHighResLiftDeltapComparison} sowie zugehöriger Tabelle~\ref{tab:cylinder2dHighResComparison} die aerodynamischen Kennzahlen der uniformen \(N=48\) und \(N=80\) Gitter sowie eines problembezogen varierten \(N=20\) Gitters entsprechend der Struktur in Abbildung~\ref{fig:CylinderOptimizedGridComparison} ohne Ausflussverfeinerung.
+
+\bigskip
+
+\begin{figure}[H]
+\centering
+\input{img/cylinder2d_high_res_drag_comparison.tikz}
+\caption{Strömungswiderstandskoeffizient in feineren Simulationen}
+\label{fig:cylinder2dHighResDragComparison}
+\end{figure}
\begin{figure}[H]
\centering
-\input{img/cylinder2d_high_res_comparsion.tikz}
-\caption{Zeitlicher Verlauf der Messwerte höher aufgelöster Gitter}
-\label{fig:cylinder2dHighResComparison}
+\input{img/cylinder2d_high_res_lift_deltap_comparison.tikz}
+\caption{Auftriebskoeffizient und Druckdifferenz in feineren Simulationen}
+\label{fig:cylinder2dHighResLiftDeltapComparison}
\end{figure}
-\begin{table}[h]
+Das geeignet verfeinerte Gitter liefert demnach in zwei von drei Messwerten einen kleineren Fehler als ein äquivalent aufgelöstes \(N=48\) Gitter und besteht im Vergleich mit dem uniformen \(N=80\) Gitter erneut gegenüber einer signifikant mehr Knoten nutzenden Simulation. Selbst gegenüber eines mehr als zehnmal so viele Knoten aufwendenden uniformen \(N=160\) Gitter erhalten wir mit der verfeinerten Variante noch einen leicht kleineren Fehler in der Druckdifferenz.
+
+\begin{table}[H]
\centering
\sisetup{round-precision=4}
@@ -1201,7 +1204,6 @@ Knotenanzahl & \num{2298014} & \num{576758} & \num{207862} & \num{208031} & \\ \label{tab:cylinder2dHighResComparison}
\end{table}
-Das geeignet verfeinerte Gitter liefert demnach in zwei von drei Messwerten einen kleineren Fehler als ein äquivalent aufgelöstes \(N=48\) Gitter und besteht im Vergleich mit dem uniformen \(N=80\) Gitter erneut gegenüber einer deutlich mehr Knoten nutzenden Simulation. Selbst gegenüber eines mehr als zehnmal so viele Knoten aufwendenden uniformen \(N=160\) Gitter erhalten wir mit der uniformen Variante noch einen leicht kleineren Fehler in der Druckdifferenz.
Da alle vier getesteten Gitter gute Übereinstimmung zu den Referenzdaten von Schäfer und Turek aufweisen, fällt der Vorteil der Gitterverfeinerung im Allgemeinen jedoch geringer aus, als noch im Vergleich der niedrig aufgelösten Gitter aus Abbildung~\ref{fig:CylinderOptimizedGridComparison} und Tabelle~\ref{tab:cylinder2dComparison}. Darüber hinaus liegt die Knotenanzahl des betrachteten \(N=160\) Gitters weit oberhalb der maximalen referenzstiftenden Knotenzahlen \cite[Tabelle~4]{SchaeferTurek96}, so dass wir hier an die Grenzen der Aussagekraft von Fehlern bezüglich dieser Werte stoßen.
diff --git a/img/cylinder2d_deltap_comparison.tikz b/img/cylinder2d_deltap_comparison.tikz index 2d6fd99..709273c 100644 --- a/img/cylinder2d_deltap_comparison.tikz +++ b/img/cylinder2d_deltap_comparison.tikz @@ -5,7 +5,7 @@ \begin{axis}[ scale only axis, - height=8cm, + height=7.5cm, width=0.9*\textwidth, legend cell align=left, legend pos=south east, @@ -16,7 +16,8 @@ ylabel={Druckdifferenz}, x unit=s, y unit=N/m^2, - y tick label style={/pgf/number format/.cd, use comma} + y tick label style={/pgf/number format/.cd, use comma}, + ylabel absolute, every axis y label/.append style={yshift=0.2cm}, ] \addplot[ diff --git a/img/cylinder2d_drag_comparison.tikz b/img/cylinder2d_drag_lift_comparison.tikz index 82746f3..ca4bb02 100644 --- a/img/cylinder2d_drag_comparison.tikz +++ b/img/cylinder2d_drag_lift_comparison.tikz @@ -5,16 +5,15 @@ \begin{axis}[ scale only axis, - height=8cm, + height=7.5cm, width=0.9*\textwidth, legend cell align=left, legend pos=south east, grid=both, domain=0:16, xmin=0, xmax=16, - xlabel={Simulierte physikalische Zeit}, ylabel={Widerstandskoeffizient}, - x unit=s + ylabel absolute, every axis y label/.append style={yshift=0.2cm} ] \addplot[ @@ -23,7 +22,6 @@ ] table [ x expr=\thisrow{time}, y=drag ] {\uniform}; -\addlegendentry {Uniformes \(N=12\) Gitter}; \addplot[ color=green!70!black, @@ -31,11 +29,47 @@ ] table [ x expr=8*\thisrow{time}, y=drag ] {\refined}; -\addlegendentry {Problembezogen verfeinertes \(N=5\) Gitter}; \addplot[color=black]{3.23}; \addlegendentry {Gemittelte Referenzlösung \(c_\text{Wmax} := \num{3.23}\)}; \end{axis} -\end{tikzpicture} +\begin{axis}[ + scale only axis, + height=7.5cm, + yshift=-8.75cm, + width=0.9*\textwidth, + legend cell align=left, + legend pos=south west, + grid=both, + domain=0:16, + xmin=0, xmax=16, + xlabel={Simulierte physikalische Zeit}, + ylabel={Auftriebskoeffizient}, + ylabel absolute, every axis y label/.append style={yshift=0.2cm}, + x unit=s +] + +\addplot[ + color=blue!50!white, + very thin +] table [ + x expr=\thisrow{time}, y=lift +] {\uniform}; +\addlegendentry {Uniformes \(N=12\) Gitter}; + +\addplot[ + color=green!70!black, + thick +] table [ + x expr=8*\thisrow{time}, y=lift +] {\refined}; +\addlegendentry {Problembezogen verfeinertes \(N=5\) Gitter}; + +\addplot[color=black]{1.0}; +\addlegendentry {Gemittelte Referenzlösung \(c_\text{Lmax} := 1\)}; + +\end{axis} + +\end{tikzpicture} diff --git a/img/cylinder2d_high_res_drag_comparison.tikz b/img/cylinder2d_high_res_drag_comparison.tikz new file mode 100644 index 0000000..8ecdcbd --- /dev/null +++ b/img/cylinder2d_high_res_drag_comparison.tikz @@ -0,0 +1,33 @@ +\begin{tikzpicture} +\pgfplotstableread[col sep=comma]{img/data/cylinder2d_optimized_grid_n20_re100_drag_lift_deltap.csv}\refined +\pgfplotstableread[col sep=comma]{img/data/cylinder2d_unrefined_n48_re100_drag_lift_deltap.csv}\uniformMiddle +\pgfplotstableread[col sep=comma]{img/data/cylinder2d_unrefined_n80_re100_drag_lift_deltap.csv}\uniformHigh + +\begin{axis}[ + scale only axis, + height=7.5cm, + width=0.9*\textwidth, + legend cell align=left, + legend pos=south east, + grid=both, + domain=0:16, + xmin=6, xmax=16, + xlabel={Simulierte physikalische Zeit}, + x unit=s, + ylabel={Widerstandskoeffizient}, + ylabel absolute, every axis y label/.append style={yshift=0.4cm}, + y tick label style={/pgf/number format/.cd, use comma} +] + +\addplot[color=black]{3.23}; +\addlegendentry {Gemittelte Referenzlösung \(c_\text{Wmax} := \num{3.23}\)}; +\addplot[color=blue!50!white,thin,densely dashed] table [x expr=\thisrow{time}, y=drag] {\uniformHigh}; +\addlegendentry {Uniformes \(N=80\) Gitter mit \(\sim 577000\) Knoten}; +\addplot[color=blue!50!white,thin] table [x expr=\thisrow{time}, y=drag] {\uniformMiddle}; +\addlegendentry {Uniformes \(N=48\) Gitter mit \(\sim 208000\) Knoten}; +\addplot[color=green!70!black,thick] table [x expr=8*\thisrow{time}, y=drag] {\refined}; +\addlegendentry {Verfeinertes \(N=20\) Gitter mit \(\sim 208000\) Knoten}; + +\end{axis} + +\end{tikzpicture} diff --git a/img/cylinder2d_high_res_comparsion.tikz b/img/cylinder2d_high_res_lift_deltap_comparison.tikz index 97d6ba7..358a893 100644 --- a/img/cylinder2d_high_res_comparsion.tikz +++ b/img/cylinder2d_high_res_lift_deltap_comparison.tikz @@ -5,30 +5,7 @@ \begin{axis}[ scale only axis, - height=6cm, - width=0.9*\textwidth, - legend cell align=left, - legend pos=south east, - grid=both, - domain=0:16, - xmin=6, xmax=16, - ylabel={Widerstandskoeffizient}, - ylabel absolute, every axis y label/.append style={yshift=0.4cm}, - y tick label style={/pgf/number format/.cd, use comma} -] - -\addplot[color=black]{3.23}; -\addlegendentry {Gemittelte Referenzlösung \(c_\text{Wmax} := \num{3.23}\)}; -\addplot[color=blue!50!white,thin,densely dashed] table [x expr=\thisrow{time}, y=drag] {\uniformHigh}; -\addplot[color=blue!50!white,thin] table [x expr=\thisrow{time}, y=drag] {\uniformMiddle}; -\addplot[color=green!70!black,thick] table [x expr=8*\thisrow{time}, y=drag] {\refined}; - -\end{axis} - -\begin{axis}[ - scale only axis, - yshift=-7cm, - height=6cm, + height=7.5cm, width=0.9*\textwidth, legend cell align=left, legend pos=south east, @@ -50,8 +27,8 @@ \begin{axis}[ scale only axis, - yshift=-14cm, - height=6cm, + yshift=-8.5cm, + height=7.5cm, width=0.9*\textwidth, legend cell align=left, legend pos=south east, diff --git a/img/cylinder2d_lift_comparison.tikz b/img/cylinder2d_lift_comparison.tikz deleted file mode 100644 index 644a6b8..0000000 --- a/img/cylinder2d_lift_comparison.tikz +++ /dev/null @@ -1,41 +0,0 @@ -\begin{tikzpicture} -\pgfplotstableread[col sep=comma]{img/data/cylinder2d_optimized_refinement_n5_re100_drag_lift_deltap.csv}\refined -\pgfplotstableread[col sep=comma]{img/data/cylinder2d_unrefined_n12_re100_drag_lift_deltap.csv}\uniform -\pgfplotstableread[col sep=comma]{img/data/cylinder2d_unrefined_n40_re100_drag_lift_deltap.csv}\uniformHighRes - -\begin{axis}[ - scale only axis, - height=8cm, - width=0.9*\textwidth, - legend cell align=left, - legend pos=south west, - grid=both, - domain=0:16, - xmin=0, xmax=16, - xlabel={Simulierte physikalische Zeit}, - ylabel={Auftriebskoeffizient}, - x unit=s -] - -\addplot[ - color=blue!50!white, - very thin -] table [ - x expr=\thisrow{time}, y=lift -] {\uniform}; -\addlegendentry {Uniformes \(N=12\) Gitter}; - -\addplot[ - color=green!70!black, - thick -] table [ - x expr=8*\thisrow{time}, y=lift -] {\refined}; -\addlegendentry {Problembezogen verfeinertes \(N=5\) Gitter}; - -\addplot[color=black]{1.0}; -\addlegendentry {Gemittelte Referenzlösung \(c_\text{Lmax} := 1\)}; - -\end{axis} -\end{tikzpicture} - |