From 94d3e79a8617f88dc0219cfdeedfa3147833719d Mon Sep 17 00:00:00 2001
From: Adrian Kummerlaender
Date: Mon, 24 Jun 2019 14:43:36 +0200
Subject: Initialize at openlb-1-3
---
src/dynamics/superGuoZhaoPostProcessor2D.hh | 92 +++++++++++++++++++++++++++++
1 file changed, 92 insertions(+)
create mode 100644 src/dynamics/superGuoZhaoPostProcessor2D.hh
(limited to 'src/dynamics/superGuoZhaoPostProcessor2D.hh')
diff --git a/src/dynamics/superGuoZhaoPostProcessor2D.hh b/src/dynamics/superGuoZhaoPostProcessor2D.hh
new file mode 100644
index 0000000..161b057
--- /dev/null
+++ b/src/dynamics/superGuoZhaoPostProcessor2D.hh
@@ -0,0 +1,92 @@
+/* This file is part of the OpenLB library
+ *
+ * Copyright (C) 2016-2017 Davide Dapelo, Mathias J. Krause
+ * OpenLB e-mail contact: info@openlb.net
+ * The most recent release of OpenLB can be downloaded at
+ *
+ *
+ * This program is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU General Public License
+ * as published by the Free Software Foundation; either version 2
+ * of the License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public
+ * License along with this program; if not, write to the Free
+ * Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
+ * Boston, MA 02110-1301, USA.
+*/
+
+/** \file
+ * Class to define the external fields involved
+ * in the porous modelling (i.e., porosity, porous conductivity
+ * with the addition of a generic body force)
+ * -- generic file
+ */
+
+#ifndef SUPER_GUO_ZAO_POST_PROCESSOR_2D_HH
+#define SUPER_GUO_ZAO_POST_PROCESSOR_2D_HH
+
+#include "dynamics/guoZhaoLbHelpers.h"
+
+namespace olb {
+
+template
+SuperGuoZhaoInstantiator2D::SuperGuoZhaoInstantiator2D (
+ SuperLattice2D& sLattice_) :
+ sLattice(sLattice_)
+{}
+
+template
+void SuperGuoZhaoInstantiator2D::definePorousFields (
+ AnalyticalF2D& epsilon_, AnalyticalF2D& K_)
+{
+
+}
+
+template
+void SuperGuoZhaoInstantiator2D::defineEpsilon (
+ SuperGeometry2D& sGeometry, int material, AnalyticalF2D& epsilon)
+{
+
+ sLattice.template defineField(sGeometry, material, epsilon);
+}
+
+template
+void SuperGuoZhaoInstantiator2D::defineK (
+ UnitConverter const& converter, SuperGeometry2D& sGeometry, int material, AnalyticalF2D& K)
+{
+
+ AnalyticalConst2D normFactor(converter.getConversionFactorLength()*converter.getConversionFactorLength());
+ AnalyticalIdentity2D KLb(K / normFactor);
+ sLattice.template defineField(sGeometry, material, KLb);
+}
+
+template
+void SuperGuoZhaoInstantiator2D::defineNu (
+ UnitConverter const& converter, SuperGeometry2D& sGeometry, int material)
+{
+
+ AnalyticalConst2D nu(converter.getLatticeViscosity());
+ sLattice.template defineField(sGeometry, material, nu);
+}
+
+template
+void SuperGuoZhaoInstantiator2D::defineBodyForce (
+ UnitConverter const& converter, SuperGeometry2D& sGeometry, int material, AnalyticalF2D& BodyForce)
+{
+
+ std::vector normFactorValue ( 2,
+ converter.getConversionFactorLength() / (converter.getConversionFactorTime()*converter.getConversionFactorTime()) );
+ AnalyticalConst2D normFactor(normFactorValue);
+ AnalyticalIdentity2D BodyForceLb(BodyForce / normFactor);
+ sLattice.template defineField(sGeometry, material, BodyForceLb);
+}
+
+}
+
+#endif
--
cgit v1.2.3