From 169b24a98ae0dc1dabf19912f9228ff819fdb6ef Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 15:45:11 -0400 Subject: [PATCH 01/28] clang-tidy bash script --- utilities/clang_tidy.sh | 48 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 48 insertions(+) create mode 100755 utilities/clang_tidy.sh diff --git a/utilities/clang_tidy.sh b/utilities/clang_tidy.sh new file mode 100755 index 000000000..63e2d896e --- /dev/null +++ b/utilities/clang_tidy.sh @@ -0,0 +1,48 @@ +#!/bin/bash + +# +# Script to run clang-tidy over the entire repo. +# +# Run the script in the main folder (i.e., ./utilities/clang_tidy.sh) +# +# Requires LLVM 16.0.0 or later. + +dir=$1 + +# Check that the user has supplied a directory to begin the search +if [ ! -d "$dir/src" ] || [ ! -d "$dir/include" ] || [ ! -d "$dir/applications" ] || [ ! -f "$dir/CMakeLists.txt" ]; then + echo "Error, usage is: ./utilities/clang_tidy.sh /path/to/your/library" + exit 1 +fi + +# Print source directory +echo "Source directory: ${dir}" + +# Check that run-clang-tidy is installed and in path +if ! [ -x "$(command -v run-clang-tidy)" ] || ! [ -x "$(command -v clang++)" ]; then + echo "Error, run-clang-tidy and clang++ do not seem to be installed/in your path" + exit 2 +fi + +# Setup cmake arguments with export compile commands and debug mode +arguments=("-D" "CMAKE_EXPORT_COMPILE_COMMANDS=ON" "-D" "CMAKE_BUILD_TYPE=Debug") + +# Compile with clang +CC=clang CXX=clang++ cmake "${arguments[@]}" "$dir" || (echo "cmake failed!"; false) || exit 2 +cmake --build . || (echo "make failed!"; false) || exit 3 + +# Run clang-tidy +run-clang-tidy -p . -quiet -header-filter "$dir/include/*" "$dir/src/*" "$dir/tests/*" "$dir/applications/*" 2>error.txt >output.txt + +# Remove duplicates & log them +grep -E '(warning|error): ' output.txt | sort | uniq > clang-tidy.log + +# If there are errors, exit unsuccessfully +if [ -s clang-tidy.log ]; then + cat clang-tidy.log + exit 4 +fi + +# Successfully exit +echo "Clang-tidy checks passed!" +exit 0 \ No newline at end of file From a0d92bf1c6aacd84c8e9f456a1e893a970cc00c5 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 15:45:20 -0400 Subject: [PATCH 02/28] gitignore update --- .gitignore | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/.gitignore b/.gitignore index f9385a929..21adf319e 100644 --- a/.gitignore +++ b/.gitignore @@ -11,6 +11,10 @@ build/* # clangd .clangd +# Clang-tidy +output.txt +error.txt + # misc compile_commands.json @@ -97,7 +101,7 @@ DoxygenWarningLog.txt *.cproject *.DS_Store freeEnergy.txt -output.txt + # Output files integratedFields.txt From 7730ac41497288ee674bf9d29612509c7bb1e133 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 15:58:45 -0400 Subject: [PATCH 03/28] clangtidy ci --- .github/workflows/clangtidy.yml | 57 +++++++++++++++++++++++++++++++++ 1 file changed, 57 insertions(+) create mode 100644 .github/workflows/clangtidy.yml diff --git a/.github/workflows/clangtidy.yml b/.github/workflows/clangtidy.yml new file mode 100644 index 000000000..014a7adf5 --- /dev/null +++ b/.github/workflows/clangtidy.yml @@ -0,0 +1,57 @@ +name: Clang-tidy + +on: + push: + branches: + -master + pull_request: + branches: + - master + - development + types: + - opened + - reopened + - synchronize + - ready_for_review + +concurrency: + group: ${{ github.event_name }}-${{ github.workflow }}-${{ github.ref }} + cancel-in-progress: ${{ github.event_name == 'pull_request'}} + +jobs: + clang-tidy: + runs-on: [ubuntu-22.04] + + container: + image: dealii/dealii:v9.6.0-jammy + options: --user root + + steps: + - name: Checkout repo + uses: actions/checkout@v4 + with: + fetch-depth: 30 + + - name: Cache llvm-18 installation + uses: actions/cache@v3 + with: + path: /usr/lib/llvm-18 + key: ${{ runner.os }}-llvm-18 + restore-keys: | + ${{ runner.os }}-llvm + + - name: Install llvm-18 + if: steps.cache.outputs.cache-hit != 'true' + run: | + wget https://apt.llvm.org/llvm.sh + chmod +x llvm.sh + ./llvm.sh 18 all + + - name: Set up path for llvm-18 + run: | + echo "/usr/lib/llvm-18/bin" >> "$GITHUB_PATH" + + - name: Run clang-tidy + run: | + ./utilities/clang_tidy.sh . + From f4430ef8ce4d63c203c68839133c58ff383f626c Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 17:31:59 -0400 Subject: [PATCH 04/28] updating clangtidy --- .clang-tidy | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/.clang-tidy b/.clang-tidy index 7cd753dcb..7fea7776d 100644 --- a/.clang-tidy +++ b/.clang-tidy @@ -3,10 +3,26 @@ Checks: > -*, boost-*, + bugprone-*, + -bugprone-easily-swappable-parameters, + cert-*, + cppcoreguidelines-*, + -cppcoreguidelines-avoid-const-or-ref-data-members, + -cppcoreguidelines-non-private-member-variables-in-classes, + -cppcoreguidelines-avoid-magic-numbers, + hicpp-*, + misc-*, + -misc-non-private-member-variables-in-classes, + -misc-include-cleaner, + -misc-const-correctness, modernize-*, - -modernize-avoid-c-arrays, -modernize-use-trailing-return-type, mpi-*, - performance-* + performance-*, + readability-*, + -readability-else-after-return, + -readability-static-accessed-through-instance, + -readability-avoid-const-params-in-decls, + -readability-magic-numbers -WarningsAsErrors: '*' \ No newline at end of file +WarningsAsErrors: '*' From eb7d2de5a97131253ca96dce1e8fdf42c966b18b Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 21:44:19 -0400 Subject: [PATCH 05/28] nodiscard --- include/FloodFiller.h | 4 +- .../IntegrationTools/datastruc/PNDArray.hh | 10 ++-- include/IntegrationTools/pfield/Coordinate.hh | 2 +- .../pfield/interpolation/Hexahedron.hh | 58 +++++++++---------- .../pfield/interpolation/Quad.hh | 34 +++++------ .../IntegrationTools/pfunction/PFuncBase.hh | 2 +- .../IntegrationTools/pfunction/PSimpleBase.hh | 8 +-- .../pfunction/PSimpleFunction.hh | 8 +-- include/SimplifiedGrainRepresentation.h | 12 ++-- include/initialConditions.h | 2 +- include/inputFileReader.h | 6 +- include/matrixFreePDE.h | 2 +- include/nonUniformDirichletBC.h | 2 +- include/userInputParameters.h | 24 ++++---- src/matrixfree/initialConditions.cc | 2 +- 15 files changed, 88 insertions(+), 88 deletions(-) diff --git a/include/FloodFiller.h b/include/FloodFiller.h index 7a29bf71c..75e714404 100644 --- a/include/FloodFiller.h +++ b/include/FloodFiller.h @@ -35,7 +35,7 @@ class GrainSet /** * Gets the grain index. */ - unsigned int + [[nodiscard]] unsigned int getGrainIndex() const { return grain_index; @@ -53,7 +53,7 @@ class GrainSet /** * Gets the order parameter index. */ - unsigned int + [[nodiscard]] unsigned int getOrderParameterIndex() const { return order_parameter_index; diff --git a/include/IntegrationTools/datastruc/PNDArray.hh b/include/IntegrationTools/datastruc/PNDArray.hh index 1d16163cd..1de524573 100644 --- a/include/IntegrationTools/datastruc/PNDArray.hh +++ b/include/IntegrationTools/datastruc/PNDArray.hh @@ -33,7 +33,7 @@ namespace PRISMS resize(dim); } - PNDArray(const std::vector &dim, const std::vector &value) + [[nodiscard]] PNDArray(const std::vector &dim, const std::vector &value) { resize(dim); if (_volume != value.size()) @@ -47,13 +47,13 @@ namespace PRISMS _val = value; } - int + [[nodiscard]] int order() const { return _order; } - int + [[nodiscard]] int volume() const { return _volume; @@ -96,13 +96,13 @@ namespace PRISMS _volume = 0; } - const std::vector & + [[nodiscard]] const std::vector & dim() const { return _dim; } - int + [[nodiscard]] int dim(int i) const { return _dim[i]; diff --git a/include/IntegrationTools/pfield/Coordinate.hh b/include/IntegrationTools/pfield/Coordinate.hh index 47ea49402..9fc722d94 100644 --- a/include/IntegrationTools/pfield/Coordinate.hh +++ b/include/IntegrationTools/pfield/Coordinate.hh @@ -16,7 +16,7 @@ namespace PRISMS double _coord[DIM]; public: - int + [[nodiscard]] int size() const { return DIM; diff --git a/include/IntegrationTools/pfield/interpolation/Hexahedron.hh b/include/IntegrationTools/pfield/interpolation/Hexahedron.hh index c87ab3aee..e96dee0c0 100644 --- a/include/IntegrationTools/pfield/interpolation/Hexahedron.hh +++ b/include/IntegrationTools/pfield/interpolation/Hexahedron.hh @@ -12,7 +12,7 @@ namespace PRISMS { class Hexahedron_f : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { // var[0]: coordinate to be evaluated @@ -34,7 +34,7 @@ namespace PRISMS this->_name = "Hexahedron_f"; } - Hexahedron_f * + [[nodiscard]] Hexahedron_f * clone() const override { return new Hexahedron_f(*this); @@ -43,7 +43,7 @@ namespace PRISMS class Hexahedron_grad_0 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return -var[3][0] * (1.0 - var[3][1] * (var[0][1] - var[1][1]) / var[2][1]) * @@ -56,7 +56,7 @@ namespace PRISMS this->_name = "Hexahedron_grad_0"; } - Hexahedron_grad_0 * + [[nodiscard]] Hexahedron_grad_0 * clone() const override { return new Hexahedron_grad_0(*this); @@ -65,7 +65,7 @@ namespace PRISMS class Hexahedron_grad_1 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return -var[3][1] * (1.0 - var[3][0] * (var[0][0] - var[1][0]) / var[2][0]) * @@ -78,7 +78,7 @@ namespace PRISMS this->_name = "Hexahedron_grad_1"; } - Hexahedron_grad_1 * + [[nodiscard]] Hexahedron_grad_1 * clone() const override { return new Hexahedron_grad_1(*this); @@ -87,7 +87,7 @@ namespace PRISMS class Hexahedron_grad_2 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return -var[3][2] * (1.0 - var[3][0] * (var[0][0] - var[1][0]) / var[2][0]) * @@ -100,7 +100,7 @@ namespace PRISMS this->_name = "Hexahedron_grad_2"; } - Hexahedron_grad_2 * + [[nodiscard]] Hexahedron_grad_2 * clone() const override { return new Hexahedron_grad_2(*this); @@ -110,7 +110,7 @@ namespace PRISMS class Hexahedron_hess_0_0 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return 0.0; @@ -122,7 +122,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_0_0"; } - Hexahedron_hess_0_0 * + [[nodiscard]] Hexahedron_hess_0_0 * clone() const override { return new Hexahedron_hess_0_0(*this); @@ -132,7 +132,7 @@ namespace PRISMS class Hexahedron_hess_0_1 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][0] * var[3][1] / var[2][0] / var[2][1]; @@ -144,7 +144,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_0_1"; } - Hexahedron_hess_0_1 * + [[nodiscard]] Hexahedron_hess_0_1 * clone() const override { return new Hexahedron_hess_0_1(*this); @@ -154,7 +154,7 @@ namespace PRISMS class Hexahedron_hess_0_2 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][0] * var[3][2] / var[2][0] / var[2][2]; @@ -166,7 +166,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_0_2"; } - Hexahedron_hess_0_2 * + [[nodiscard]] Hexahedron_hess_0_2 * clone() const override { return new Hexahedron_hess_0_2(*this); @@ -176,7 +176,7 @@ namespace PRISMS class Hexahedron_hess_1_0 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][1] * var[3][0] / var[2][1] / var[2][0]; @@ -188,7 +188,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_1_0"; } - Hexahedron_hess_1_0 * + [[nodiscard]] Hexahedron_hess_1_0 * clone() const override { return new Hexahedron_hess_1_0(*this); @@ -198,7 +198,7 @@ namespace PRISMS class Hexahedron_hess_1_1 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return 0.0; @@ -210,7 +210,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_1_1"; } - Hexahedron_hess_1_1 * + [[nodiscard]] Hexahedron_hess_1_1 * clone() const override { return new Hexahedron_hess_1_1(*this); @@ -220,7 +220,7 @@ namespace PRISMS class Hexahedron_hess_1_2 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][1] * var[3][2] / var[2][1] / var[2][2]; @@ -232,7 +232,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_1_2"; } - Hexahedron_hess_1_2 * + [[nodiscard]] Hexahedron_hess_1_2 * clone() const override { return new Hexahedron_hess_1_2(*this); @@ -242,7 +242,7 @@ namespace PRISMS class Hexahedron_hess_2_0 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][2] * var[3][0] / var[2][2] / var[2][0]; @@ -254,7 +254,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_2_0"; } - Hexahedron_hess_2_0 * + [[nodiscard]] Hexahedron_hess_2_0 * clone() const override { return new Hexahedron_hess_2_0(*this); @@ -264,7 +264,7 @@ namespace PRISMS class Hexahedron_hess_2_1 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][2] * var[3][1] / var[2][2] / var[2][1]; @@ -276,7 +276,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_2_1"; } - Hexahedron_hess_2_1 * + [[nodiscard]] Hexahedron_hess_2_1 * clone() const override { return new Hexahedron_hess_2_1(*this); @@ -286,7 +286,7 @@ namespace PRISMS class Hexahedron_hess_2_2 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return 0.0; @@ -298,7 +298,7 @@ namespace PRISMS this->_name = "Hexahedron_hess_2_2"; } - Hexahedron_hess_2_2 * + [[nodiscard]] Hexahedron_hess_2_2 * clone() const override { return new Hexahedron_hess_2_2(*this); @@ -348,7 +348,7 @@ namespace PRISMS delete[] _hess_val; } - Hexahedron * + [[nodiscard]] Hexahedron * clone() const override { return new Hexahedron(*this); @@ -563,7 +563,7 @@ namespace PRISMS } } - PRISMS::Coordinate<3> + [[nodiscard]] PRISMS::Coordinate<3> min() const override { PRISMS::Coordinate<3> coord = _var[1]; @@ -578,7 +578,7 @@ namespace PRISMS return coord; } - PRISMS::Coordinate<3> + [[nodiscard]] PRISMS::Coordinate<3> max() const override { PRISMS::Coordinate<3> coord = _var[1]; diff --git a/include/IntegrationTools/pfield/interpolation/Quad.hh b/include/IntegrationTools/pfield/interpolation/Quad.hh index bc7ad7349..41a9cb3a6 100644 --- a/include/IntegrationTools/pfield/interpolation/Quad.hh +++ b/include/IntegrationTools/pfield/interpolation/Quad.hh @@ -12,7 +12,7 @@ namespace PRISMS { class Quad_f : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { // var[0]: coordinate to be evaluated @@ -33,7 +33,7 @@ namespace PRISMS this->_name = "Quad_f"; } - Quad_f * + [[nodiscard]] Quad_f * clone() const override { return new Quad_f(*this); @@ -42,7 +42,7 @@ namespace PRISMS class Quad_grad_0 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return -var[3][0] * (1.0 - var[3][1] * (var[0][1] - var[1][1]) / var[2][1]) / @@ -55,7 +55,7 @@ namespace PRISMS this->_name = "Quad_grad_0"; } - Quad_grad_0 * + [[nodiscard]] Quad_grad_0 * clone() const override { return new Quad_grad_0(*this); @@ -64,7 +64,7 @@ namespace PRISMS class Quad_grad_1 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return -var[3][1] * (1.0 - var[3][0] * (var[0][0] - var[1][0]) / var[2][0]) / @@ -77,7 +77,7 @@ namespace PRISMS this->_name = "Quad_grad_1"; } - Quad_grad_1 * + [[nodiscard]] Quad_grad_1 * clone() const override { return new Quad_grad_1(*this); @@ -86,7 +86,7 @@ namespace PRISMS class Quad_hess_0_0 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return 0.0; @@ -98,7 +98,7 @@ namespace PRISMS this->_name = "Quad_hess_0_0"; } - Quad_hess_0_0 * + [[nodiscard]] Quad_hess_0_0 * clone() const override { return new Quad_hess_0_0(*this); @@ -107,7 +107,7 @@ namespace PRISMS class Quad_hess_0_1 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][0] * var[3][1] / var[2][0] / var[2][1]; @@ -119,7 +119,7 @@ namespace PRISMS this->_name = "Quad_hess_0_1"; } - Quad_hess_0_1 * + [[nodiscard]] Quad_hess_0_1 * clone() const override { return new Quad_hess_0_1(*this); @@ -128,7 +128,7 @@ namespace PRISMS class Quad_hess_1_0 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return var[3][0] * var[3][1] / var[2][0] / var[2][1]; @@ -140,7 +140,7 @@ namespace PRISMS this->_name = "Quad_hess_1_0"; } - Quad_hess_1_0 * + [[nodiscard]] Quad_hess_1_0 * clone() const override { return new Quad_hess_1_0(*this); @@ -149,7 +149,7 @@ namespace PRISMS class Quad_hess_1_1 : public PSimpleBase>, double> { - double + [[nodiscard]] double eval(const std::vector> &var) const override { return 0.0; @@ -161,7 +161,7 @@ namespace PRISMS this->_name = "Quad_hess_1_1"; } - Quad_hess_1_1 * + [[nodiscard]] Quad_hess_1_1 * clone() const override { return new Quad_hess_1_1(*this); @@ -206,7 +206,7 @@ namespace PRISMS delete[] _hess_val; } - Quad * + [[nodiscard]] Quad * clone() const override { return new Quad(*this); @@ -396,7 +396,7 @@ namespace PRISMS } } - PRISMS::Coordinate<2> + [[nodiscard]] PRISMS::Coordinate<2> min() const override { PRISMS::Coordinate<2> coord = _var[1]; @@ -409,7 +409,7 @@ namespace PRISMS return coord; } - PRISMS::Coordinate<2> + [[nodiscard]] PRISMS::Coordinate<2> max() const override { PRISMS::Coordinate<2> coord = _var[1]; diff --git a/include/IntegrationTools/pfunction/PFuncBase.hh b/include/IntegrationTools/pfunction/PFuncBase.hh index 50c56e601..92e9ecce2 100644 --- a/include/IntegrationTools/pfunction/PFuncBase.hh +++ b/include/IntegrationTools/pfunction/PFuncBase.hh @@ -44,7 +44,7 @@ namespace PRISMS return _name; } - size_type + [[nodiscard]] size_type size() const { return _var_name.size(); diff --git a/include/IntegrationTools/pfunction/PSimpleBase.hh b/include/IntegrationTools/pfunction/PSimpleBase.hh index 80653265f..da0aebe9b 100644 --- a/include/IntegrationTools/pfunction/PSimpleBase.hh +++ b/include/IntegrationTools/pfunction/PSimpleBase.hh @@ -26,7 +26,7 @@ namespace PRISMS public: virtual ~PSimpleBase() {}; - std::string + [[nodiscard]] std::string name() const { return _name; @@ -56,21 +56,21 @@ namespace PRISMS return new PSimpleBase(*this); } - virtual std::string + [[nodiscard]] virtual std::string csrc() const { undefined("std::string csrc()"); return std::string(); } - virtual std::string + [[nodiscard]] virtual std::string sym() const { undefined("std::string sym()"); return std::string(); } - virtual std::string + [[nodiscard]] virtual std::string latex() const { undefined("std::string latex()"); diff --git a/include/IntegrationTools/pfunction/PSimpleFunction.hh b/include/IntegrationTools/pfunction/PSimpleFunction.hh index efd93227d..a604da73a 100644 --- a/include/IntegrationTools/pfunction/PSimpleFunction.hh +++ b/include/IntegrationTools/pfunction/PSimpleFunction.hh @@ -17,25 +17,25 @@ namespace PRISMS PSimpleBase *ptr; public: - std::string + [[nodiscard]] std::string name() const { return (*ptr).name(); } - std::string + [[nodiscard]] std::string csrc() const { return (*ptr).csrc(); } - std::string + [[nodiscard]] std::string sym() const { return (*ptr).sym(); } - std::string + [[nodiscard]] std::string latex() const { return (*ptr).latex(); diff --git a/include/SimplifiedGrainRepresentation.h b/include/SimplifiedGrainRepresentation.h index 6c3f1ebf6..b1bdbbef6 100644 --- a/include/SimplifiedGrainRepresentation.h +++ b/include/SimplifiedGrainRepresentation.h @@ -25,19 +25,19 @@ class SimplifiedGrainRepresentation /** * Getter for the grain center/centroid. */ - dealii::Point + [[nodiscard]] dealii::Point getCenter() const; /** * Getter for the grain radius. */ - double + [[nodiscard]] double getRadius() const; /** * Getter for the grain id. */ - unsigned int + [[nodiscard]] unsigned int getGrainId() const; /** @@ -49,7 +49,7 @@ class SimplifiedGrainRepresentation /** * Getter for the order parameter id. */ - unsigned int + [[nodiscard]] unsigned int getOrderParameterId() const; /** @@ -62,7 +62,7 @@ class SimplifiedGrainRepresentation * Getter for the old value of the order parameter id (used in the * transferGrainIds method of the SimplifiedGrainManipulator class). */ - unsigned int + [[nodiscard]] unsigned int getOldOrderParameterId() const; /** @@ -76,7 +76,7 @@ class SimplifiedGrainRepresentation * Getter for the distance from this grain to the nearest grain with the same * order parameter */ - double + [[nodiscard]] double getDistanceToNeighbor() const; protected: diff --git a/include/initialConditions.h b/include/initialConditions.h index 0dfb332d3..6bfc35d5a 100644 --- a/include/initialConditions.h +++ b/include/initialConditions.h @@ -31,7 +31,7 @@ class InitialCondition : public dealii::Function } // IC for scalar values - double + [[nodiscard]] double value(const dealii::Point &p, const unsigned int component = 0) const override { double scalar_IC = 0.0; diff --git a/include/inputFileReader.h b/include/inputFileReader.h index 9364c5394..136c012e2 100644 --- a/include/inputFileReader.h +++ b/include/inputFileReader.h @@ -20,21 +20,21 @@ class inputFileReader // Method to get a list of entry values from multiple subsections in an input // file - std::vector + [[nodiscard]] std::vector get_subsection_entry_list(const std::string ¶meters_file_name, const std::string &subsec_name, const std::string &entry_name, const std::string &default_entry) const; // Method to count the number of related entries in an input file - unsigned int + [[nodiscard]] unsigned int get_number_of_entries(const std::string ¶meters_file_name, const std::string &keyword, const std::string &entry_name) const; // Get the trailing part of the entry name after a specified string (used to // extract the model constant names) - std::vector + [[nodiscard]] std::vector get_entry_name_ending_list(const std::string ¶meters_file_name, const std::string &keyword, const std::string &entry_name_begining) const; diff --git a/include/matrixFreePDE.h b/include/matrixFreePDE.h index 27be76f2b..108f513f5 100644 --- a/include/matrixFreePDE.h +++ b/include/matrixFreePDE.h @@ -459,7 +459,7 @@ class MatrixFreePDE : public Subscriptor // Method to obtain the nucleation probability for an element, nontrival case // must be implemented in the subsclass - virtual double + [[nodiscard]] virtual double getNucleationProbability(variableValueContainer, double, Point, diff --git a/include/nonUniformDirichletBC.h b/include/nonUniformDirichletBC.h index a14e3d0f5..af0259c26 100644 --- a/include/nonUniformDirichletBC.h +++ b/include/nonUniformDirichletBC.h @@ -24,7 +24,7 @@ class NonUniformDirichletBC : public dealii::Function } // IC for scalar values - double + [[nodiscard]] double value(const dealii::Point &p, const unsigned int component = 0) const override { double scalar_BC = 0.0; diff --git a/include/userInputParameters.h b/include/userInputParameters.h index 92af67224..a1566c625 100644 --- a/include/userInputParameters.h +++ b/include/userInputParameters.h @@ -61,7 +61,7 @@ class userInputParameters * * \param constant_name Name of the constant to retrieve. */ - double + [[nodiscard]] double get_model_constant_double(const std::string constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), @@ -79,7 +79,7 @@ class userInputParameters * * \param constant_name Name of the constant to retrieve. */ - int + [[nodiscard]] int get_model_constant_int(const std::string constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), @@ -97,7 +97,7 @@ class userInputParameters * * \param constant_name Name of the constant to retrieve. */ - bool + [[nodiscard]] bool get_model_constant_bool(const std::string constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), @@ -115,7 +115,7 @@ class userInputParameters * * \param constant_name Name of the constant to retrieve. */ - dealii::Tensor<1, dim> + [[nodiscard]] dealii::Tensor<1, dim> get_model_constant_rank_1_tensor(const std::string constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), @@ -134,7 +134,7 @@ class userInputParameters * * \param constant_name Name of the constant to retrieve. */ - dealii::Tensor<2, dim> + [[nodiscard]] dealii::Tensor<2, dim> get_model_constant_rank_2_tensor(const std::string constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), @@ -153,7 +153,7 @@ class userInputParameters * * \param constant_name Name of the constant to retrieve. */ - dealii::Tensor<2, 2 * dim - 1 + dim / 3> + [[nodiscard]] dealii::Tensor<2, 2 * dim - 1 + dim / 3> get_model_constant_elasticity_tensor(const std::string constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), @@ -171,35 +171,35 @@ class userInputParameters loadVariableAttributes(variableAttributeLoader variable_attributes); // Nucleation attribute methods - std::vector + [[nodiscard]] std::vector get_nucleus_semiaxes(unsigned int var_index) const { return nucleation_parameters_list[nucleation_parameters_list_index.at(var_index)] .semiaxes; }; - std::vector + [[nodiscard]] std::vector get_nucleus_freeze_semiaxes(unsigned int var_index) const { return nucleation_parameters_list[nucleation_parameters_list_index.at(var_index)] .freeze_semiaxes; }; - std::vector + [[nodiscard]] std::vector get_nucleus_rotation(unsigned int var_index) const { return nucleation_parameters_list[nucleation_parameters_list_index.at(var_index)] .ellipsoid_rotation; }; - double + [[nodiscard]] double get_no_nucleation_border_thickness(unsigned int var_index) const { return nucleation_parameters_list[nucleation_parameters_list_index.at(var_index)] .no_nucleation_border_thickness; }; - double + [[nodiscard]] double get_nucleus_hold_time(unsigned int var_index) const { return nucleation_parameters_list[nucleation_parameters_list_index.at(var_index)] @@ -342,7 +342,7 @@ class userInputParameters load_user_constants(inputFileReader &input_file_reader, dealii::ParameterHandler ¶meter_handler); - dealii::Tensor<2, 2 * dim - 1 + dim / 3> + [[nodiscard]] dealii::Tensor<2, 2 * dim - 1 + dim / 3> get_Cij_tensor(std::vector elastic_constants, const std::string &elastic_const_symmetry) const; diff --git a/src/matrixfree/initialConditions.cc b/src/matrixfree/initialConditions.cc index de534695c..c7b476211 100644 --- a/src/matrixfree/initialConditions.cc +++ b/src/matrixfree/initialConditions.cc @@ -22,7 +22,7 @@ class InitialConditionPField : public Function , inputField(_inputField) {} - double + [[nodiscard]] double value(const Point &p, const unsigned int component = 0) const override { double scalar_IC; From 30f023c0382c667ac68abbe2ca2044bcb3dcae1f Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 21:59:45 -0400 Subject: [PATCH 06/28] using --- include/FloodFiller.h | 2 +- include/IntegrationTools/pfield/PField.hh | 2 +- .../pfield/interpolation/Hexahedron.hh | 2 +- .../pfield/interpolation/Quad.hh | 2 +- .../IntegrationTools/pfunction/PFuncBase.hh | 2 +- include/matrixFreePDE.h | 4 +-- include/typeDefs.h | 26 +++++++++---------- 7 files changed, 20 insertions(+), 20 deletions(-) diff --git a/include/FloodFiller.h b/include/FloodFiller.h index 75e714404..d6ac72efd 100644 --- a/include/FloodFiller.h +++ b/include/FloodFiller.h @@ -12,7 +12,7 @@ #include #ifndef vectorType -typedef dealii::LinearAlgebra::distributed::Vector vectorType; +using vectorType = dealii::LinearAlgebra::distributed::Vector; #endif /** diff --git a/include/IntegrationTools/pfield/PField.hh b/include/IntegrationTools/pfield/PField.hh index 4b9d828dd..f93bec0ca 100644 --- a/include/IntegrationTools/pfield/PField.hh +++ b/include/IntegrationTools/pfield/PField.hh @@ -24,7 +24,7 @@ namespace PRISMS class PField : public PFuncBase { public: - typedef typename PFuncBase::size_type size_type; + using size_type = typename PFuncBase::size_type; // pointer to a Mesh that lives in a Body Mesh *_mesh; diff --git a/include/IntegrationTools/pfield/interpolation/Hexahedron.hh b/include/IntegrationTools/pfield/interpolation/Hexahedron.hh index e96dee0c0..f0345eff1 100644 --- a/include/IntegrationTools/pfield/interpolation/Hexahedron.hh +++ b/include/IntegrationTools/pfield/interpolation/Hexahedron.hh @@ -485,7 +485,7 @@ namespace PRISMS std::vector> _var; public: - typedef typename Interpolator::size_type size_type; + using size_type = typename Interpolator::size_type; // node_index: index of node in mesh // node_index: index of element in mesh diff --git a/include/IntegrationTools/pfield/interpolation/Quad.hh b/include/IntegrationTools/pfield/interpolation/Quad.hh index 41a9cb3a6..a97cda675 100644 --- a/include/IntegrationTools/pfield/interpolation/Quad.hh +++ b/include/IntegrationTools/pfield/interpolation/Quad.hh @@ -336,7 +336,7 @@ namespace PRISMS std::vector> _var; public: - typedef typename Interpolator::size_type size_type; + using size_type = typename Interpolator::size_type; // node_index: index of node in mesh // node_index: index of element in mesh diff --git a/include/IntegrationTools/pfunction/PFuncBase.hh b/include/IntegrationTools/pfunction/PFuncBase.hh index 92e9ecce2..58b2d30f4 100644 --- a/include/IntegrationTools/pfunction/PFuncBase.hh +++ b/include/IntegrationTools/pfunction/PFuncBase.hh @@ -22,7 +22,7 @@ namespace PRISMS std::vector _var_description; public: - typedef std::vector::size_type size_type; + using size_type = std::vector::size_type; PFuncBase() {} diff --git a/include/matrixFreePDE.h b/include/matrixFreePDE.h index 108f513f5..c844f8dd2 100644 --- a/include/matrixFreePDE.h +++ b/include/matrixFreePDE.h @@ -49,10 +49,10 @@ using namespace dealii; // define data types #ifndef scalarType -typedef VectorizedArray scalarType; +using scalarType = VectorizedArray; #endif #ifndef vectorType -typedef LinearAlgebra::distributed::Vector vectorType; +using vectorType = LinearAlgebra::distributed::Vector; #endif // macro for constants diff --git a/include/typeDefs.h b/include/typeDefs.h index ea59d1867..547fe3c67 100644 --- a/include/typeDefs.h +++ b/include/typeDefs.h @@ -33,47 +33,47 @@ // define data types #ifndef scalarType -typedef dealii::VectorizedArray scalarType; +using scalarType = dealii::VectorizedArray; #endif #ifndef vectorType -typedef dealii::LinearAlgebra::distributed::Vector vectorType; +using vectorType = dealii::LinearAlgebra::distributed::Vector; #endif // define FE system types #ifndef typeScalar -typedef dealii::FEEvaluation typeScalar; +using typeScalar = dealii::FEEvaluation; #endif #ifndef typeVector -typedef dealii::FEEvaluation typeVector; +using typeVector = dealii::FEEvaluation; #endif // define data value types #ifndef scalarvalueType -typedef dealii::VectorizedArray scalarvalueType; +using scalarvalueType = dealii::VectorizedArray; #endif #ifndef vectorvalueType -typedef dealii::Tensor<1, dim, dealii::VectorizedArray> vectorvalueType; +using vectorvalueType = dealii::Tensor<1, dim, dealii::VectorizedArray>; #endif #if problemDIM == 1 # ifndef scalargradType -typedef dealii::VectorizedArray scalargradType; +using scalargradType = dealii::VectorizedArray; # endif # ifndef vectorgradType -typedef dealii::VectorizedArray vectorgradType; +using vectorgradType = dealii::VectorizedArray; # endif # ifndef vectorhessType -typedef dealii::VectorizedArray vectorhessType; +using vectorhessType = dealii::VectorizedArray; # endif #else # ifndef scalargradType -typedef dealii::Tensor<1, dim, dealii::VectorizedArray> scalargradType; +using scalargradType = dealii::Tensor<1, dim, dealii::VectorizedArray>; # endif # ifndef scalarhessType -typedef dealii::Tensor<2, dim, dealii::VectorizedArray> scalarhessType; +using scalarhessType = dealii::Tensor<2, dim, dealii::VectorizedArray>; # endif # ifndef vectorgradType -typedef dealii::Tensor<2, dim, dealii::VectorizedArray> vectorgradType; +using vectorgradType = dealii::Tensor<2, dim, dealii::VectorizedArray>; # endif # ifndef vectorhessType -typedef dealii::Tensor<3, dim, dealii::VectorizedArray> vectorhessType; +using vectorhessType = dealii::Tensor<3, dim, dealii::VectorizedArray>; # endif #endif From 9307c76fba0a5d8a0c247a011e00d80626f2e069 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 22:13:14 -0400 Subject: [PATCH 07/28] adding braces --- include/IntegrationTools/datastruc/Bin.hh | 12 +++- include/IntegrationTools/pfield/Coordinate.hh | 4 +- include/IntegrationTools/pfield/Mesh.hh | 8 ++- include/IntegrationTools/pfield/PField.hh | 12 +++- .../pfield/interpolation/Hexahedron.hh | 4 +- .../pfield/interpolation/Quad.hh | 4 +- .../pfunction/PSimpleFunction.hh | 24 +++++-- src/inputFileReader/inputFileReader.cc | 68 ++++++++++++++----- 8 files changed, 102 insertions(+), 34 deletions(-) diff --git a/include/IntegrationTools/datastruc/Bin.hh b/include/IntegrationTools/datastruc/Bin.hh index 06a5e4d7b..ac1c1137a 100644 --- a/include/IntegrationTools/datastruc/Bin.hh +++ b/include/IntegrationTools/datastruc/Bin.hh @@ -89,7 +89,9 @@ namespace PRISMS for (int i = 0; i < singlebin.size(); i++) { if (singlebin[i] == newitem) - return; + { + return; + } } singlebin.push_back(newitem); @@ -171,8 +173,12 @@ namespace PRISMS { unsigned int max = 0; for (int i = 0; i < _item.volume(); i++) - if (_item(i).size() > max) - max = _item(i).size(); + { + if (_item(i).size() > max) + { + max = _item(i).size(); + } + } return max; } diff --git a/include/IntegrationTools/pfield/Coordinate.hh b/include/IntegrationTools/pfield/Coordinate.hh index 9fc722d94..ce5f04cd5 100644 --- a/include/IntegrationTools/pfield/Coordinate.hh +++ b/include/IntegrationTools/pfield/Coordinate.hh @@ -47,7 +47,9 @@ namespace PRISMS { outstream << coord[i]; if (i < coord.size() - 1) - outstream << " "; + { + outstream << " "; + } } return outstream; } diff --git a/include/IntegrationTools/pfield/Mesh.hh b/include/IntegrationTools/pfield/Mesh.hh index a66d62d83..00f4ae80d 100644 --- a/include/IntegrationTools/pfield/Mesh.hh +++ b/include/IntegrationTools/pfield/Mesh.hh @@ -661,14 +661,18 @@ namespace PRISMS min(Coordinate &coord) { for (int i = 0; i < DIM; i++) - coord[i] = _min[i]; + { + coord[i] = _min[i]; + } } void max(Coordinate &coord) { for (int i = 0; i < DIM; i++) - coord[i] = _max[i]; + { + coord[i] = _max[i]; + } } double diff --git a/include/IntegrationTools/pfield/PField.hh b/include/IntegrationTools/pfield/PField.hh index f93bec0ca..6026cdd7e 100644 --- a/include/IntegrationTools/pfield/PField.hh +++ b/include/IntegrationTools/pfield/PField.hh @@ -178,7 +178,9 @@ namespace PRISMS PField::eval_grad(const Coordinate &coord) { for (int di = 0; di < DIM; di++) - (*this).grad(coord, di); + { + (*this).grad(coord, di); + } } template @@ -186,8 +188,12 @@ namespace PRISMS PField::eval_hess(const Coordinate &coord) { for (int di = 0; di < DIM; di++) - for (int dj = 0; dj < DIM; dj++) - (*this).hess(coord, di, dj); + { + for (int dj = 0; dj < DIM; dj++) + { + (*this).hess(coord, di, dj); + } + } } template diff --git a/include/IntegrationTools/pfield/interpolation/Hexahedron.hh b/include/IntegrationTools/pfield/interpolation/Hexahedron.hh index f0345eff1..dc0067fce 100644 --- a/include/IntegrationTools/pfield/interpolation/Hexahedron.hh +++ b/include/IntegrationTools/pfield/interpolation/Hexahedron.hh @@ -605,7 +605,9 @@ namespace PRISMS { e = _var[3][i] * (_var[0][i] - _var[1][i]) / _var[2][i]; if (e < 0.0 || e >= 1.0) - return false; + { + return false; + } // if( e == 0.0 && std::signbit(e)) // return false; diff --git a/include/IntegrationTools/pfield/interpolation/Quad.hh b/include/IntegrationTools/pfield/interpolation/Quad.hh index a97cda675..635b2d8ec 100644 --- a/include/IntegrationTools/pfield/interpolation/Quad.hh +++ b/include/IntegrationTools/pfield/interpolation/Quad.hh @@ -433,7 +433,9 @@ namespace PRISMS { e = _var[3][i] * (_var[0][i] - _var[1][i]) / _var[2][i]; if (e < 0.0 || e >= 1.0) - return false; + { + return false; + } // if( e == 0.0 && std::signbit(e)) // return false; diff --git a/include/IntegrationTools/pfunction/PSimpleFunction.hh b/include/IntegrationTools/pfunction/PSimpleFunction.hh index a604da73a..35d7cc6b2 100644 --- a/include/IntegrationTools/pfunction/PSimpleFunction.hh +++ b/include/IntegrationTools/pfunction/PSimpleFunction.hh @@ -70,7 +70,9 @@ namespace PRISMS operator=(const PSimpleFunction &RHS) { if (ptr != NULL) - delete ptr; + { + delete ptr; + } ptr = RHS.ptr->clone(); return *this; } @@ -82,7 +84,9 @@ namespace PRISMS RHS.is_derived_from_PSimpleBase(); if (ptr != NULL) - delete ptr; + { + delete ptr; + } ptr = RHS.clone(); return *this; } @@ -98,7 +102,9 @@ namespace PRISMS exit(1); } if (ptr != NULL) - delete ptr; + { + delete ptr; + } ptr = RHS; return *this; } @@ -111,9 +117,13 @@ namespace PRISMS PSimpleFunction(const PSimpleFunction &RHS) { if (RHS.ptr != NULL) - ptr = RHS.ptr->clone(); + { + ptr = RHS.ptr->clone(); + } else - ptr = NULL; + { + ptr = NULL; + } } template @@ -127,7 +137,9 @@ namespace PRISMS ~PSimpleFunction() { if (ptr != NULL) - delete ptr; + { + delete ptr; + } } }; diff --git a/src/inputFileReader/inputFileReader.cc b/src/inputFileReader/inputFileReader.cc index 5290efbeb..2e7cb3a66 100644 --- a/src/inputFileReader/inputFileReader.cc +++ b/src/inputFileReader/inputFileReader.cc @@ -62,63 +62,89 @@ inputFileReader::parse_line(std::string line, { // Strip spaces at the front and back while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) - line.erase(0, 1); + { + line.erase(0, 1); + } while ((line.size() > 0) && (line[line.size() - 1] == ' ' || line[line.size() - 1] == '\t')) - line.erase(line.size() - 1, std::string::npos); + { + line.erase(line.size() - 1, std::string::npos); + } // now see whether the line starts with 'keyword' followed by multiple spaces // if not, try next line (if the entry is "", then zero spaces after the // keyword is ok) if (line.size() < keyword.size()) - return false; + { + return false; + } for (unsigned int i = 0; i < keyword.size(); i++) { if (line[i] != keyword[i]) - return false; + { + return false; + } } if (entry_name.size() > 0) { if (!(line[keyword.size()] == ' ' || line[keyword.size()] == '\t')) - return false; + { + return false; + } } // delete the "keyword" and then delete more spaces if present line.erase(0, keyword.size()); while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) - line.erase(0, 1); + { + line.erase(0, 1); + } // now see whether the next word is the word we look for if (line.find(entry_name) != 0) - return false; + { + return false; + } line.erase(0, entry_name.size()); while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) - line.erase(0, 1); + { + line.erase(0, 1); + } // we'd expect an equals size here if expect_equals_sign is true if (expect_equals_sign) { if ((line.size() < 1) || (line[0] != '=')) - return false; + { + return false; + } } // remove comment std::string::size_type pos = line.find('#'); if (pos != std::string::npos) - line.erase(pos); + { + line.erase(pos); + } // trim the equals sign at the beginning and possibly following spaces // as well as spaces at the end if (expect_equals_sign) - line.erase(0, 1); + { + line.erase(0, 1); + } while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) - line.erase(0, 1); + { + line.erase(0, 1); + } while ((line.size() > 0) && (line[line.size() - 1] == ' ' || line[line.size() - 1] == '\t')) - line.erase(line.size() - 1, std::string::npos); + { + line.erase(line.size() - 1, std::string::npos); + } out_string = line; return true; @@ -218,7 +244,9 @@ inputFileReader::get_number_of_entries(const std::string ¶meters_file_name, { found_entry = parse_line(line, keyword, entry_name, entry, false); if (found_entry) - count++; + { + count++; + } } return count; } @@ -249,11 +277,15 @@ inputFileReader::get_entry_name_ending_list(const std::string ¶meters_file_n // Strip whitespace at the beginning while ((entry.size() > 0) && (entry[0] == ' ' || entry[0] == '\t')) - entry.erase(0, 1); + { + entry.erase(0, 1); + } // Strip everything up to the equals sign while ((entry.size() > 0) && (entry[entry.size() - 1] != '=')) - entry.erase(entry.size() - 1, std::string::npos); + { + entry.erase(entry.size() - 1, std::string::npos); + } // Strip the equals sign entry.erase(entry.size() - 1, std::string::npos); @@ -261,7 +293,9 @@ inputFileReader::get_entry_name_ending_list(const std::string ¶meters_file_n // Strip whitespace between the entry name and the equals sign while ((entry.size() > 0) && (entry[entry.size() - 1] == ' ' || entry[entry.size() - 1] == '\t')) - entry.erase(entry.size() - 1, std::string::npos); + { + entry.erase(entry.size() - 1, std::string::npos); + } // Add it to the list entry_name_end_list.push_back(entry); From 09526dc5c5c12e60388cadd21fb3922ae617a6f2 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Wed, 23 Oct 2024 23:06:52 -0400 Subject: [PATCH 08/28] fixing some sort variable names --- include/FloodFiller.h | 10 ++-- include/RefinementCriterion.h | 24 ++++---- include/SimplifiedGrainRepresentation.h | 4 +- src/FloodFiller/FloodFiller.cc | 59 ++++++++++--------- .../SimplifiedGrainRepresentation.cc | 36 +++++------ 5 files changed, 67 insertions(+), 66 deletions(-) diff --git a/include/FloodFiller.h b/include/FloodFiller.h index d6ac72efd..a368bbf9c 100644 --- a/include/FloodFiller.h +++ b/include/FloodFiller.h @@ -111,16 +111,14 @@ class FloodFiller : quadrature(_quadrature) , num_quad_points(_quadrature.size()) , dofs_per_cell(_fe.dofs_per_cell) - { - fe = &_fe; - }; + , fe(&_fe) {}; /** * The primary external interface. This method takes in information about the * mesh/field and outputs a vector of GrainSet objects. */ void - calcGrainSets(dealii::FESystem &fe, + calcGrainSets(dealii::FESystem &finite_element, dealii::DoFHandler &dof_handler, vectorType *solution_field, double threshold_lower, @@ -135,8 +133,8 @@ class FloodFiller */ template void - recursiveFloodFill(T di, - T di_end, + recursiveFloodFill(T cell, + T cell_end, vectorType *solution_field, double threshold_lower, double threshold_upper, diff --git a/include/RefinementCriterion.h b/include/RefinementCriterion.h index 2979581b6..ec4d098cd 100644 --- a/include/RefinementCriterion.h +++ b/include/RefinementCriterion.h @@ -10,34 +10,34 @@ enum RefinementCriterionFlags // Function that enables bitwise OR between flags inline RefinementCriterionFlags -operator|(const RefinementCriterionFlags f1, const RefinementCriterionFlags f2) +operator|(const RefinementCriterionFlags flag_1, const RefinementCriterionFlags flag_2) { - return static_cast(static_cast(f1) | - static_cast(f2)); + return static_cast(static_cast(flag_1) | + static_cast(flag_2)); } // Function that enables bitwise compound OR between flags inline RefinementCriterionFlags & -operator|=(RefinementCriterionFlags &f1, const RefinementCriterionFlags f2) +operator|=(RefinementCriterionFlags &flag_1, const RefinementCriterionFlags flag_2) { - f1 = f1 | f2; - return f1; + flag_1 = flag_1 | flag_2; + return flag_1; } // Function that enables bitwise AND between flags inline RefinementCriterionFlags -operator&(const RefinementCriterionFlags f1, const RefinementCriterionFlags f2) +operator&(const RefinementCriterionFlags flag_1, const RefinementCriterionFlags flag_2) { - return static_cast(static_cast(f1) & - static_cast(f2)); + return static_cast(static_cast(flag_1) & + static_cast(flag_2)); } // Function that enables bitwise compound AND between flags inline RefinementCriterionFlags & -operator&=(RefinementCriterionFlags &f1, const RefinementCriterionFlags f2) +operator&=(RefinementCriterionFlags &flag_1, const RefinementCriterionFlags flag_2) { - f1 = f1 & f2; - return f1; + flag_1 = flag_1 & flag_2; + return flag_1; } /** diff --git a/include/SimplifiedGrainRepresentation.h b/include/SimplifiedGrainRepresentation.h index b1bdbbef6..cea6c76cd 100644 --- a/include/SimplifiedGrainRepresentation.h +++ b/include/SimplifiedGrainRepresentation.h @@ -44,7 +44,7 @@ class SimplifiedGrainRepresentation * Setter for the grain id. */ void - setGrainId(unsigned int id); + setGrainId(unsigned int _grain_id); /** * Getter for the order parameter id. @@ -56,7 +56,7 @@ class SimplifiedGrainRepresentation * Setter for the order parameter id. */ void - setOrderParameterId(unsigned int id); + setOrderParameterId(unsigned int _order_parameter_id); /** * Getter for the old value of the order parameter id (used in the diff --git a/src/FloodFiller/FloodFiller.cc b/src/FloodFiller/FloodFiller.cc index f292fc66d..5a277c11c 100644 --- a/src/FloodFiller/FloodFiller.cc +++ b/src/FloodFiller/FloodFiller.cc @@ -4,7 +4,7 @@ template void -FloodFiller::calcGrainSets(dealii::FESystem &fe, +FloodFiller::calcGrainSets(dealii::FESystem &finite_element, dealii::DoFHandler &dof_handler, vectorType *solution_field, double threshold_lower, @@ -17,11 +17,11 @@ FloodFiller::calcGrainSets(dealii::FESystem &fe, // Loop through the whole mesh and set the user flags to false (so everything // is considered unmarked) - typename dealii::DoFHandler::cell_iterator di = dof_handler.begin(); - while (di != dof_handler.end()) + typename dealii::DoFHandler::cell_iterator cell = dof_handler.begin(); + while (cell != dof_handler.end()) { - di->clear_user_flag(); - ++di; + cell->clear_user_flag(); + ++cell; } GrainSet grain_set; @@ -29,14 +29,14 @@ FloodFiller::calcGrainSets(dealii::FESystem &fe, grain_sets.back().setOrderParameterIndex(order_parameter_index); // The flood fill loop - di = dof_handler.begin(); - while (di != dof_handler.end()) + cell = dof_handler.begin(); + while (cell != dof_handler.end()) { - if (!di->has_children()) + if (!cell->has_children()) { bool grain_assigned = false; recursiveFloodFill::cell_iterator>( - di, + cell, dof_handler.end(), solution_field, threshold_lower, @@ -56,7 +56,7 @@ FloodFiller::calcGrainSets(dealii::FESystem &fe, } } - ++di; + ++cell; } // If the last grain was initialized but empty, delete it @@ -79,8 +79,8 @@ FloodFiller::calcGrainSets(dealii::FESystem &fe, template template void -FloodFiller::recursiveFloodFill(T di, - T di_end, +FloodFiller::recursiveFloodFill(T cell, + T cell_end, vectorType *solution_field, double threshold_lower, double threshold_upper, @@ -89,20 +89,20 @@ FloodFiller::recursiveFloodFill(T di, std::vector> &grain_sets, bool &grain_assigned) { - if (di != di_end) + if (cell != cell_end) { // Check if the cell has been marked yet - bool cellMarked = di->user_flag_set(); + bool cellMarked = cell->user_flag_set(); if (!cellMarked) { - if (di->has_children()) + if (cell->has_children()) { // Call recursiveFloodFill on the element's children - for (unsigned int n = 0; n < di->n_children(); n++) + for (unsigned int n_child = 0; n_child < cell->n_children(); n_child++) { - recursiveFloodFill(di->child(n), - di_end, + recursiveFloodFill(cell->child(n_child), + cell_end, solution_field, threshold_lower, threshold_upper, @@ -114,16 +114,17 @@ FloodFiller::recursiveFloodFill(T di, } else { - if (di->is_locally_owned()) + if (cell->is_locally_owned()) { - di->set_user_flag(); + cell->set_user_flag(); dealii::FEValues fe_values(*fe, quadrature, dealii::update_values); - std::vector var_values(num_quad_points); + + std::vector var_values(num_quad_points); std::vector> q_point_list(num_quad_points); // Get the most common value for the element - fe_values.reinit(di); + fe_values.reinit(cell); fe_values.get_function_values(*solution_field, var_values); double ele_val; @@ -151,19 +152,19 @@ FloodFiller::recursiveFloodFill(T di, grain_assigned = true; std::vector> vertex_list; - for (unsigned int v = 0; - v < dealii::Utilities::fixed_power(2.0); - v++) + for (unsigned int vertex_index = 0; + vertex_index < dealii::Utilities::fixed_power(2.0); + vertex_index++) { - vertex_list.push_back(di->vertex(v)); + vertex_list.push_back(cell->vertex(vertex_index)); } grain_sets.back().addVertexList(vertex_list); // Call recursiveFloodFill on the element's neighbors - for (unsigned int n = 0; n < 2 * dim; n++) + for (unsigned int n_child = 0; n_child < 2 * dim; n_child++) { - recursiveFloodFill(di->neighbor(n), - di_end, + recursiveFloodFill(cell->neighbor(n_child), + cell_end, solution_field, threshold_lower, threshold_upper, diff --git a/src/SimplifiedGrainRepresentation/SimplifiedGrainRepresentation.cc b/src/SimplifiedGrainRepresentation/SimplifiedGrainRepresentation.cc index 67c49d2df..f3f7a76d3 100644 --- a/src/SimplifiedGrainRepresentation/SimplifiedGrainRepresentation.cc +++ b/src/SimplifiedGrainRepresentation/SimplifiedGrainRepresentation.cc @@ -20,7 +20,7 @@ SimplifiedGrainRepresentation::SimplifiedGrainRepresentation( double grain_volume = 0.0; dealii::Tensor<1, dim> centroid; - for (unsigned int c = 0; c < vertex_list.size(); c++) + for (auto &vertex : vertex_list) { double cell_volume = 1.0; dealii::Point cell_center; @@ -35,17 +35,17 @@ SimplifiedGrainRepresentation::SimplifiedGrainRepresentation( opposite_corner_index = 7; } - for (unsigned int d = 0; d < dim; d++) + for (unsigned int dimension = 0; dimension < dim; dimension++) { cell_volume *= - (vertex_list.at(c)[opposite_corner_index][d] - vertex_list.at(c)[0][d]); - cell_center(d) = - (vertex_list.at(c)[opposite_corner_index][d] + vertex_list.at(c)[0][d]) / 2.0; + (vertex[opposite_corner_index][dimension] - vertex[0][dimension]); + cell_center(dimension) = + (vertex[opposite_corner_index][dimension] + vertex[0][dimension]) / 2.0; } - for (unsigned int d = 0; d < dim; d++) + for (unsigned int dimension = 0; dimension < dim; dimension++) { - centroid[d] += cell_volume * cell_center(d); + centroid[dimension] += cell_volume * cell_center(dimension); } grain_volume += cell_volume; @@ -53,21 +53,23 @@ SimplifiedGrainRepresentation::SimplifiedGrainRepresentation( centroid /= grain_volume; - for (unsigned int d = 0; d < dim; d++) + for (unsigned int dimension = 0; dimension < dim; dimension++) { - center(d) = centroid[d]; + center(dimension) = centroid[dimension]; } // Calculate the radius as the largest distance from the centroid to one of // the vertices radius = 0.0; - for (unsigned int c = 0; c < vertex_list.size(); c++) + for (auto &vertex : vertex_list) { - for (unsigned int v = 0; v < dealii::Utilities::fixed_power(2.0); v++) + for (unsigned int vertex_index = 0; + vertex_index < dealii::Utilities::fixed_power(2.0); + vertex_index++) { - if (vertex_list[c][v].distance(center) > radius) + if (vertex[vertex_index].distance(center) > radius) { - radius = vertex_list[c][v].distance(center); + radius = vertex[vertex_index].distance(center); } } } @@ -96,9 +98,9 @@ SimplifiedGrainRepresentation::getGrainId() const template void -SimplifiedGrainRepresentation::setGrainId(unsigned int id) +SimplifiedGrainRepresentation::setGrainId(unsigned int _grain_id) { - grain_id = id; + grain_id = _grain_id; } template @@ -110,9 +112,9 @@ SimplifiedGrainRepresentation::getOrderParameterId() const template void -SimplifiedGrainRepresentation::setOrderParameterId(unsigned int id) +SimplifiedGrainRepresentation::setOrderParameterId(unsigned int _order_parameter_id) { - order_parameter_id = id; + order_parameter_id = _order_parameter_id; } template From e5a06fc7597fe409af9e4d1d11746c89e86c856d Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Thu, 24 Oct 2024 10:42:48 -0400 Subject: [PATCH 09/28] removing applications and tests --- utilities/clang_tidy.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/utilities/clang_tidy.sh b/utilities/clang_tidy.sh index 63e2d896e..e08da4865 100755 --- a/utilities/clang_tidy.sh +++ b/utilities/clang_tidy.sh @@ -32,7 +32,7 @@ CC=clang CXX=clang++ cmake "${arguments[@]}" "$dir" || (echo "cmake failed!"; fa cmake --build . || (echo "make failed!"; false) || exit 3 # Run clang-tidy -run-clang-tidy -p . -quiet -header-filter "$dir/include/*" "$dir/src/*" "$dir/tests/*" "$dir/applications/*" 2>error.txt >output.txt +run-clang-tidy -p . -quiet -header-filter "$dir/include/*" "$dir/src/*" 2>error.txt >output.txt # Remove duplicates & log them grep -E '(warning|error): ' output.txt | sort | uniq > clang-tidy.log From db21b3c49d9eb31e2837bfcef43fc6b38c2e7bef Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Thu, 24 Oct 2024 10:56:57 -0400 Subject: [PATCH 10/28] exclude integrationtools --- utilities/clang_tidy.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/utilities/clang_tidy.sh b/utilities/clang_tidy.sh index e08da4865..a185883ee 100755 --- a/utilities/clang_tidy.sh +++ b/utilities/clang_tidy.sh @@ -32,7 +32,7 @@ CC=clang CXX=clang++ cmake "${arguments[@]}" "$dir" || (echo "cmake failed!"; fa cmake --build . || (echo "make failed!"; false) || exit 3 # Run clang-tidy -run-clang-tidy -p . -quiet -header-filter "$dir/include/*" "$dir/src/*" 2>error.txt >output.txt +run-clang-tidy -p . -quiet -header-filter "$dir/include/(?!IntegrationTools).*" "$dir/src/*" 2>error.txt >output.txt # Remove duplicates & log them grep -E '(warning|error): ' output.txt | sort | uniq > clang-tidy.log From 86937d3cb0f4e954bcc0318955186d4f84b533c5 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 28 Oct 2024 15:18:35 -0400 Subject: [PATCH 11/28] delete template class header --- include/matrixFreePDE.h | 18 ++++++++++ .../matrixFreePDE_template_instantiations.h | 33 ------------------- src/matrixfree/boundaryConditions.cc | 2 -- src/matrixfree/buildFields.cc | 2 -- src/matrixfree/checkpoint.cc | 2 -- src/matrixfree/computeIntegral.cc | 2 -- src/matrixfree/computeLHS.cc | 2 -- src/matrixfree/computeRHS.cc | 2 -- src/matrixfree/init.cc | 2 -- src/matrixfree/initForTests.cc | 2 -- src/matrixfree/initialConditions.cc | 2 -- src/matrixfree/invM.cc | 2 -- src/matrixfree/markBoundaries.cc | 2 -- src/matrixfree/matrixFreePDE.cc | 2 -- src/matrixfree/nucleation.cc | 3 -- src/matrixfree/outputResults.cc | 2 -- src/matrixfree/postprocessor.cc | 2 -- src/matrixfree/reassignGrains.cc | 2 -- src/matrixfree/reinit.cc | 2 -- src/matrixfree/setNonlinearEqInitialGuess.cc | 2 -- src/matrixfree/solve.cc | 2 -- src/matrixfree/solveIncrement.cc | 4 +-- src/matrixfree/utilities.cc | 2 -- 23 files changed, 19 insertions(+), 77 deletions(-) delete mode 100644 include/matrixFreePDE_template_instantiations.h diff --git a/include/matrixFreePDE.h b/include/matrixFreePDE.h index c844f8dd2..dae7521b7 100644 --- a/include/matrixFreePDE.h +++ b/include/matrixFreePDE.h @@ -512,4 +512,22 @@ class MatrixFreePDE : public Subscriptor AdaptiveRefinement AMR; }; +template class MatrixFreePDE<2, 1>; +template class MatrixFreePDE<3, 1>; + +template class MatrixFreePDE<2, 2>; +template class MatrixFreePDE<3, 2>; + +template class MatrixFreePDE<3, 3>; +template class MatrixFreePDE<2, 3>; + +template class MatrixFreePDE<3, 4>; +template class MatrixFreePDE<2, 4>; + +template class MatrixFreePDE<3, 5>; +template class MatrixFreePDE<2, 5>; + +template class MatrixFreePDE<3, 6>; +template class MatrixFreePDE<2, 6>; + #endif diff --git a/include/matrixFreePDE_template_instantiations.h b/include/matrixFreePDE_template_instantiations.h deleted file mode 100644 index 05789f31b..000000000 --- a/include/matrixFreePDE_template_instantiations.h +++ /dev/null @@ -1,33 +0,0 @@ -/* - * matrixFreePDE_template_instantiations.h - * - * Created on: Feb 28, 2017 - * Author: stephendewitt - */ - -#ifndef INCLUDE_MATRIXFREEPDE_TEMPLATE_INSTANTIATIONS_H_ -#define INCLUDE_MATRIXFREEPDE_TEMPLATE_INSTANTIATIONS_H_ - -#ifndef MATRIXFREEPDE_TEMPLATE_INSTANTIATION -# define MATRIXFREEPDE_TEMPLATE_INSTANTIATION - -template class MatrixFreePDE<2, 1>; -template class MatrixFreePDE<3, 1>; - -template class MatrixFreePDE<2, 2>; -template class MatrixFreePDE<3, 2>; - -template class MatrixFreePDE<3, 3>; -template class MatrixFreePDE<2, 3>; - -template class MatrixFreePDE<3, 4>; -template class MatrixFreePDE<2, 4>; - -template class MatrixFreePDE<3, 5>; -template class MatrixFreePDE<2, 5>; - -template class MatrixFreePDE<3, 6>; -template class MatrixFreePDE<2, 6>; -#endif - -#endif /* INCLUDE_MATRIXFREEPDE_TEMPLATE_INSTANTIATIONS_H_ */ diff --git a/src/matrixfree/boundaryConditions.cc b/src/matrixfree/boundaryConditions.cc index 8053e41dd..743a61b2b 100644 --- a/src/matrixfree/boundaryConditions.cc +++ b/src/matrixfree/boundaryConditions.cc @@ -316,5 +316,3 @@ MatrixFreePDE::set_rigid_body_mode_constraints( } } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/buildFields.cc b/src/matrixfree/buildFields.cc index 041110307..b4ef8181c 100644 --- a/src/matrixfree/buildFields.cc +++ b/src/matrixfree/buildFields.cc @@ -23,5 +23,3 @@ MatrixFreePDE::buildFields() userInputs.var_name[i])); } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/checkpoint.cc b/src/matrixfree/checkpoint.cc index 827a57127..9dc0ad239 100644 --- a/src/matrixfree/checkpoint.cc +++ b/src/matrixfree/checkpoint.cc @@ -254,5 +254,3 @@ MatrixFreePDE::verify_checkpoint_file_exists(const std::string &fil filename + "> does not appear to exist!")); } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/computeIntegral.cc b/src/matrixfree/computeIntegral.cc index 398eb898e..c4d06e1c1 100644 --- a/src/matrixfree/computeIntegral.cc +++ b/src/matrixfree/computeIntegral.cc @@ -44,5 +44,3 @@ MatrixFreePDE::computeIntegral(double &integrated integratedField = value; } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/computeLHS.cc b/src/matrixfree/computeLHS.cc index d975e560b..a335cb794 100644 --- a/src/matrixfree/computeLHS.cc +++ b/src/matrixfree/computeLHS.cc @@ -88,5 +88,3 @@ MatrixFreePDE::getLHS( currentFieldIndex); } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/computeRHS.cc b/src/matrixfree/computeRHS.cc index 8b0cd96c6..1afe08c4e 100644 --- a/src/matrixfree/computeRHS.cc +++ b/src/matrixfree/computeRHS.cc @@ -116,5 +116,3 @@ MatrixFreePDE::getNonexplicitRHS( variable_list.integrate_and_distribute(dst); } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/init.cc b/src/matrixfree/init.cc index 58d4342d9..f12121930 100644 --- a/src/matrixfree/init.cc +++ b/src/matrixfree/init.cc @@ -452,5 +452,3 @@ MatrixFreePDE::compute_element_volume() } } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/initForTests.cc b/src/matrixfree/initForTests.cc index 6c75dbfb7..d58bb8da7 100644 --- a/src/matrixfree/initForTests.cc +++ b/src/matrixfree/initForTests.cc @@ -113,5 +113,3 @@ MatrixFreePDE::initForTests(std::vector> fields) *U = 0; } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/initialConditions.cc b/src/matrixfree/initialConditions.cc index c7b476211..cab1c2c17 100644 --- a/src/matrixfree/initialConditions.cc +++ b/src/matrixfree/initialConditions.cc @@ -438,5 +438,3 @@ MatrixFreePDE::applyInitialConditions() // vector_IC = inputField(coord); // } //}; - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/invM.cc b/src/matrixfree/invM.cc index bd39ab70a..14efc9471 100644 --- a/src/matrixfree/invM.cc +++ b/src/matrixfree/invM.cc @@ -169,5 +169,3 @@ MatrixFreePDE::computeInvM() pcout << "computed vector mass matrix (using FE space for field: " << parabolicVectorFieldIndex << ")\n"; } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/markBoundaries.cc b/src/matrixfree/markBoundaries.cc index 06bff54b7..cde2d19be 100644 --- a/src/matrixfree/markBoundaries.cc +++ b/src/matrixfree/markBoundaries.cc @@ -31,5 +31,3 @@ MatrixFreePDE::markBoundaries( } } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/matrixFreePDE.cc b/src/matrixfree/matrixFreePDE.cc index 6fa9c7708..3a23d11a4 100644 --- a/src/matrixfree/matrixFreePDE.cc +++ b/src/matrixfree/matrixFreePDE.cc @@ -70,5 +70,3 @@ MatrixFreePDE::~MatrixFreePDE() delete residual; } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/nucleation.cc b/src/matrixfree/nucleation.cc index c1972bf31..53ed9b214 100644 --- a/src/matrixfree/nucleation.cc +++ b/src/matrixfree/nucleation.cc @@ -566,6 +566,3 @@ MatrixFreePDE::weightedDistanceFromNucleusCenter( } return weighted_dist; } - -// Template instantiations -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/outputResults.cc b/src/matrixfree/outputResults.cc index aac7d1078..87904c4bd 100644 --- a/src/matrixfree/outputResults.cc +++ b/src/matrixfree/outputResults.cc @@ -251,5 +251,3 @@ MatrixFreePDE::outputResults() // log time computing_timer.leave_subsection("matrixFreePDE: output"); } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/postprocessor.cc b/src/matrixfree/postprocessor.cc index 06fa05f05..dc012e1d8 100644 --- a/src/matrixfree/postprocessor.cc +++ b/src/matrixfree/postprocessor.cc @@ -75,5 +75,3 @@ MatrixFreePDE::getPostProcessedFields( pp_variable_list.integrate_and_distribute(dst); } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/reassignGrains.cc b/src/matrixfree/reassignGrains.cc index be6f86293..6fb6942a5 100644 --- a/src/matrixfree/reassignGrains.cc +++ b/src/matrixfree/reassignGrains.cc @@ -111,5 +111,3 @@ MatrixFreePDE::reassignGrains() // end log computing_timer.leave_subsection("matrixFreePDE: reassignGrains"); } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/reinit.cc b/src/matrixfree/reinit.cc index 031598846..f2d88eca9 100644 --- a/src/matrixfree/reinit.cc +++ b/src/matrixfree/reinit.cc @@ -206,5 +206,3 @@ MatrixFreePDE::reinit() computing_timer.leave_subsection("matrixFreePDE: reinitialization"); } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/setNonlinearEqInitialGuess.cc b/src/matrixfree/setNonlinearEqInitialGuess.cc index 1f8953147..e8ba24f3e 100644 --- a/src/matrixfree/setNonlinearEqInitialGuess.cc +++ b/src/matrixfree/setNonlinearEqInitialGuess.cc @@ -199,5 +199,3 @@ MatrixFreePDE::getLaplaceLHS( mat.distribute_local_to_global(dst); } } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/solve.cc b/src/matrixfree/solve.cc index 28d49f4ca..cb3df3ea7 100644 --- a/src/matrixfree/solve.cc +++ b/src/matrixfree/solve.cc @@ -152,5 +152,3 @@ MatrixFreePDE::solve() // log time computing_timer.leave_subsection("matrixFreePDE: solve"); } - -#include "../../include/matrixFreePDE_template_instantiations.h" diff --git a/src/matrixfree/solveIncrement.cc b/src/matrixfree/solveIncrement.cc index 3199cf0ff..3b6e83bb9 100644 --- a/src/matrixfree/solveIncrement.cc +++ b/src/matrixfree/solveIncrement.cc @@ -545,6 +545,4 @@ MatrixFreePDE::updateImplicitSolution(unsigned int fieldIndex, } return nonlinear_it_converged; -} - -#include "../../include/matrixFreePDE_template_instantiations.h" +} \ No newline at end of file diff --git a/src/matrixfree/utilities.cc b/src/matrixfree/utilities.cc index 44efbcb43..9be4b7911 100644 --- a/src/matrixfree/utilities.cc +++ b/src/matrixfree/utilities.cc @@ -15,5 +15,3 @@ MatrixFreePDE::getFieldIndex(std::string _name) pcout << "\nutilities.h: field '" << _name.c_str() << "' not initialized\n"; exit(-1); } - -#include "../../include/matrixFreePDE_template_instantiations.h" From 399e2edde47ca305b190e6d282f287142d85f45b Mon Sep 17 00:00:00 2001 From: landinjm Date: Thu, 31 Oct 2024 11:19:20 -0400 Subject: [PATCH 12/28] remove extraneous src from clang-tidy script --- utilities/clang_tidy.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/utilities/clang_tidy.sh b/utilities/clang_tidy.sh index a185883ee..51cb6156d 100755 --- a/utilities/clang_tidy.sh +++ b/utilities/clang_tidy.sh @@ -32,7 +32,7 @@ CC=clang CXX=clang++ cmake "${arguments[@]}" "$dir" || (echo "cmake failed!"; fa cmake --build . || (echo "make failed!"; false) || exit 3 # Run clang-tidy -run-clang-tidy -p . -quiet -header-filter "$dir/include/(?!IntegrationTools).*" "$dir/src/*" 2>error.txt >output.txt +run-clang-tidy -p . -quiet -header-filter "$dir/include/(?!IntegrationTools).*" 2>error.txt >output.txt # Remove duplicates & log them grep -E '(warning|error): ' output.txt | sort | uniq > clang-tidy.log From 773d189c8c79a4398d99915d6c00397d32dd49bf Mon Sep 17 00:00:00 2001 From: landinjm Date: Thu, 31 Oct 2024 16:05:42 -0400 Subject: [PATCH 13/28] updating clang tidy --- .clang-tidy | 4 ---- 1 file changed, 4 deletions(-) diff --git a/.clang-tidy b/.clang-tidy index 7fea7776d..a40848af4 100644 --- a/.clang-tidy +++ b/.clang-tidy @@ -9,12 +9,9 @@ Checks: > cppcoreguidelines-*, -cppcoreguidelines-avoid-const-or-ref-data-members, -cppcoreguidelines-non-private-member-variables-in-classes, - -cppcoreguidelines-avoid-magic-numbers, hicpp-*, misc-*, -misc-non-private-member-variables-in-classes, - -misc-include-cleaner, - -misc-const-correctness, modernize-*, -modernize-use-trailing-return-type, mpi-*, @@ -23,6 +20,5 @@ Checks: > -readability-else-after-return, -readability-static-accessed-through-instance, -readability-avoid-const-params-in-decls, - -readability-magic-numbers WarningsAsErrors: '*' From fde4e14285325f7339d54a43d36b8b1290d1deb4 Mon Sep 17 00:00:00 2001 From: landinjm Date: Thu, 31 Oct 2024 11:55:32 -0400 Subject: [PATCH 14/28] tidying --- include/EquationDependencyParser.h | 8 +- include/SolverParameters.h | 4 +- include/inputFileReader.h | 16 +- .../EquationDependencyParser.cc | 39 +++-- src/SolverParameters/SolverParameters.cc | 2 +- src/inputFileReader/inputFileReader.cc | 68 ++++---- .../parallelNucleationList.cc | 163 +++++++++++------- .../loadVariableAttributes.cc | 128 ++++++-------- .../load_user_constants.cc | 55 +++--- src/userInputParameters/setTimeStepList.cc | 4 +- .../userInputParameters.cc | 73 ++++---- src/utilities/sortIndexEntryPairList.cc | 8 +- src/utilities/vectorBCFunction.cc | 4 +- .../variableAttributeLoader.cc | 12 +- 14 files changed, 299 insertions(+), 285 deletions(-) diff --git a/include/EquationDependencyParser.h b/include/EquationDependencyParser.h index 4a8dd1b03..cde6834a9 100644 --- a/include/EquationDependencyParser.h +++ b/include/EquationDependencyParser.h @@ -54,14 +54,14 @@ class EquationDependencyParser /* * Method to strip excess whitespace for the dependency lists */ - void + static void strip_dependency_whitespace(std::string &dependency_list); /** * Method to parse the RHS dependency strings and populate the vectors for * whether values, gradients, or hessians are needed. */ - void + static void parseDependencyListRHS( std::vector &variable_name_list, std::vector variable_eq_type, @@ -76,7 +76,7 @@ class EquationDependencyParser * Method to parse the LHS dependency strings and populate the vectors for * whether values, gradients, or hessians are needed. */ - void + static void parseDependencyListLHS( std::vector &variable_name_list, std::vector variable_eq_type, @@ -92,7 +92,7 @@ class EquationDependencyParser * Method to parse the postprocessing dependency strings and populate the * vectors for whether values, gradients, or hessians are needed. */ - void + static void parseDependencyListPP( std::vector &variable_name_list, unsigned int variable_index, diff --git a/include/SolverParameters.h b/include/SolverParameters.h index c63757fb8..52c6a8b73 100644 --- a/include/SolverParameters.h +++ b/include/SolverParameters.h @@ -95,8 +95,8 @@ class NonlinearSolverParameters : public SolverParametersBase * Method to get the maximum number of allowed iterations for the nonlinear * solver. */ - double - getMaxIterations(); + [[nodiscard]] double + getMaxIterations() const; /** * Method to load the parameters for one governing equation into the class. diff --git a/include/inputFileReader.h b/include/inputFileReader.h index 136c012e2..f37dc01ab 100644 --- a/include/inputFileReader.h +++ b/include/inputFileReader.h @@ -20,24 +20,24 @@ class inputFileReader // Method to get a list of entry values from multiple subsections in an input // file - [[nodiscard]] std::vector + [[nodiscard]] static std::vector get_subsection_entry_list(const std::string ¶meters_file_name, const std::string &subsec_name, const std::string &entry_name, - const std::string &default_entry) const; + const std::string &default_entry); // Method to count the number of related entries in an input file - [[nodiscard]] unsigned int + [[nodiscard]] static unsigned int get_number_of_entries(const std::string ¶meters_file_name, const std::string &keyword, - const std::string &entry_name) const; + const std::string &entry_name); // Get the trailing part of the entry name after a specified string (used to // extract the model constant names) - [[nodiscard]] std::vector + [[nodiscard]] static std::vector get_entry_name_ending_list(const std::string ¶meters_file_name, const std::string &keyword, - const std::string &entry_name_begining) const; + const std::string &entry_name_begining); // Method to declare the parameters to be read from an input file void @@ -48,12 +48,12 @@ class inputFileReader const std::vector &var_nucleates) const; // Method to check if a line has the desired contents and if so, extract it - bool + static bool parse_line(std::string line, const std::string &keyword, const std::string &entry_name, std::string &out_string, - bool expect_equals_sign) const; + bool expect_equals_sign); // Variables dealii::ParameterHandler parameter_handler; diff --git a/src/EquationDependencyParser/EquationDependencyParser.cc b/src/EquationDependencyParser/EquationDependencyParser.cc index ba199ba84..a6d6af7fa 100644 --- a/src/EquationDependencyParser/EquationDependencyParser.cc +++ b/src/EquationDependencyParser/EquationDependencyParser.cc @@ -22,7 +22,7 @@ EquationDependencyParser::parse(std::vector &var_name, std::vector &var_nonlinear) { // Determine the number of variables - size_t n_variables = var_name.size(); + const size_t n_variables = var_name.size(); // Resize the dependency evaluation flag vectors eval_flags_explicit_RHS.resize(n_variables, dealii::EvaluationFlags::nothing); @@ -47,7 +47,7 @@ EquationDependencyParser::parse(std::vector &var_name, // Now check for each variable_eq_type if (var_eq_type[i] == EXPLICIT_TIME_DEPENDENT) { - bool single_var_nonlinear; + bool single_var_nonlinear = false; parseDependencyListRHS(var_name, var_eq_type, @@ -62,7 +62,7 @@ EquationDependencyParser::parse(std::vector &var_name, } else if (var_eq_type[i] == AUXILIARY) { - bool single_var_nonlinear; + bool single_var_nonlinear = false; parseDependencyListRHS(var_name, var_eq_type, @@ -78,7 +78,8 @@ EquationDependencyParser::parse(std::vector &var_name, else if (var_eq_type[i] == IMPLICIT_TIME_DEPENDENT || var_eq_type[i] == TIME_INDEPENDENT) { - bool single_var_nonlinear_RHS, single_var_nonlinear_LHS; + bool single_var_nonlinear_RHS = false; + bool single_var_nonlinear_LHS = false; parseDependencyListRHS(var_name, var_eq_type, @@ -116,18 +117,18 @@ EquationDependencyParser::parseDependencyListRHS( bool &is_nonlinear) { // Split the dependency strings into lists of entries - std::vector split_value_dependency_list = + const std::vector split_value_dependency_list = dealii::Utilities::split_string_list(value_dependencies); std::vector split_gradient_dependency_list = dealii::Utilities::split_string_list(gradient_dependencies); // Check if either is empty and set value and gradient flags for the // residual appropriately - if (split_value_dependency_list.size() > 0) + if (!split_value_dependency_list.empty()) { residual_flags[variable_index] |= dealii::EvaluationFlags::values; } - if (split_gradient_dependency_list.size() > 0) + if (!split_gradient_dependency_list.empty()) { residual_flags[variable_index] |= dealii::EvaluationFlags::gradients; } @@ -166,15 +167,15 @@ EquationDependencyParser::parseDependencyListRHS( variable.end()); // Is the variable we are finding the dependencies for explicit - bool variable_is_explicit = + const bool variable_is_explicit = variable_eq_type[variable_index] == EXPLICIT_TIME_DEPENDENT; // Is the dependency variable explicit - bool dependency_variable_is_explicit = + const bool dependency_variable_is_explicit = variable_eq_type[dependency_variable_index] == EXPLICIT_TIME_DEPENDENT; // Is the dependency the variable - bool same_variable = variable_index == dependency_variable_index; + const bool same_variable = variable_index == dependency_variable_index; // Case if the dependency is x if (dependency == variable) @@ -225,18 +226,18 @@ EquationDependencyParser::parseDependencyListLHS( bool &is_nonlinear) { // Split the dependency strings into lists of entries - std::vector split_value_dependency_list = + const std::vector split_value_dependency_list = dealii::Utilities::split_string_list(value_dependencies); std::vector split_gradient_dependency_list = dealii::Utilities::split_string_list(gradient_dependencies); // Check if either is empty and set value and gradient flags for the // residual appropriately - if (split_value_dependency_list.size() > 0) + if (!split_value_dependency_list.empty()) { residual_flags[variable_index] |= dealii::EvaluationFlags::values; } - if (split_gradient_dependency_list.size() > 0) + if (!split_gradient_dependency_list.empty()) { residual_flags[variable_index] |= dealii::EvaluationFlags::gradients; } @@ -291,7 +292,7 @@ EquationDependencyParser::parseDependencyListLHS( variable.end()); // Is the variable we are finding the dependencies for explicit - bool dependency_variable_is_explicit = + const bool dependency_variable_is_explicit = variable_eq_type[dependency_variable_index] == EXPLICIT_TIME_DEPENDENT; // Case if the dependency is x @@ -380,8 +381,8 @@ EquationDependencyParser::pp_parse(std::vector &var_name, std::vector sorted_dependencies_gradient) { // Determine the number of variables - size_t n_variables = var_name.size(); - size_t n_postprocess_variables = pp_var_name.size(); + const size_t n_variables = var_name.size(); + const size_t n_postprocess_variables = pp_var_name.size(); // Resize the dependency evaluation flag vectors eval_flags_postprocess.resize(n_variables, dealii::EvaluationFlags::nothing); @@ -416,18 +417,18 @@ EquationDependencyParser::parseDependencyListPP( std::vector &residual_flags) { // Split the dependency strings into lists of entries - std::vector split_value_dependency_list = + const std::vector split_value_dependency_list = dealii::Utilities::split_string_list(value_dependencies); std::vector split_gradient_dependency_list = dealii::Utilities::split_string_list(gradient_dependencies); // Check if either is empty and set value and gradient flags for the // residual appropriately - if (split_value_dependency_list.size() > 0) + if (!split_value_dependency_list.empty()) { residual_flags[variable_index] |= dealii::EvaluationFlags::values; } - if (split_gradient_dependency_list.size() > 0) + if (!split_gradient_dependency_list.empty()) { residual_flags[variable_index] |= dealii::EvaluationFlags::gradients; } diff --git a/src/SolverParameters/SolverParameters.cc b/src/SolverParameters/SolverParameters.cc index f3579d6a3..f1c64c2cc 100644 --- a/src/SolverParameters/SolverParameters.cc +++ b/src/SolverParameters/SolverParameters.cc @@ -103,7 +103,7 @@ NonlinearSolverParameters::setMaxIterations(unsigned int _max_iterations) } double -NonlinearSolverParameters::getMaxIterations() +NonlinearSolverParameters::getMaxIterations() const { return max_iterations; } diff --git a/src/inputFileReader/inputFileReader.cc b/src/inputFileReader/inputFileReader.cc index 2e7cb3a66..bbd2de577 100644 --- a/src/inputFileReader/inputFileReader.cc +++ b/src/inputFileReader/inputFileReader.cc @@ -12,21 +12,19 @@ // Constructor inputFileReader::inputFileReader(const std::string &input_file_name, variableAttributeLoader &variable_attributes) + : var_types(variable_attributes.var_type) + , var_eq_types(variable_attributes.var_eq_type) + , num_pp_vars(variable_attributes.var_name_list_PP.size()) + , var_names(variable_attributes.var_name) + , var_nonlinear(variable_attributes.var_nonlinear) { // Extract an ordered vector of the variable types from variable_attributes - unsigned int number_of_variables = variable_attributes.var_name_list.size(); - var_types = variable_attributes.var_type; - var_eq_types = variable_attributes.var_eq_type; - var_names = variable_attributes.var_name; - - var_nonlinear = variable_attributes.var_nonlinear; + const unsigned int number_of_variables = variable_attributes.var_name_list.size(); var_nucleates = sortIndexEntryPairList(variable_attributes.nucleating_variable_list, number_of_variables, false); - num_pp_vars = variable_attributes.var_name_list_PP.size(); - num_constants = get_number_of_entries(input_file_name, "set", "Model constant"); model_constant_names = @@ -58,14 +56,14 @@ inputFileReader::parse_line(std::string line, const std::string &keyword, const std::string &entry_name, std::string &out_string, - const bool expect_equals_sign) const + const bool expect_equals_sign) { // Strip spaces at the front and back - while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) + while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) { line.erase(0, 1); } - while ((line.size() > 0) && + while ((!line.empty()) && (line[line.size() - 1] == ' ' || line[line.size() - 1] == '\t')) { line.erase(line.size() - 1, std::string::npos); @@ -86,9 +84,9 @@ inputFileReader::parse_line(std::string line, return false; } } - if (entry_name.size() > 0) + if (!entry_name.empty()) { - if (!(line[keyword.size()] == ' ' || line[keyword.size()] == '\t')) + if (line[keyword.size()] != ' ' && line[keyword.size()] != '\t') { return false; } @@ -96,7 +94,7 @@ inputFileReader::parse_line(std::string line, // delete the "keyword" and then delete more spaces if present line.erase(0, keyword.size()); - while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) + while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) { line.erase(0, 1); } @@ -107,7 +105,7 @@ inputFileReader::parse_line(std::string line, } line.erase(0, entry_name.size()); - while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) + while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) { line.erase(0, 1); } @@ -115,14 +113,14 @@ inputFileReader::parse_line(std::string line, // we'd expect an equals size here if expect_equals_sign is true if (expect_equals_sign) { - if ((line.size() < 1) || (line[0] != '=')) + if ((line.empty()) || (line[0] != '=')) { return false; } } // remove comment - std::string::size_type pos = line.find('#'); + const std::string::size_type pos = line.find('#'); if (pos != std::string::npos) { line.erase(pos); @@ -135,12 +133,12 @@ inputFileReader::parse_line(std::string line, line.erase(0, 1); } - while ((line.size() > 0) && (line[0] == ' ' || line[0] == '\t')) + while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) { line.erase(0, 1); } - while ((line.size() > 0) && + while ((!line.empty()) && (line[line.size() - 1] == ' ' || line[line.size() - 1] == '\t')) { line.erase(line.size() - 1, std::string::npos); @@ -156,15 +154,17 @@ std::vector inputFileReader::get_subsection_entry_list(const std::string ¶meters_file_name, const std::string &subsec_name, const std::string &entry_name, - const std::string &default_entry) const + const std::string &default_entry) { std::ifstream input_file; input_file.open(parameters_file_name); - std::string line, entry; - bool in_subsection = false; - bool found_entry, desired_entry_found; - unsigned int subsection_index; + std::string line; + std::string entry; + bool in_subsection = false; + bool found_entry = false; + bool desired_entry_found = false; + unsigned int subsection_index = 0; std::vector entry_list; std::vector index_list; @@ -229,13 +229,14 @@ inputFileReader::get_subsection_entry_list(const std::string ¶meters_file_na unsigned int inputFileReader::get_number_of_entries(const std::string ¶meters_file_name, const std::string &keyword, - const std::string &entry_name) const + const std::string &entry_name) { std::ifstream input_file; input_file.open(parameters_file_name); - std::string line, entry; - bool found_entry; + std::string line; + std::string entry; + bool found_entry = false; unsigned int count = 0; @@ -256,13 +257,14 @@ inputFileReader::get_number_of_entries(const std::string ¶meters_file_name, std::vector inputFileReader::get_entry_name_ending_list(const std::string ¶meters_file_name, const std::string &keyword, - const std::string &entry_name_begining) const + const std::string &entry_name_begining) { std::ifstream input_file; input_file.open(parameters_file_name); - std::string line, entry; - bool found_entry; + std::string line; + std::string entry; + bool found_entry = false; std::vector entry_name_end_list; @@ -276,13 +278,13 @@ inputFileReader::get_entry_name_ending_list(const std::string ¶meters_file_n // sign // Strip whitespace at the beginning - while ((entry.size() > 0) && (entry[0] == ' ' || entry[0] == '\t')) + while ((!entry.empty()) && (entry[0] == ' ' || entry[0] == '\t')) { entry.erase(0, 1); } // Strip everything up to the equals sign - while ((entry.size() > 0) && (entry[entry.size() - 1] != '=')) + while ((!entry.empty()) && (entry[entry.size() - 1] != '=')) { entry.erase(entry.size() - 1, std::string::npos); } @@ -291,7 +293,7 @@ inputFileReader::get_entry_name_ending_list(const std::string ¶meters_file_n entry.erase(entry.size() - 1, std::string::npos); // Strip whitespace between the entry name and the equals sign - while ((entry.size() > 0) && + while ((!entry.empty()) && (entry[entry.size() - 1] == ' ' || entry[entry.size() - 1] == '\t')) { entry.erase(entry.size() - 1, std::string::npos); diff --git a/src/parallelNucleationList/parallelNucleationList.cc b/src/parallelNucleationList/parallelNucleationList.cc index b50a2b7b3..76865b3dd 100644 --- a/src/parallelNucleationList/parallelNucleationList.cc +++ b/src/parallelNucleationList/parallelNucleationList.cc @@ -23,13 +23,13 @@ parallelNucleationList::buildGlobalNucleiList(double min_dist_between unsigned int old_num_nuclei) { // MPI INITIALIZATON - int numProcs = dealii::Utilities::MPI::n_mpi_processes(MPI_COMM_WORLD); - int thisProc = dealii::Utilities::MPI::this_mpi_process(MPI_COMM_WORLD); + const unsigned int numProcs = dealii::Utilities::MPI::n_mpi_processes(MPI_COMM_WORLD); + const unsigned int thisProc = dealii::Utilities::MPI::this_mpi_process(MPI_COMM_WORLD); if (numProcs > 1) { // Cycle through each processor, sending and receiving, to append the list // of new nuclei - for (int proc_index = 0; proc_index < numProcs - 1; proc_index++) + for (unsigned int proc_index = 0; proc_index < numProcs - 1; proc_index++) { if (thisProc == proc_index) { @@ -104,12 +104,16 @@ parallelNucleationList::sendUpdate(int procno) const s_center_x.push_back(s_center[0]); s_center_y.push_back(s_center[1]); if (dim == 3) - s_center_z.push_back(s_center[2]); + { + s_center_z.push_back(s_center[2]); + } s_semiaxis_a.push_back(thisNuclei.semiaxes[0]); s_semiaxis_b.push_back(thisNuclei.semiaxes[1]); if (dim == 3) - s_semiaxis_c.push_back(thisNuclei.semiaxes[2]); + { + s_semiaxis_c.push_back(thisNuclei.semiaxes[2]); + } s_seededTime.push_back(thisNuclei.seededTime); s_seedingTime.push_back(thisNuclei.seedingTime); @@ -117,27 +121,32 @@ parallelNucleationList::sendUpdate(int procno) const s_orderParameterIndex.push_back(thisNuclei.orderParameterIndex); } // Send vectors to next processor - MPI_Send(&s_index[0], currnonucs, MPI_UNSIGNED, procno, 1, MPI_COMM_WORLD); - MPI_Send(&s_center_x[0], currnonucs, MPI_DOUBLE, procno, 2, MPI_COMM_WORLD); - MPI_Send(&s_center_y[0], currnonucs, MPI_DOUBLE, procno, 3, MPI_COMM_WORLD); + MPI_Send(s_index.data(), currnonucs, MPI_UNSIGNED, procno, 1, MPI_COMM_WORLD); + MPI_Send(s_center_x.data(), currnonucs, MPI_DOUBLE, procno, 2, MPI_COMM_WORLD); + MPI_Send(s_center_y.data(), currnonucs, MPI_DOUBLE, procno, 3, MPI_COMM_WORLD); if (dim == 3) { - MPI_Send(&s_center_z[0], currnonucs, MPI_DOUBLE, procno, 4, MPI_COMM_WORLD); - MPI_Send(&s_semiaxis_c[0], currnonucs, MPI_DOUBLE, procno, 7, MPI_COMM_WORLD); + MPI_Send(s_center_z.data(), currnonucs, MPI_DOUBLE, procno, 4, MPI_COMM_WORLD); + MPI_Send(s_semiaxis_c.data(), + currnonucs, + MPI_DOUBLE, + procno, + 7, + MPI_COMM_WORLD); } - MPI_Send(&s_semiaxis_a[0], currnonucs, MPI_DOUBLE, procno, 5, MPI_COMM_WORLD); - MPI_Send(&s_semiaxis_b[0], currnonucs, MPI_DOUBLE, procno, 6, MPI_COMM_WORLD); + MPI_Send(s_semiaxis_a.data(), currnonucs, MPI_DOUBLE, procno, 5, MPI_COMM_WORLD); + MPI_Send(s_semiaxis_b.data(), currnonucs, MPI_DOUBLE, procno, 6, MPI_COMM_WORLD); - MPI_Send(&s_seededTime[0], currnonucs, MPI_DOUBLE, procno, 8, MPI_COMM_WORLD); - MPI_Send(&s_seedingTime[0], currnonucs, MPI_DOUBLE, procno, 9, MPI_COMM_WORLD); - MPI_Send(&s_seedingTimestep[0], + MPI_Send(s_seededTime.data(), currnonucs, MPI_DOUBLE, procno, 8, MPI_COMM_WORLD); + MPI_Send(s_seedingTime.data(), currnonucs, MPI_DOUBLE, procno, 9, MPI_COMM_WORLD); + MPI_Send(s_seedingTimestep.data(), currnonucs, MPI_UNSIGNED, procno, 10, MPI_COMM_WORLD); - MPI_Send(&s_orderParameterIndex[0], + MPI_Send(s_orderParameterIndex.data(), currnonucs, MPI_UNSIGNED, procno, @@ -183,21 +192,21 @@ parallelNucleationList::receiveUpdate(int procno) std::vector r_orderParameterIndex(recvnonucs, 0); // Recieve vectors from processor procno - MPI_Recv(&r_index[0], + MPI_Recv(r_index.data(), recvnonucs, MPI_UNSIGNED, procno, 1, MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_center_x[0], + MPI_Recv(r_center_x.data(), recvnonucs, MPI_DOUBLE, procno, 2, MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_center_y[0], + MPI_Recv(r_center_y.data(), recvnonucs, MPI_DOUBLE, procno, @@ -206,14 +215,14 @@ parallelNucleationList::receiveUpdate(int procno) MPI_STATUS_IGNORE); if (dim == 3) { - MPI_Recv(&r_center_z[0], + MPI_Recv(r_center_z.data(), recvnonucs, MPI_DOUBLE, procno, 4, MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_semiaxis_c[0], + MPI_Recv(r_semiaxis_c.data(), recvnonucs, MPI_DOUBLE, procno, @@ -222,14 +231,14 @@ parallelNucleationList::receiveUpdate(int procno) MPI_STATUS_IGNORE); } - MPI_Recv(&r_semiaxis_a[0], + MPI_Recv(r_semiaxis_a.data(), recvnonucs, MPI_DOUBLE, procno, 5, MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_semiaxis_b[0], + MPI_Recv(r_semiaxis_b.data(), recvnonucs, MPI_DOUBLE, procno, @@ -237,28 +246,28 @@ parallelNucleationList::receiveUpdate(int procno) MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_seededTime[0], + MPI_Recv(r_seededTime.data(), recvnonucs, MPI_DOUBLE, procno, 8, MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_seedingTime[0], + MPI_Recv(r_seedingTime.data(), recvnonucs, MPI_DOUBLE, procno, 9, MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_seedingTimestep[0], + MPI_Recv(r_seedingTimestep.data(), recvnonucs, MPI_UNSIGNED, procno, 10, MPI_COMM_WORLD, MPI_STATUS_IGNORE); - MPI_Recv(&r_orderParameterIndex[0], + MPI_Recv(r_orderParameterIndex.data(), recvnonucs, MPI_UNSIGNED, procno, @@ -269,18 +278,23 @@ parallelNucleationList::receiveUpdate(int procno) // Loop to store info in vectors onto the nuclei structure for (int jnuc = 0; jnuc <= recvnonucs - 1; jnuc++) { - auto *temp = new nucleus; + auto temp = std::make_unique>(); + temp->index = r_index[jnuc]; dealii::Point r_center; r_center[0] = r_center_x[jnuc]; r_center[1] = r_center_y[jnuc]; if (dim == 3) - r_center[2] = r_center_z[jnuc]; + { + r_center[2] = r_center_z[jnuc]; + } temp->center = r_center; temp->semiaxes.push_back(r_semiaxis_a[jnuc]); temp->semiaxes.push_back(r_semiaxis_b[jnuc]); if (dim == 3) - temp->semiaxes.push_back(r_semiaxis_c[jnuc]); + { + temp->semiaxes.push_back(r_semiaxis_c[jnuc]); + } temp->seededTime = r_seededTime[jnuc]; temp->seedingTime = r_seedingTime[jnuc]; temp->seedingTimestep = r_seedingTimestep[jnuc]; @@ -305,7 +319,7 @@ parallelNucleationList::broadcastUpdate(int broadcastProc, int thisProc) { // Creating vectors of each quantity in nuclei. Each numbered acording to // the tags used for MPI_Send/MPI_Recv - unsigned int initial_vec_size; + unsigned int initial_vec_size = 0; if (thisProc == broadcastProc) { initial_vec_size = 0; @@ -364,29 +378,51 @@ parallelNucleationList::broadcastUpdate(int broadcastProc, int thisProc) } // Recieve vectors from processor procno - MPI_Bcast(&r_index[0], currnonucs, MPI_UNSIGNED, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(&r_center_x[0], currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(&r_center_y[0], currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_index.data(), currnonucs, MPI_UNSIGNED, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_center_x.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_center_y.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); if (dim == 3) - MPI_Bcast(&r_center_z[0], currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); - - MPI_Bcast(&r_semiaxis_a[0], currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(&r_semiaxis_b[0], currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + { + MPI_Bcast(r_center_z.data(), + currnonucs, + MPI_DOUBLE, + broadcastProc, + MPI_COMM_WORLD); + } + MPI_Bcast(r_semiaxis_a.data(), + currnonucs, + MPI_DOUBLE, + broadcastProc, + MPI_COMM_WORLD); + MPI_Bcast(r_semiaxis_b.data(), + currnonucs, + MPI_DOUBLE, + broadcastProc, + MPI_COMM_WORLD); if (dim == 3) - MPI_Bcast(&r_semiaxis_c[0], - currnonucs, - MPI_DOUBLE, - broadcastProc, - MPI_COMM_WORLD); - - MPI_Bcast(&r_seededTime[0], currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(&r_seedingTime[0], currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(&r_seedingTimestep[0], + { + MPI_Bcast(r_semiaxis_c.data(), + currnonucs, + MPI_DOUBLE, + broadcastProc, + MPI_COMM_WORLD); + } + MPI_Bcast(r_seededTime.data(), + currnonucs, + MPI_DOUBLE, + broadcastProc, + MPI_COMM_WORLD); + MPI_Bcast(r_seedingTime.data(), + currnonucs, + MPI_DOUBLE, + broadcastProc, + MPI_COMM_WORLD); + MPI_Bcast(r_seedingTimestep.data(), currnonucs, MPI_UNSIGNED, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(&r_orderParameterIndex[0], + MPI_Bcast(r_orderParameterIndex.data(), currnonucs, MPI_UNSIGNED, broadcastProc, @@ -397,13 +433,16 @@ parallelNucleationList::broadcastUpdate(int broadcastProc, int thisProc) // Loop to store info in vectors onto the nuclei structure for (int jnuc = 0; jnuc <= currnonucs - 1; jnuc++) { - auto *temp = new nucleus; + auto temp = std::make_unique>(); + temp->index = r_index[jnuc]; dealii::Point r_center; r_center[0] = r_center_x[jnuc]; r_center[1] = r_center_y[jnuc]; if (dim == 3) - r_center[2] = r_center_z[jnuc]; + { + r_center[2] = r_center_z[jnuc]; + } temp->center = r_center; temp->semiaxes.push_back(r_semiaxis_a[jnuc]); temp->semiaxes.push_back(r_semiaxis_b[jnuc]); @@ -475,8 +514,10 @@ parallelNucleationList::removeSubsetOfNuclei( // methods to reduce duplication. // MPI INITIALIZATON - int numProcs = dealii::Utilities::MPI::n_mpi_processes(MPI_COMM_WORLD); - int thisProc = dealii::Utilities::MPI::this_mpi_process(MPI_COMM_WORLD); + const int numProcs = + static_cast(dealii::Utilities::MPI::n_mpi_processes(MPI_COMM_WORLD)); + const int thisProc = + static_cast(dealii::Utilities::MPI::this_mpi_process(MPI_COMM_WORLD)); // Build a global list of nuclei to delete, first sending the length of the // vector of indices, then the vector itself @@ -488,9 +529,9 @@ parallelNucleationList::removeSubsetOfNuclei( { if (thisProc == proc_index) { - int currnonucs = nuclei_to_remove.size(); + int currnonucs = static_cast(nuclei_to_remove.size()); MPI_Send(&currnonucs, 1, MPI_INT, thisProc + 1, 0, MPI_COMM_WORLD); - MPI_Send(&nuclei_to_remove[0], + MPI_Send(nuclei_to_remove.data(), currnonucs, MPI_UNSIGNED, thisProc + 1, @@ -508,7 +549,7 @@ parallelNucleationList::removeSubsetOfNuclei( MPI_COMM_WORLD, MPI_STATUS_IGNORE); std::vector recieved_nuclei_to_remove(recvnonucs); - MPI_Recv(&recieved_nuclei_to_remove[0], + MPI_Recv(recieved_nuclei_to_remove.data(), recvnonucs, MPI_UNSIGNED, thisProc - 1, @@ -524,14 +565,14 @@ parallelNucleationList::removeSubsetOfNuclei( // The final processor now has the final list of the new nuclei, broadcast // it to all the other processors - int currnonucs = nuclei_to_remove.size(); + int currnonucs = static_cast(nuclei_to_remove.size()); MPI_Bcast(&currnonucs, 1, MPI_INT, numProcs - 1, MPI_COMM_WORLD); std::vector recieved_nuclei_to_remove(currnonucs); if (thisProc == numProcs - 1) { recieved_nuclei_to_remove = nuclei_to_remove; } - MPI_Bcast(&recieved_nuclei_to_remove[0], + MPI_Bcast(recieved_nuclei_to_remove.data(), currnonucs, MPI_UNSIGNED, numProcs - 1, @@ -539,9 +580,9 @@ parallelNucleationList::removeSubsetOfNuclei( nuclei_to_remove = recieved_nuclei_to_remove; } - for (unsigned int i : nuclei_to_remove) + for (const unsigned int nuclei : nuclei_to_remove) { - std::cout << thisProc << ": " << i << std::endl; + std::cout << thisProc << ": " << nuclei << std::endl; } // Remove the nuclei from the list @@ -549,9 +590,9 @@ parallelNucleationList::removeSubsetOfNuclei( for (unsigned int nuc = 0; nuc < newnuclei.size(); nuc++) { bool pruneNucleus = false; - for (unsigned int i : nuclei_to_remove) + for (const unsigned int nuclei : nuclei_to_remove) { - if (i == nuclei_size + nuc) + if (nuclei == nuclei_size + nuc) { pruneNucleus = true; break; diff --git a/src/userInputParameters/loadVariableAttributes.cc b/src/userInputParameters/loadVariableAttributes.cc index 942936973..82355d7e8 100644 --- a/src/userInputParameters/loadVariableAttributes.cc +++ b/src/userInputParameters/loadVariableAttributes.cc @@ -23,7 +23,7 @@ userInputParameters::loadVariableAttributes( // Load some nucleation parameters for (unsigned int i = 0; i < number_of_variables; i++) { - if (variable_attributes.nucleating_variable.at(i) == true) + if (variable_attributes.nucleating_variable.at(i)) { nucleating_variable_indices.push_back(i); } @@ -34,8 +34,8 @@ userInputParameters::loadVariableAttributes( } } - nucleating_variable_indices.size() > 0 ? nucleation_occurs = true - : nucleation_occurs = false; + !nucleating_variable_indices.empty() ? nucleation_occurs = true + : nucleation_occurs = false; // Load these attributes into the varInfoList objects @@ -43,7 +43,8 @@ userInputParameters::loadVariableAttributes( num_var_explicit_RHS = 0; for (unsigned int i = 0; i < number_of_variables; i++) { - if (!(variable_attributes.equation_dependency_parser.eval_flags_explicit_RHS[i] & + if (!static_cast( + variable_attributes.equation_dependency_parser.eval_flags_explicit_RHS[i] & dealii::EvaluationFlags::nothing)) { num_var_explicit_RHS++; @@ -52,19 +53,13 @@ userInputParameters::loadVariableAttributes( varInfoListExplicitRHS.reserve(num_var_explicit_RHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo; - - varInfo.evaluation_flags = - variable_attributes.equation_dependency_parser.eval_flags_explicit_RHS[i]; - - varInfo.residual_flags = variable_attributes.equation_dependency_parser - .eval_flags_residual_explicit_RHS[i]; - - varInfo.global_var_index = i; - - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = var_type[i] == SCALAR; + variable_info varInfo { + var_type[i] == SCALAR, + i, + variable_attributes.equation_dependency_parser.eval_flags_explicit_RHS[i], + variable_attributes.equation_dependency_parser + .eval_flags_residual_explicit_RHS[i], + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing)}; varInfoListExplicitRHS.push_back(varInfo); } @@ -73,7 +68,8 @@ userInputParameters::loadVariableAttributes( num_var_nonexplicit_RHS = 0; for (unsigned int i = 0; i < number_of_variables; i++) { - if (!(variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_RHS[i] & + if (!static_cast( + variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_RHS[i] & dealii::EvaluationFlags::nothing)) { num_var_nonexplicit_RHS++; @@ -82,19 +78,13 @@ userInputParameters::loadVariableAttributes( varInfoListNonexplicitRHS.reserve(num_var_nonexplicit_RHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo; - - varInfo.evaluation_flags = - variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_RHS[i]; - - varInfo.residual_flags = variable_attributes.equation_dependency_parser - .eval_flags_residual_nonexplicit_RHS[i]; - - varInfo.global_var_index = i; - - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = var_type[i] == SCALAR; + variable_info varInfo { + var_type[i] == SCALAR, + i, + variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_RHS[i], + variable_attributes.equation_dependency_parser + .eval_flags_residual_nonexplicit_RHS[i], + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing)}; varInfoListNonexplicitRHS.push_back(varInfo); } @@ -103,7 +93,8 @@ userInputParameters::loadVariableAttributes( num_var_LHS = 0; for (unsigned int i = 0; i < number_of_variables; i++) { - if (!(variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_LHS[i] & + if (!static_cast( + variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_LHS[i] & dealii::EvaluationFlags::nothing)) { num_var_LHS++; @@ -113,19 +104,13 @@ userInputParameters::loadVariableAttributes( varInfoListLHS.reserve(num_var_LHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo; - - varInfo.evaluation_flags = - variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_LHS[i]; - - varInfo.residual_flags = variable_attributes.equation_dependency_parser - .eval_flags_residual_nonexplicit_LHS[i]; - - varInfo.global_var_index = i; - - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = var_type[i] == SCALAR; + variable_info varInfo { + var_type[i] == SCALAR, + i, + variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_LHS[i], + variable_attributes.equation_dependency_parser + .eval_flags_residual_nonexplicit_LHS[i], + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing)}; varInfoListLHS.push_back(varInfo); } @@ -133,20 +118,14 @@ userInputParameters::loadVariableAttributes( varChangeInfoListLHS.reserve(num_var_LHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo; - - varInfo.evaluation_flags = variable_attributes.equation_dependency_parser - .eval_flags_change_nonexplicit_LHS[i]; - - // FOR NOW, TAKING THESE FROM THE VARIABLE ITSELF!! - varInfo.residual_flags = variable_attributes.equation_dependency_parser - .eval_flags_residual_nonexplicit_LHS[i]; - - varInfo.global_var_index = i; - - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = var_type[i] == SCALAR; + variable_info varInfo {var_type[i] == SCALAR, + i, + variable_attributes.equation_dependency_parser + .eval_flags_change_nonexplicit_LHS[i], + variable_attributes.equation_dependency_parser + .eval_flags_residual_nonexplicit_LHS[i], + !static_cast(varInfo.evaluation_flags & + dealii::EvaluationFlags::nothing)}; varChangeInfoListLHS.push_back(varInfo); } @@ -156,16 +135,12 @@ userInputParameters::loadVariableAttributes( pp_baseVarInfoList.reserve(number_of_variables); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo; - - varInfo.evaluation_flags = - variable_attributes.equation_dependency_parser.eval_flags_postprocess[i]; - - varInfo.global_var_index = i; - - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = var_type[i] == SCALAR; + variable_info varInfo { + var_type[i] == SCALAR, + i, + variable_attributes.equation_dependency_parser.eval_flags_postprocess[i], + dealii::EvaluationFlags::nothing, + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing)}; pp_baseVarInfoList.push_back(varInfo); } @@ -189,15 +164,12 @@ userInputParameters::loadVariableAttributes( pp_varInfoList.reserve(pp_number_of_variables); for (unsigned int i = 0; i < pp_number_of_variables; i++) { - variable_info varInfo; - varInfo.var_needed = true; - - varInfo.residual_flags = - variable_attributes.equation_dependency_parser.eval_flags_residual_postprocess[i]; - - varInfo.global_var_index = i; - - varInfo.is_scalar = pp_var_type[i] == SCALAR; + variable_info varInfo { + pp_var_type[i] == SCALAR, + i, + dealii::EvaluationFlags::nothing, + variable_attributes.equation_dependency_parser.eval_flags_residual_postprocess[i], + true}; pp_varInfoList.push_back(varInfo); } diff --git a/src/userInputParameters/load_user_constants.cc b/src/userInputParameters/load_user_constants.cc index 5726daff9..979747197 100644 --- a/src/userInputParameters/load_user_constants.cc +++ b/src/userInputParameters/load_user_constants.cc @@ -11,7 +11,7 @@ void userInputParameters::load_user_constants(inputFileReader &input_file_reader, dealii::ParameterHandler ¶meter_handler) { - unsigned int number_of_constants = input_file_reader.num_constants; + const unsigned int number_of_constants = input_file_reader.num_constants; for (unsigned int i = 0; i < input_file_reader.model_constant_names.size(); i++) { @@ -54,15 +54,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi } else if (boost::iequals(model_constants_type_strings.at(0), "bool")) { - bool temp; - if (boost::iequals(model_constants_strings.at(0), "true")) - { - temp = true; - } - else - { - temp = false; - } + bool temp = boost::iequals(model_constants_strings.at(0), "true"); model_constants.push_back(temp); } else @@ -78,7 +70,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi { if (boost::iequals(model_constants_type_strings.at(0), "tensor")) { - unsigned int num_elements = model_constants_strings.size() - 1; + const unsigned int num_elements = model_constants_strings.size() - 1; // Strip parentheses from the input, counting how many rows there // are @@ -139,7 +131,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi // Rank 2 tensor else if (open_parentheses < 5) { - unsigned int row_length; + unsigned int row_length = 0; if (num_elements == 4) { row_length = 2; @@ -180,7 +172,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi else if (boost::iequals(model_constants_type_strings.at(1), "elastic") && boost::iequals(model_constants_type_strings.at(2), "constants")) { - unsigned int num_elements = model_constants_strings.size() - 1; + const unsigned int num_elements = model_constants_strings.size() - 1; // Strip parentheses from the input, counting how many rows there // are @@ -226,7 +218,8 @@ userInputParameters::load_user_constants(inputFileReader &input_fi dealii::Utilities::string_to_double(model_constants_strings.at(i))); } - std::string elastic_const_symmetry = model_constants_type_strings.at(0); + const std::string elastic_const_symmetry = + model_constants_type_strings.at(0); dealii::Tensor<2, 2 *dim - 1 + dim / 3> temp = get_Cij_tensor(temp_elastic_constants, elastic_const_symmetry); model_constants.push_back(temp); @@ -283,7 +276,7 @@ userInputParameters::get_Cij_tensor(std::vector elastic_constants, { std::vector elastic_constants_temp = elastic_constants; elastic_constants.clear(); - std::vector indices_2D = {0, 1, 5, 6, 10, 14}; + const std::vector indices_2D = {0, 1, 5, 6, 10, 14}; for (const auto &index : indices_2D) { elastic_constants.push_back(elastic_constants_temp.at(index)); @@ -363,12 +356,13 @@ userInputParameters::getCIJMatrix(const elasticityModel model, case ISOTROPIC: { pcout << " ISOTROPIC \n"; - double E = constants[0], nu = constants[1]; - double mu = E / (2 * (1 + nu)), - lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); - CIJ[0][0] = lambda + 2 * mu; - CIJ[1][1] = lambda + 2 * mu; - CIJ[2][2] = mu; + const double E = constants[0]; + const double nu = constants[1]; + const double mu = E / (2 * (1 + nu)); + const double lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); + CIJ[0][0] = lambda + 2 * mu; + CIJ[1][1] = lambda + 2 * mu; + CIJ[2][2] = mu; CIJ[0][1] = CIJ[1][0] = lambda; break; } @@ -402,15 +396,16 @@ userInputParameters::getCIJMatrix(const elasticityModel model, case ISOTROPIC: { pcout << " ISOTROPIC \n"; - double E = constants[0], nu = constants[1]; - double mu = E / (2 * (1 + nu)), - lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); - CIJ[0][0] = lambda + 2 * mu; - CIJ[1][1] = lambda + 2 * mu; - CIJ[2][2] = lambda + 2 * mu; - CIJ[3][3] = mu; - CIJ[4][4] = mu; - CIJ[5][5] = mu; + const double E = constants[0]; + const double nu = constants[1]; + const double mu = E / (2 * (1 + nu)); + const double lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); + CIJ[0][0] = lambda + 2 * mu; + CIJ[1][1] = lambda + 2 * mu; + CIJ[2][2] = lambda + 2 * mu; + CIJ[3][3] = mu; + CIJ[4][4] = mu; + CIJ[5][5] = mu; CIJ[0][1] = CIJ[1][0] = lambda; CIJ[0][2] = CIJ[2][0] = lambda; CIJ[1][2] = CIJ[2][1] = lambda; diff --git a/src/userInputParameters/setTimeStepList.cc b/src/userInputParameters/setTimeStepList.cc index 7f7cc56b6..0382a8443 100644 --- a/src/userInputParameters/setTimeStepList.cc +++ b/src/userInputParameters/setTimeStepList.cc @@ -64,8 +64,8 @@ userInputParameters::setTimeStepList( timeStepList.push_back(1); for (unsigned int iter = 2; iter <= totalIncrements; iter++) { - unsigned int decade = std::ceil(std::log10(iter)); - unsigned int step_size = std::pow(10, decade) / numberOfOutputs; + const unsigned int decade = std::ceil(std::log10(iter)); + const unsigned int step_size = std::pow(10, decade) / numberOfOutputs; if (iter % step_size == 0) { timeStepList.push_back(iter); diff --git a/src/userInputParameters/userInputParameters.cc b/src/userInputParameters/userInputParameters.cc index a1f460ddb..867648bde 100644 --- a/src/userInputParameters/userInputParameters.cc +++ b/src/userInputParameters/userInputParameters.cc @@ -69,8 +69,8 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.enter_subsection(subsection_text); { - std::string crit_type_string = parameter_handler.get("Criterion type"); - if (crit_type_string.size() > 0) + const std::string crit_type_string = parameter_handler.get("Criterion type"); + if (!crit_type_string.empty()) { RefinementCriterion new_criterion; new_criterion.variable_index = i; @@ -140,9 +140,9 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } // Time stepping parameters - dtValue = parameter_handler.get_double("Time step"); - int totalIncrements_temp = parameter_handler.get_integer("Number of time steps"); - finalTime = parameter_handler.get_double("Simulation end time"); + dtValue = parameter_handler.get_double("Time step"); + const int totalIncrements_temp = parameter_handler.get_integer("Number of time steps"); + finalTime = parameter_handler.get_double("Simulation end time"); // Linear solver parameters for (unsigned int i = 0; i < number_of_variables; i++) @@ -157,7 +157,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi { // Set the tolerance type SolverToleranceType temp_type; - std::string type_string = parameter_handler.get("Tolerance type"); + const std::string type_string = parameter_handler.get("Tolerance type"); if (boost::iequals(type_string, "ABSOLUTE_RESIDUAL")) { temp_type = ABSOLUTE_RESIDUAL; @@ -187,10 +187,10 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } // Set the tolerance value - double temp_value = parameter_handler.get_double("Tolerance value"); + const double temp_value = parameter_handler.get_double("Tolerance value"); // Set the maximum number of iterations - unsigned int temp_max_iterations = + const unsigned int temp_max_iterations = parameter_handler.get_integer("Maximum linear solver iterations"); linear_solver_parameters.loadParameters(i, @@ -219,7 +219,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi { // Set the tolerance type SolverToleranceType temp_type; - std::string type_string = parameter_handler.get("Tolerance type"); + const std::string type_string = parameter_handler.get("Tolerance type"); if (boost::iequals(type_string, "ABSOLUTE_RESIDUAL")) { temp_type = ABSOLUTE_RESIDUAL; @@ -243,24 +243,24 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } // Set the tolerance value - double temp_value = parameter_handler.get_double("Tolerance value"); + const double temp_value = parameter_handler.get_double("Tolerance value"); // Set the backtrace damping flag - bool temp_backtrack_damping = + const bool temp_backtrack_damping = parameter_handler.get_bool("Use backtracking line search damping"); // Set the backtracking step size modifier - double temp_step_modifier = + const double temp_step_modifier = parameter_handler.get_double("Backtracking step size modifier"); // Set the constant that determines how much the residual must // decrease to be accepted as sufficient - double temp_residual_decrease_coeff = + const double temp_residual_decrease_coeff = parameter_handler.get_double("Backtracking residual decrease coefficient"); // Set the default damping coefficient (used if backtracking isn't // used) - double temp_damping_coefficient = + const double temp_damping_coefficient = parameter_handler.get_double("Constant damping value"); // Set whether to use the solution of Laplace's equation instead of @@ -301,15 +301,15 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } // Set the max number of nonlinear iterations - if (var_nonlinear.size() == 0) + if (var_nonlinear.empty()) { nonlinear_solver_parameters.setMaxIterations(0); } // Output parameters - std::string output_condition = parameter_handler.get("Output condition"); - unsigned int num_outputs = parameter_handler.get_integer("Number of outputs"); - std::vector user_given_time_step_list_temp = + const std::string output_condition = parameter_handler.get("Output condition"); + const unsigned int num_outputs = parameter_handler.get_integer("Number of outputs"); + const std::vector user_given_time_step_list_temp = dealii::Utilities::string_to_int(dealii::Utilities::split_string_list( parameter_handler.get("List of time steps to output"))); std::vector user_given_time_step_list; @@ -445,10 +445,11 @@ userInputParameters::userInputParameters(inputFileReader &input_fi // Parameters for checkpoint/restart resume_from_checkpoint = parameter_handler.get_bool("Load from a checkpoint"); - std::string checkpoint_condition = parameter_handler.get("Checkpoint condition"); - unsigned int num_checkpoints = parameter_handler.get_integer("Number of checkpoints"); + const std::string checkpoint_condition = parameter_handler.get("Checkpoint condition"); + const unsigned int num_checkpoints = + parameter_handler.get_integer("Number of checkpoints"); - std::vector user_given_checkpoint_time_step_list_temp = + const std::vector user_given_checkpoint_time_step_list_temp = dealii::Utilities::string_to_int(dealii::Utilities::split_string_list( parameter_handler.get("List of time steps to save checkpoints"))); std::vector user_given_checkpoint_time_step_list; @@ -473,27 +474,27 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.enter_subsection(nucleation_text); { - unsigned int var_index = i; - std::vector semiaxes = + const unsigned int var_index = i; + const std::vector semiaxes = dealii::Utilities::string_to_double(dealii::Utilities::split_string_list( parameter_handler.get("Nucleus semiaxes (x, y, z)"))); - std::vector ellipsoid_rotation = + const std::vector ellipsoid_rotation = dealii::Utilities::string_to_double(dealii::Utilities::split_string_list( parameter_handler.get("Nucleus rotation in degrees (x, y, z)"))); - std::vector freeze_semiaxes = + const std::vector freeze_semiaxes = dealii::Utilities::string_to_double(dealii::Utilities::split_string_list( parameter_handler.get("Freeze zone semiaxes (x, y, z)"))); - double hold_time = + const double hold_time = parameter_handler.get_double("Freeze time following nucleation"); - double no_nucleation_border_thickness = + const double no_nucleation_border_thickness = parameter_handler.get_double("Nucleation-free border thickness"); - nucleationParameters temp(var_index, - semiaxes, - freeze_semiaxes, - ellipsoid_rotation, - hold_time, - no_nucleation_border_thickness); + const nucleationParameters temp(var_index, + semiaxes, + freeze_semiaxes, + ellipsoid_rotation, + hold_time, + no_nucleation_border_thickness); nucleation_parameters_list.push_back(temp); // Validate nucleation input @@ -563,7 +564,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi buffer_between_grains = parameter_handler.get_double("Buffer between grains before reassignment"); - if (buffer_between_grains < 0.0 && grain_remapping_activated == true) + if (buffer_between_grains < 0.0 && grain_remapping_activated) { std::cerr << "PRISMS-PF Error: If grain reassignment is activated, a " "non-negative buffer distance must be given. See the 'Buffer " @@ -572,7 +573,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi abort(); } - std::vector variables_for_remapping_str = + const std::vector variables_for_remapping_str = dealii::Utilities::split_string_list( parameter_handler.get("Order parameter fields for grain reassignment")); for (const auto &field : variables_for_remapping_str) @@ -588,7 +589,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi break; } } - if (field_found == false && grain_remapping_activated == true) + if (!field_found && grain_remapping_activated) { std::cerr << "PRISMS-PF Error: Entries in the list of order " "parameter fields used for grain reassignment must " diff --git a/src/utilities/sortIndexEntryPairList.cc b/src/utilities/sortIndexEntryPairList.cc index 3bf75d1ff..9a9654b4a 100644 --- a/src/utilities/sortIndexEntryPairList.cc +++ b/src/utilities/sortIndexEntryPairList.cc @@ -7,7 +7,7 @@ sortIndexEntryPairList( bool default_value) { std::vector sorted_vec; - unsigned int entry_index; + unsigned int entry_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { bool entry_found = false; @@ -40,7 +40,7 @@ sortIndexEntryPairList( const std::string &default_value) { std::vector sorted_vec; - unsigned int entry_index; + unsigned int entry_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { bool entry_found = false; @@ -73,7 +73,7 @@ sortIndexEntryPairList( fieldType default_value) { std::vector sorted_vec; - unsigned int entry_index; + unsigned int entry_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { bool entry_found = false; @@ -106,7 +106,7 @@ sortIndexEntryPairList( PDEType default_value) { std::vector sorted_vec; - unsigned int entry_index; + unsigned int entry_index = 0; for (unsigned int i = 0; i < number_of_variables; i++) { bool entry_found = false; diff --git a/src/utilities/vectorBCFunction.cc b/src/utilities/vectorBCFunction.cc index ff4bfb6b7..fe683b7d0 100644 --- a/src/utilities/vectorBCFunction.cc +++ b/src/utilities/vectorBCFunction.cc @@ -35,7 +35,9 @@ vectorBCFunction::vector_value_list( { const unsigned int n_points = points.size(); for (unsigned int p = 0; p < n_points; ++p) - vectorBCFunction::vector_value(points[p], value_list[p]); + { + vectorBCFunction::vector_value(points[p], value_list[p]); + } } template class vectorBCFunction<1>; diff --git a/src/variableAttributeLoader/variableAttributeLoader.cc b/src/variableAttributeLoader/variableAttributeLoader.cc index 1a15ab204..26e946d9a 100644 --- a/src/variableAttributeLoader/variableAttributeLoader.cc +++ b/src/variableAttributeLoader/variableAttributeLoader.cc @@ -16,16 +16,16 @@ variableAttributeLoader::variableAttributeLoader() number_of_variables, EXPLICIT_TIME_DEPENDENT); - std::vector sorted_dependencies_value_RHS = + const std::vector sorted_dependencies_value_RHS = sortIndexEntryPairList(var_eq_dependencies_value_RHS, number_of_variables, ""); - std::vector sorted_dependencies_gradient_RHS = + const std::vector sorted_dependencies_gradient_RHS = sortIndexEntryPairList(var_eq_dependencies_gradient_RHS, number_of_variables, ""); - std::vector sorted_dependencies_value_LHS = + const std::vector sorted_dependencies_value_LHS = sortIndexEntryPairList(var_eq_dependencies_value_LHS, number_of_variables, ""); - std::vector sorted_dependencies_gradient_LHS = + const std::vector sorted_dependencies_gradient_LHS = sortIndexEntryPairList(var_eq_dependencies_gradient_LHS, number_of_variables, ""); nucleating_variable = @@ -49,10 +49,10 @@ variableAttributeLoader::variableAttributeLoader() pp_var_name = sortIndexEntryPairList(var_name_list_PP, pp_number_of_variables, "var"); pp_var_type = sortIndexEntryPairList(var_type_list_PP, pp_number_of_variables, SCALAR); - std::vector pp_sorted_dependencies_value = + const std::vector pp_sorted_dependencies_value = sortIndexEntryPairList(var_eq_dependencies_value_PP, pp_number_of_variables, ""); - std::vector pp_sorted_dependencies_gradient = + const std::vector pp_sorted_dependencies_gradient = sortIndexEntryPairList(var_eq_dependencies_gradient_PP, pp_number_of_variables, ""); pp_calc_integral = From fe7028984b800afda9d2bd57ed714b61bfc54f5e Mon Sep 17 00:00:00 2001 From: supriyoumich Date: Mon, 4 Nov 2024 11:58:28 -0500 Subject: [PATCH 15/28] Improved vtk file reading using rectilinear mesh (#286) * Add files via upload * Add files via upload * Add files via upload * Add files via upload * Add files via upload * Add files via upload * Add files via upload * Update parameters.prm added "set vtk file type" to select what type of vtk file to read * This is the 64X64 2D rectilinear mesh * Updated Body.hh for switch between RL and US mesh * Instructions on how to create a rectilinear mesh using dream3d and convert it * autoformatting * fixing warnings --------- Co-authored-by: Jason Landini --- .../grainGrowth_dream3d/20_grain_2D_RL.vtk | 492 ++++++++++++++++++ .../grainGrowth_dream3d/parameters.prm | 2 +- .../rectilinear_grid_instructions.pdf | Bin 0 -> 511495 bytes include/IntegrationTools/pfield/Body.hh | 192 ++++++- include/IntegrationTools/pfield/Coordinate.hh | 6 +- include/IntegrationTools/pfield/Mesh.hh | 280 ++++++---- include/userInputParameters.h | 5 +- src/inputFileReader/inputFileReader.cc | 10 + src/matrixfree/initialConditions.cc | 32 +- .../userInputParameters.cc | 5 +- 10 files changed, 888 insertions(+), 136 deletions(-) create mode 100644 applications/grainGrowth_dream3d/20_grain_2D_RL.vtk create mode 100644 applications/grainGrowth_dream3d/tex_files/rectilinear_grid_instructions.pdf diff --git a/applications/grainGrowth_dream3d/20_grain_2D_RL.vtk b/applications/grainGrowth_dream3d/20_grain_2D_RL.vtk new file mode 100644 index 000000000..c1416c72b --- /dev/null +++ b/applications/grainGrowth_dream3d/20_grain_2D_RL.vtk @@ -0,0 +1,492 @@ +# vtk DataFile Version 4.2 +vtk output +ASCII +DATASET RECTILINEAR_GRID +FIELD FieldData 3 +MeshName 1 1 string +mesh + +CYCLE 1 1 int +2 +TIME 1 1 double +2 +DIMENSIONS 65 65 1 +X_COORDINATES 65 double +0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 +Y_COORDINATES 65 double +0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 +Z_COORDINATES 1 double +0 +POINT_DATA 4225 +SCALARS FeatureIds double +LOOKUP_TABLE default +3 3 3 3 3 3 3 3 3 +3 3 3 3 17 17 17 17 17 +17 17 17 17 17 17 17 17 19 +19 19 19 19 19 19 19 19 19 +19 19 19 4 4 4 4 4 4 +4 4 4 4 4 2 2 2 2 +2 2 2 2 2 2 2 2 2 +2 2 3 3 3 3 3 3 3 +3 3 3 3 3 3 17 17 17 +17 17 17 17 17 17 17 17 17 +17 19 19 19 19 19 19 19 19 +19 19 19 19 19 4 4 4 4 +4 4 4 4 4 4 4 4 2 +2 2 2 2 2 2 2 2 2 +2 2 2 2 3 3 3 3 3 +3 3 3 3 3 3 3 3 17 +17 17 17 17 17 17 17 17 17 +17 17 17 19 19 19 19 19 19 +19 19 19 19 19 19 19 4 4 +4 4 4 4 4 4 4 4 4 +4 4 2 2 2 2 2 2 2 +2 2 2 2 2 2 3 3 3 +3 3 3 3 3 3 3 3 3 +3 17 17 17 17 17 17 17 17 +17 17 17 17 17 19 19 19 19 +19 19 19 19 19 19 19 19 19 +4 4 4 4 4 4 4 4 4 +4 4 4 4 4 2 2 2 2 +2 2 2 2 2 2 2 2 3 +3 3 3 3 3 3 3 3 3 +3 3 17 17 17 17 17 17 17 +17 17 17 17 17 17 17 19 19 +19 19 19 19 19 19 19 19 19 +19 19 4 4 4 4 4 4 4 +4 4 4 4 4 4 4 2 2 +2 2 2 2 2 2 2 2 2 +2 3 3 3 3 3 3 3 3 +3 3 3 17 17 17 17 17 17 +17 17 17 17 17 17 17 17 17 +19 19 19 19 19 19 19 19 19 +19 19 19 19 19 4 4 4 4 +4 4 4 4 4 4 4 4 4 +4 2 2 2 2 2 2 2 2 +2 2 2 13 13 13 13 3 3 +3 3 3 3 17 17 17 17 17 +17 17 17 17 17 17 17 17 17 +17 17 19 19 19 19 19 19 19 +19 19 19 19 19 19 19 4 4 +4 4 4 4 4 4 4 4 4 +4 4 4 2 2 2 16 16 16 +16 16 16 16 16 13 13 13 13 +13 13 3 3 3 3 17 17 17 +17 17 17 17 17 17 17 17 17 +17 17 17 17 19 19 19 19 19 +19 19 19 19 19 19 19 19 19 +19 4 4 4 4 4 4 4 4 +4 4 4 4 4 2 16 16 16 +16 16 16 16 16 16 16 13 13 +13 13 13 13 13 13 13 13 17 +17 17 17 17 17 17 17 17 17 +17 17 17 17 17 17 19 19 19 +19 19 19 19 19 19 19 19 19 +19 19 19 12 12 12 12 12 12 +12 4 4 4 4 4 4 16 16 +16 16 16 16 16 16 16 16 16 +13 13 13 13 13 13 13 13 13 +13 17 17 17 17 17 17 17 17 +17 17 17 17 9 9 9 9 19 +19 19 19 19 19 19 19 19 19 +19 19 19 19 19 12 12 12 12 +12 12 12 12 12 12 4 4 16 +16 16 16 16 16 16 16 16 16 +16 16 13 13 13 13 13 13 13 +13 13 13 8 17 17 17 17 17 +17 17 17 17 9 9 9 9 9 +9 19 19 19 19 19 19 19 19 +19 19 19 19 19 19 19 12 12 +12 12 12 12 12 12 12 12 12 +12 16 16 16 16 16 16 16 16 +16 16 16 16 13 13 13 13 13 +13 13 13 13 13 8 8 17 17 +17 17 17 17 17 9 9 9 9 +9 9 9 19 19 19 19 19 19 +19 19 19 19 19 19 19 19 19 +12 12 12 12 12 12 12 12 12 +12 12 12 16 16 16 16 16 16 +16 16 16 16 16 16 13 13 13 +13 13 13 13 13 13 8 8 8 +8 17 17 17 17 17 9 9 9 +9 9 9 9 9 9 19 19 19 +19 19 19 19 19 19 19 19 19 +19 19 12 12 12 12 12 12 12 +12 12 12 12 12 16 16 16 16 +16 16 16 16 16 16 16 16 13 +13 13 13 13 13 13 13 13 8 +8 8 8 8 17 17 17 9 9 +9 9 9 9 9 9 9 9 19 +19 19 19 19 19 19 19 19 19 +19 19 19 19 12 12 12 12 12 +12 12 12 12 12 12 12 16 16 +16 16 16 16 16 16 16 16 16 +16 13 13 13 13 13 13 13 13 +8 8 8 8 8 8 8 8 9 +9 9 9 9 9 9 9 9 9 +9 19 19 19 19 19 19 19 19 +19 19 19 19 19 12 12 12 12 +12 12 12 12 12 12 12 12 12 +12 16 16 16 16 16 16 16 16 +16 16 16 13 13 13 13 13 13 +13 8 8 8 8 8 8 8 8 +8 9 9 9 9 9 9 9 9 +9 9 9 9 19 19 19 19 19 +19 19 19 19 19 19 19 12 12 +12 12 12 12 12 12 12 12 12 +12 12 12 16 16 16 16 16 16 +16 16 16 16 16 20 20 20 13 +13 13 13 8 8 8 8 8 8 +8 8 8 8 9 9 9 9 9 +9 9 9 9 9 9 19 19 19 +19 19 19 19 19 19 19 19 19 +12 12 12 12 12 12 12 12 12 +12 12 12 12 12 16 16 16 16 +16 16 16 16 16 16 16 20 20 +20 20 20 13 8 8 8 8 8 +8 8 8 8 8 8 9 9 9 +9 9 9 9 9 9 9 9 19 +19 19 19 19 19 19 19 19 19 +19 19 12 12 12 12 12 12 12 +12 12 12 12 12 12 12 16 16 +16 16 16 16 16 16 16 16 16 +20 20 20 20 20 20 8 8 8 +8 8 8 8 8 8 8 8 9 +9 9 9 9 9 9 9 9 9 +9 19 19 19 19 19 19 19 19 +19 19 19 5 5 12 12 12 12 +12 12 12 12 12 12 12 12 12 +16 16 16 16 16 16 16 16 16 +16 16 20 20 20 20 20 20 20 +8 8 8 8 8 8 8 8 8 +8 9 9 9 9 9 9 9 9 +9 9 9 19 19 19 19 19 19 +19 19 19 19 5 5 5 5 12 +12 12 12 12 12 12 12 12 12 +12 12 16 16 16 16 16 16 16 +16 16 16 16 20 20 20 20 20 +20 20 20 8 8 8 8 8 8 +8 8 8 9 9 9 9 9 9 +9 9 9 9 9 19 19 19 19 +19 19 19 19 19 5 5 5 5 +5 5 12 12 12 12 12 12 12 +12 12 12 12 16 16 16 16 16 +16 16 16 16 16 16 20 20 20 +20 20 20 20 20 20 8 8 8 +8 8 8 8 8 9 9 9 9 +9 9 9 9 9 9 9 19 19 +19 19 19 19 19 19 5 5 5 +5 5 5 5 5 12 12 12 12 +12 12 12 12 12 12 6 6 6 +16 16 16 16 16 16 16 16 20 +20 20 20 20 20 20 20 20 20 +8 8 8 8 8 8 8 9 9 +9 9 9 9 9 9 9 9 9 +19 19 19 19 19 19 19 5 5 +5 5 5 5 5 5 5 5 12 +12 12 12 12 12 12 12 6 6 +6 6 6 6 6 6 6 6 6 +6 20 20 20 20 20 20 20 20 +20 20 8 8 8 8 8 8 8 +9 9 9 9 9 9 9 9 9 +9 9 19 19 19 19 19 5 5 +5 5 5 5 5 5 5 5 5 +5 5 12 12 12 12 12 12 6 +6 6 6 6 6 6 6 6 6 +6 6 6 20 20 20 20 20 20 +20 20 20 20 8 8 8 8 8 +8 8 9 9 9 9 9 9 9 +9 9 9 9 7 7 5 5 5 +5 5 5 5 5 5 5 5 5 +5 5 5 5 5 5 12 12 12 +6 6 6 6 6 6 6 6 6 +6 6 6 6 6 20 20 20 20 +20 20 20 20 20 20 8 8 8 +8 8 8 8 9 9 9 9 9 +9 9 9 9 9 7 7 7 5 +5 5 5 5 5 5 5 5 5 +5 5 5 5 5 5 5 5 5 +6 6 6 6 6 6 6 6 6 +6 6 6 6 6 6 6 20 20 +20 20 20 20 20 20 20 20 8 +8 8 8 8 8 8 9 9 9 +9 9 9 9 9 9 7 7 7 +7 5 5 5 5 5 5 5 5 +5 5 5 5 5 5 5 5 5 +5 5 6 6 6 6 6 6 6 +6 6 6 6 6 6 6 6 6 +15 15 15 15 15 15 15 15 15 +15 15 15 8 8 8 8 8 9 +9 9 9 9 9 9 9 7 7 +7 7 7 7 5 5 5 5 5 +5 5 5 5 5 5 5 5 5 +5 5 5 5 6 6 6 6 6 +6 6 6 6 6 6 6 6 6 +6 6 15 15 15 15 15 15 15 +15 15 15 15 15 15 15 15 15 +15 15 9 9 9 9 9 9 7 +7 7 7 7 7 7 7 5 5 +5 5 5 5 5 5 5 5 5 +5 5 5 5 5 5 6 6 6 +6 6 6 6 6 6 6 6 6 +6 6 6 6 15 15 15 15 15 +15 15 15 15 15 15 15 15 15 +15 15 15 15 15 9 9 9 7 +7 7 7 7 7 7 7 7 7 +5 5 5 5 5 5 5 5 5 +5 5 5 5 5 5 5 6 6 +6 6 6 6 6 6 6 6 6 +6 6 6 6 6 6 15 15 15 +15 15 15 15 15 15 15 15 15 +15 15 15 15 15 15 15 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 5 5 5 5 5 5 +5 5 5 5 5 5 5 5 5 +6 6 6 6 6 6 6 6 6 +6 6 6 6 6 6 6 6 15 +15 15 15 15 15 15 15 15 15 +15 15 15 15 15 15 15 15 15 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 5 5 5 +5 5 5 5 5 5 5 5 5 +5 5 6 6 6 6 6 6 6 +6 6 6 6 6 6 6 6 6 +6 15 15 15 15 15 15 15 15 +15 15 15 15 15 15 15 15 15 +15 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +5 5 5 5 5 5 5 5 5 +5 5 5 5 6 6 6 6 6 +6 6 6 6 6 6 6 6 6 +6 6 6 15 15 15 15 15 15 +15 15 15 15 15 15 15 15 15 +15 15 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 5 5 5 5 5 5 +5 5 5 5 5 5 6 6 6 +6 6 6 6 6 6 6 6 6 +6 6 6 6 6 15 15 15 15 +15 15 15 15 15 15 15 15 15 +15 15 15 15 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 5 5 5 +5 5 5 5 5 5 5 5 6 +6 6 6 6 6 6 6 6 6 +6 6 6 6 6 6 6 15 15 +15 15 15 15 15 15 15 15 15 +15 15 15 15 15 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +5 5 5 5 5 5 5 5 5 +11 11 11 11 6 6 6 6 6 +6 6 6 6 6 6 6 6 6 +15 15 15 15 15 15 15 15 15 +15 15 15 15 15 15 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 5 5 5 5 5 5 +5 11 11 11 11 11 11 11 6 +6 6 6 6 6 6 6 6 6 +6 6 15 15 15 15 15 15 15 +15 15 15 15 15 15 15 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 5 5 5 5 +5 5 11 11 11 11 11 11 11 +11 11 6 6 6 6 6 6 6 +10 10 10 10 15 15 15 15 15 +15 15 15 15 15 15 15 15 15 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 5 5 +5 5 5 11 11 11 11 11 11 +11 11 11 11 11 6 6 6 6 +10 10 10 10 10 10 15 15 15 +15 15 15 15 15 15 15 15 15 +15 15 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +5 5 5 5 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +6 10 10 10 10 10 10 10 15 +15 15 15 15 15 15 15 15 15 +15 15 15 15 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 5 5 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 10 10 10 10 10 10 10 +10 15 15 15 15 15 15 15 15 +15 15 15 18 18 18 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 10 10 10 10 10 +10 10 10 15 15 15 15 15 15 +15 15 15 18 18 18 18 18 18 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 10 10 10 +10 10 10 10 10 15 15 15 15 +15 15 15 15 18 18 18 18 18 +18 18 18 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 10 +10 10 10 10 10 10 10 15 15 +15 15 15 15 15 18 18 18 18 +18 18 18 18 18 18 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 10 10 10 10 10 10 10 10 +15 15 15 15 15 15 18 18 18 +18 18 18 18 18 18 18 18 18 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 10 10 10 10 10 10 +10 10 15 15 15 15 15 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 11 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 10 10 10 10 10 +10 10 10 10 15 15 15 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 7 7 7 +7 7 7 7 7 7 7 7 7 +7 7 7 7 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 10 10 10 +10 10 10 10 10 10 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +7 7 7 7 7 7 7 7 7 +7 7 7 7 7 7 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 10 +10 10 10 10 10 10 10 10 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 7 7 7 7 7 7 +7 7 7 7 7 7 7 7 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +10 10 10 10 10 10 10 10 10 +10 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 7 7 7 +7 7 7 7 7 7 7 7 7 +7 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 10 10 10 10 10 10 10 +10 10 10 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +7 7 7 7 7 7 7 7 7 +7 7 7 11 11 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 10 10 10 10 10 +10 10 10 10 10 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 7 7 7 7 7 7 +7 7 7 7 7 11 11 11 11 +11 11 11 11 11 11 11 11 11 +11 11 11 11 11 11 10 10 10 +10 10 10 10 10 10 10 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 7 7 7 +7 7 7 7 7 7 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 10 +10 10 10 10 10 10 10 10 10 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +7 7 7 7 7 7 7 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 10 10 10 10 10 10 10 10 +10 10 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 7 7 7 7 7 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 1 1 1 1 1 1 +1 1 1 1 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 7 7 7 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 1 1 1 1 +1 1 1 1 1 1 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 1 1 +1 1 1 1 1 1 1 1 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +1 1 1 1 1 1 1 1 1 +1 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 1 1 1 1 1 1 1 +1 1 1 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 1 1 1 1 1 +1 1 1 1 1 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 1 1 1 +1 1 1 1 1 1 1 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 1 +1 1 1 1 1 1 1 1 1 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 1 1 1 1 1 1 1 1 +1 1 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 18 18 18 18 18 +18 18 18 18 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 14 14 14 14 14 14 +14 14 14 1 1 1 1 1 1 +1 1 1 1 diff --git a/applications/grainGrowth_dream3d/parameters.prm b/applications/grainGrowth_dream3d/parameters.prm index d5ba8342c..0a7647f4b 100644 --- a/applications/grainGrowth_dream3d/parameters.prm +++ b/applications/grainGrowth_dream3d/parameters.prm @@ -10,7 +10,7 @@ set Number of dimensions = 2 # Each axes spans from zero to the specified length set Domain size X = 64 set Domain size Y = 64 -set Domain size Z = 100 +set Domain size Z = 1 # ================================================================================= # Set the element parameters diff --git a/applications/grainGrowth_dream3d/tex_files/rectilinear_grid_instructions.pdf b/applications/grainGrowth_dream3d/tex_files/rectilinear_grid_instructions.pdf new file mode 100644 index 0000000000000000000000000000000000000000..8aa220d6e92463503f378f1f1a0de4e631e21243 GIT binary patch literal 511495 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�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�q}ao0 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¬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

o>0dbBq7kxV?>1;k|t8^Z(W1{|XC@w%FJ}BY*;e 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

?N)6~&GfnF9zV}?RrgHat52Kbc?b=a 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%0A)L9N0&(k4m5$_>EtL>)_<)n&)}x|8%zdN}rXS{U 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 literal 0 HcmV?d00001 diff --git a/include/IntegrationTools/pfield/Body.hh b/include/IntegrationTools/pfield/Body.hh index 2fb4ea0bd..9d28d0201 100644 --- a/include/IntegrationTools/pfield/Body.hh +++ b/include/IntegrationTools/pfield/Body.hh @@ -1,4 +1,3 @@ - #ifndef Body_HH #define Body_HH @@ -39,7 +38,7 @@ namespace PRISMS void read_vtk(const std::string &vtkfile) { - std::cout << "Begin reading vtk file" << std::endl; + std::cout << "Begin reading unstructured vtk file" << std::endl; // read in vtk file here std::ifstream infile_mesh(vtkfile.c_str()); @@ -53,7 +52,7 @@ namespace PRISMS std::istringstream ss; std::string str, name, type, line; int numcomp; - unsigned long int Npoints; + unsigned long int Npoints, u, p; while (!infile.eof()) { @@ -69,7 +68,8 @@ namespace PRISMS ss >> str >> Npoints; } } - else if (line[0] == 'S') + + if (line[0] == 'S') { if (line.size() > 6 && line.substr(0, 7) == "SCALARS") { @@ -82,10 +82,11 @@ namespace PRISMS // read data std::cout << "begin reading data" << std::endl; - std::vector data(Npoints); + + std::vector gid(Npoints); for (unsigned int i = 0; i < Npoints; i++) { - infile >> data[i]; + infile >> gid[i]; // std::cout << data[i] << std::endl; } std::cout << " done" << std::endl; @@ -94,14 +95,14 @@ namespace PRISMS std::vector var_name(DIM); std::vector var_description(DIM); - if (DIM >= 2) + if (DIM == 2) { var_name[0] = "x"; var_description[0] = "x coordinate"; var_name[1] = "y"; var_description[1] = "y coordinate"; } - if (DIM >= 3) + if (DIM > 2) { var_name[2] = "z"; var_description[2] = "z coordinate"; @@ -112,49 +113,191 @@ namespace PRISMS var_name, var_description, mesh, - data, + gid, 0.0)); std::cout << " done" << std::endl; + + gid.clear(); + // + } + } + } + + infile.close(); + } + + void + read_RL_vtk(const std::string &vtkfile) + { + std::cout << "Begin reading vtk file" << std::endl; + + // read in vtk file here + std::ifstream infile_mesh(vtkfile.c_str()); + + // read mesh info + mesh.read_RL_vtk(infile_mesh); + + std::ifstream infile(vtkfile.c_str()); + + // read point data + std::istringstream ss; + std::string str, name, type, line; + int numcomp; + unsigned long int N_points, Npoints_x, Npoints_y, Npoints_z, Npoints, u, p; + + while (!infile.eof()) + { + std::getline(infile, line); + + if (line[0] == 'X') + { + if (line.size() > 12 && line.substr(0, 13) == "X_COORDINATES") + { + // read header line + // std::cout << line << "\n"; + ss.clear(); + ss.str(line); + ss >> str >> Npoints_x >> type; + + std::cout << "Read X_COORDINATES: " << Npoints_x << std::endl; + + // std::cout << " reserve OK" << std::endl; } } - // Alternative field descriptor used by ParaView (holds the same information as - // the "SCALAR" line above) - else if (line[0] == 'F') + if (line[0] == 'Y') { - if (line.size() > 14 && line.substr(0, 15) == "FIELD FieldData") + if (line.size() > 12 && line.substr(0, 13) == "Y_COORDINATES") { + // read header line + // std::cout << line << "\n"; ss.clear(); ss.str(line); - ss >> str >> numcomp; + ss >> str >> Npoints_y >> type; - // read LOOKUP_TABLE line - std::getline(infile, line); + // read points + + std::cout << "Read Y_COORDINATES: " << Npoints_y << std::endl; + // std::cout << " reserve OK" << std::endl; + } + } + if (line[0] == 'Z') + { + if (line.size() > 12 && line.substr(0, 13) == "Z_COORDINATES") + { + // read header line + // std::cout << line << "\n"; + ss.clear(); + ss.str(line); + ss >> str >> Npoints_z >> type; + + // read points + + std::cout << "Read Z_COORDINATES: " << Npoints_z << std::endl; + + // std::cout << " reserve OK" << std::endl; + } + } + + if (line[0] == 'S') + { + if (line.size() > 6 && line.substr(0, 7) == "SCALARS") + { ss.clear(); ss.str(line); - ss >> name >> numcomp >> Npoints >> type; + ss >> str >> name >> type >> numcomp; + + // read LOOKUP_TABLE line + std::getline(infile, line); // read data std::cout << "begin reading data" << std::endl; - std::vector data(Npoints); - for (unsigned int i = 0; i < Npoints; i++) + + N_points = (Npoints_x) * (Npoints_y) * (Npoints_z); + + if (DIM > 2) + { + Npoints = 8 * (Npoints_x - 1) * (Npoints_y - 1) * (Npoints_z - 1); + } + if (DIM == 2) + { + Npoints = 4 * (Npoints_x - 1) * (Npoints_y - 1); + } + + std::vector data( + N_points); // NB: data and gid are of different size + std::vector gid(Npoints); // gid is the grainID for each node + // unsigned int gid[Npoints]; + + for (unsigned int i = 0; i < N_points; i++) { infile >> data[i]; + // std::cout << data[i] << std::endl; } - std::cout << " done" << std::endl; + + std::cout << "beginning grain_id stencil" << std::endl; + + u = 0; + if (DIM > 2) + { + for (unsigned int i = 0; i < (Npoints_z - 1); i++) + { + for (unsigned int j = 0; j < (Npoints_y - 1); j++) + { + for (unsigned int k = 0; k < (Npoints_x - 1); k++) + { + p = k + j * Npoints_x + i * Npoints_x * Npoints_y; + + gid[u] = data[p]; + gid[u + 1] = data[p + 1]; + gid[u + 2] = data[p + Npoints_x]; + gid[u + 3] = data[p + Npoints_x + 1]; + gid[u + 4] = data[p + Npoints_x * Npoints_y]; + gid[u + 5] = data[p + Npoints_x * Npoints_y + 1]; + gid[u + 6] = + data[p + Npoints_x + Npoints_x * Npoints_y]; + gid[u + 7] = + data[p + Npoints_x + Npoints_x * Npoints_y + 1]; + + u += 8; + } + } + } + } + + if (DIM == 2) + { + for (unsigned int j = 0; j < (Npoints_y - 1); j++) + { + for (unsigned int k = 0; k < (Npoints_x - 1); k++) + { + p = k + j * Npoints_x; + + gid[u] = data[p]; + gid[u + 1] = data[p + 1]; + gid[u + 2] = data[p + Npoints_x]; + gid[u + 3] = data[p + Npoints_x + 1]; + + u += 4; + } + } + } + + data.clear(); + // MPI_Barrier(MPI_COMM_WORLD); // construct field std::vector var_name(DIM); std::vector var_description(DIM); - if (DIM >= 2) + if (DIM == 2) { var_name[0] = "x"; var_description[0] = "x coordinate"; var_name[1] = "y"; var_description[1] = "y coordinate"; } - if (DIM >= 3) + if (DIM > 2) { var_name[2] = "z"; var_description[2] = "z coordinate"; @@ -165,9 +308,12 @@ namespace PRISMS var_name, var_description, mesh, - data, + gid, 0.0)); std::cout << " done" << std::endl; + + gid.clear(); + // } } } diff --git a/include/IntegrationTools/pfield/Coordinate.hh b/include/IntegrationTools/pfield/Coordinate.hh index ce5f04cd5..b2fc93c5f 100644 --- a/include/IntegrationTools/pfield/Coordinate.hh +++ b/include/IntegrationTools/pfield/Coordinate.hh @@ -13,7 +13,7 @@ namespace PRISMS template class Coordinate { - double _coord[DIM]; + float _coord[DIM]; public: [[nodiscard]] int @@ -22,13 +22,13 @@ namespace PRISMS return DIM; } - double & + float & operator[](int i) { return _coord[i]; } - const double & + const float & operator[](int i) const { return _coord[i]; diff --git a/include/IntegrationTools/pfield/Mesh.hh b/include/IntegrationTools/pfield/Mesh.hh index 00f4ae80d..413d369e4 100644 --- a/include/IntegrationTools/pfield/Mesh.hh +++ b/include/IntegrationTools/pfield/Mesh.hh @@ -54,12 +54,12 @@ namespace PRISMS const std::string &name, unsigned long int cell, PFuncBase>, double> *bfunc_ptr, - const std::vector &cell_node, + const std::vector &cell_node, const std::vector> &node) { if (name == "Quad") { - Interpolator *interp_ptr = nullptr; + Interpolator *interp_ptr; // std::cout << "cell nodes: " << cell_node[0] << " " << cell_node[2] << // std::endl; @@ -95,12 +95,12 @@ namespace PRISMS const std::string &name, unsigned long int cell, PFuncBase>, double> *bfunc_ptr, - const std::vector &cell_node, + const std::vector &cell_node, const std::vector> &node) { if (name == "Hexahedron") { - Interpolator *interp_ptr = nullptr; + Interpolator *interp_ptr; PRISMS::Coordinate<3> dim; dim[0] = node[cell_node[6]][0] - node[cell_node[0]][0]; @@ -177,24 +177,26 @@ namespace PRISMS } }; - // reads vtk file through 'CELL_TYPES' and then returns void read_vtk(std::ifstream &infile) { - bool mesh_as_points = true; - std::vector x_coord, y_coord, z_coord; + std::cout << "Read unstructured mesh" << std::endl; std::istringstream ss; std::string line, str, type; - unsigned long int uli_dummy; - double d_dummy; + unsigned int uli_dummy; + double d_dummy; - unsigned long int Npoints, Ncells, Ncell_numbers; - std::vector cell_node; + unsigned long int Npoints, Ncells, Ncell_numbers, u; + std::vector cell_node; PRISMS::Coordinate _coord; + std::vector min; + std::vector N; + std::vector incr; + while (!infile.eof()) { std::getline(infile, line); @@ -244,26 +246,10 @@ namespace PRISMS std::cout << " done" << std::endl; // create bins - std::vector min; - std::vector N; - std::vector incr; std::cout << "Determine Body size" << std::endl; for (int j = 0; j < DIM; j++) { - for (unsigned int i = 1; i < hist[j].size(); i++) - { - /*if( hist[j][i] != hist[j][i-1]) - { - std::cout << "Error reading 2D vtk file." << std::endl; - std::cout << " Not rectangular." << std::endl; - std::cout << " Dimension: " << j << std::endl; - std::cout << value[j][i-1] << ": " << hist[j][i-1] << " " << - value[j][i] << ": " << hist[j][i] << std::endl; exit(1); - } - */ - } - std::sort(value[j].begin(), value[j].end()); // std::cout << "j: " << j << " back(): " << value[j].back() << // std::endl; @@ -295,6 +281,7 @@ namespace PRISMS std::cout << " done" << std::endl; } } + else if (line[0] == 'C') { if (line.size() > 4 && line.substr(0, 5) == "CELLS") @@ -305,8 +292,7 @@ namespace PRISMS ss >> str >> Ncells >> Ncell_numbers; - PFuncBase>, double> *bfunc_ptr = - nullptr; + PFuncBase>, double> *bfunc_ptr; _bfunc.push_back(bfunc_ptr); if (DIM == 2) @@ -393,15 +379,40 @@ namespace PRISMS return; } } + } + } + + // main code reading the RL coordinates and constructing cells and connectivity + // similar to unstructured grid + void + read_RL_vtk(std::ifstream &infile) + { + std::cout << "Read rectilinear file and create mesh" << std::endl; + + bool mesh_as_points = true; + std::vector x_coord, y_coord, z_coord; + + std::istringstream ss; + std::string line, str, type; + + unsigned int uli_dummy; + double d_dummy; + + unsigned long int Npoints, Ncells, Ncell_numbers, u; + std::vector cell_node; + + PRISMS::Coordinate _coord; + + std::vector min; + std::vector N; + std::vector incr; + + while (!infile.eof()) + { + std::getline(infile, line); + // std::cout << "line: " << line << std::endl; if (line[0] == 'X') { - mesh_as_points = false; - - // read X_COORDINATES info: - // X_COORDINATES # type - // x - // x - // ... if (line.size() > 12 && line.substr(0, 13) == "X_COORDINATES") { // read header line @@ -411,11 +422,10 @@ namespace PRISMS ss >> str >> Npoints >> type; std::cout << "Read X_COORDINATES: " << Npoints << std::endl; - _node.reserve(Npoints); std::cout << " reserve OK" << std::endl; for (unsigned int i = 0; i < Npoints; i++) { - double temp_coord; + float temp_coord; infile >> temp_coord; @@ -425,13 +435,6 @@ namespace PRISMS } if (line[0] == 'Y') { - mesh_as_points = false; - - // read Y_COORDINATES info: - // Y_COORDINATES # type - // y - // y - // ... if (line.size() > 12 && line.substr(0, 13) == "Y_COORDINATES") { // read header line @@ -441,15 +444,13 @@ namespace PRISMS ss >> str >> Npoints >> type; // read points - std::vector> value(DIM); - std::vector> hist(DIM); std::cout << "Read Y_COORDINATES: " << Npoints << std::endl; - _node.reserve(Npoints); + std::cout << " reserve OK" << std::endl; for (unsigned int i = 0; i < Npoints; i++) { - double temp_coord; + float temp_coord; infile >> temp_coord; @@ -459,13 +460,6 @@ namespace PRISMS } if (line[0] == 'Z') { - mesh_as_points = false; - - // read Z_COORDINATES info: - // Z_COORDINATES # type - // z - // z - // ... if (line.size() > 12 && line.substr(0, 13) == "Z_COORDINATES") { // read header line @@ -477,11 +471,11 @@ namespace PRISMS // read points std::cout << "Read Z_COORDINATES: " << Npoints << std::endl; - _node.reserve(Npoints); + std::cout << " reserve OK" << std::endl; for (unsigned int i = 0; i < Npoints; i++) { - double temp_coord; + float temp_coord; infile >> temp_coord; @@ -491,55 +485,126 @@ namespace PRISMS } } - if (!mesh_as_points) + if (mesh_as_points) { std::vector> value(DIM); std::vector> hist(DIM); - for (unsigned int i = 0; i < x_coord.size(); i++) + if (DIM > 2) + { + Npoints = + 8 * (x_coord.size() - 1) * (y_coord.size() - 1) * (z_coord.size() - 1); + } + if (DIM == 2) + { + Npoints = 4 * (x_coord.size() - 1) * (y_coord.size() - 1); + } + + // interpolated coordinates for each node of a cell + std::vector COORD_X(Npoints), COORD_Y(Npoints), COORD_Z(Npoints); + + u = 0; //(defined at the beginning of read_vtk) + if (DIM > 2) { - for (unsigned int j = 0; j < y_coord.size(); j++) + for (unsigned int i = 0; i < (z_coord.size() - 1); i++) { - for (unsigned int k = 0; k < z_coord.size(); k++) + for (unsigned int j = 0; j < (y_coord.size() - 1); j++) { - _coord[0] = x_coord.at(i); - _coord[1] = y_coord.at(j); - if (DIM > 2) + for (unsigned int k = 0; k < (x_coord.size() - 1); k++) { - _coord[2] = z_coord.at(k); - } + COORD_X[u] = x_coord.at(k); + COORD_Y[u] = y_coord.at(j); + COORD_Z[u] = z_coord.at(i); - for (int m = 0; m < DIM; m++) - add_once(value[m], hist[m], _coord[m]); + COORD_X[u + 1] = x_coord.at(k + 1); + COORD_Y[u + 1] = y_coord.at(j); + COORD_Z[u + 1] = z_coord.at(i); - _node.push_back(_coord); + COORD_X[u + 2] = x_coord.at(k); + COORD_Y[u + 2] = y_coord.at(j + 1); + COORD_Z[u + 2] = z_coord.at(i); + + COORD_X[u + 3] = x_coord.at(k + 1); + COORD_Y[u + 3] = y_coord.at(j + 1); + COORD_Z[u + 3] = z_coord.at(i); + + COORD_X[u + 4] = x_coord.at(k); + COORD_Y[u + 4] = y_coord.at(j); + COORD_Z[u + 4] = z_coord.at(i + 1); + + COORD_X[u + 5] = x_coord.at(k + 1); + COORD_Y[u + 5] = y_coord.at(j); + COORD_Z[u + 5] = z_coord.at(i + 1); + + COORD_X[u + 6] = x_coord.at(k); + COORD_Y[u + 6] = y_coord.at(j + 1); + COORD_Z[u + 6] = z_coord.at(i + 1); + + COORD_X[u + 7] = x_coord.at(k + 1); + COORD_Y[u + 7] = y_coord.at(j + 1); + COORD_Z[u + 7] = z_coord.at(i + 1); + + u += 8; + } } } } - std::cout << " done" << std::endl; + if (DIM == 2) + { + for (unsigned int j = 0; j < (y_coord.size() - 1); j++) + { + for (unsigned int k = 0; k < (x_coord.size() - 1); k++) + { + COORD_X[u] = x_coord.at(k); + COORD_Y[u] = y_coord.at(j); + COORD_Z[u] = z_coord.at(0); - // create bins - std::vector min; - std::vector N; - std::vector incr; + COORD_X[u + 1] = x_coord.at(k + 1); + COORD_Y[u + 1] = y_coord.at(j); + COORD_Z[u + 1] = z_coord.at(0); - std::cout << "Determine Body size" << std::endl; - for (int j = 0; j < DIM; j++) + COORD_X[u + 2] = x_coord.at(k); + COORD_Y[u + 2] = y_coord.at(j + 1); + COORD_Z[u + 2] = z_coord.at(0); + + COORD_X[u + 3] = x_coord.at(k + 1); + COORD_Y[u + 3] = y_coord.at(j + 1); + COORD_Z[u + 3] = z_coord.at(0); + + u += 4; + } + } + } + + // _node.reserve(Npoints); + for (unsigned int i = 0; i < Npoints; i++) { - for (unsigned int i = 1; i < hist[j].size(); i++) + _coord[0] = COORD_X[i]; + _coord[1] = COORD_Y[i]; + if (DIM > 2) { - /*if( hist[j][i] != hist[j][i-1]) - { - std::cout << "Error reading 2D vtk file." << std::endl; - std::cout << " Not rectangular." << std::endl; - std::cout << " Dimension: " << j << std::endl; - std::cout << value[j][i-1] << ": " << hist[j][i-1] << " " << - value[j][i] << ": " << hist[j][i] << std::endl; exit(1); - } - */ + _coord[2] = COORD_Z[i]; } + for (int m = 0; m < DIM; m++) + add_once(value[m], hist[m], _coord[m]); + + _node.push_back(_coord); + } + + x_coord.clear(); + y_coord.clear(); + z_coord.clear(); + COORD_X.clear(); + COORD_Y.clear(); + COORD_Z.clear(); + + std::cout << "point coordinates done" << std::endl; + + std::cout << "Determine Body size" << std::endl; + for (int j = 0; j < DIM; j++) + { std::sort(value[j].begin(), value[j].end()); // std::cout << "j: " << j << " back(): " << value[j].back() << std::endl; min.push_back(value[j][0]); @@ -570,32 +635,35 @@ namespace PRISMS std::cout << " done" << std::endl; // Now add the cell data - unsigned int Ncells = (x_coord.size() - 1) * (y_coord.size() - 1); - if (DIM > 2) + // unsigned int Ncells = (x_coord.size()-1) * (y_coord.size()-1); + if (DIM == 2) { - Ncells *= (z_coord.size() - 1); + Ncells = (_node.size() / 4); + } + else if (DIM > 2) + { + Ncells = (_node.size() / 8); } - PFuncBase>, double> *bfunc_ptr = nullptr; + PFuncBase>, double> *bfunc_ptr; _bfunc.push_back(bfunc_ptr); if (DIM == 2) { // add Quad basis function - _interp.reserve(Ncells * 4); + // _interp.reserve(Ncells*4); construct_basis_function(_bfunc.back(), "Quad"); } - else if (DIM == 3) + else if (DIM > 2) { // add Hexahedron basis function - _interp.reserve(Ncells * 8); + // _interp.reserve(Ncells*8); construct_basis_function(_bfunc.back(), "Hexahedron"); } bfunc_ptr = _bfunc.back(); std::cout << "Read CELLS: " << Ncells << std::endl; - unsigned int uli_dummy; if (DIM > 2) { uli_dummy = 8; @@ -604,9 +672,10 @@ namespace PRISMS { uli_dummy = 4; } + + cell_node.reserve(uli_dummy); for (unsigned int i = 0; i < Ncells; i++) { - cell_node.resize(uli_dummy); for (unsigned int j = 0; j < uli_dummy; j++) { cell_node[j] = i * uli_dummy + j; @@ -614,11 +683,13 @@ namespace PRISMS if (DIM == 2) { - double temp = cell_node[2]; - cell_node[2] = cell_node[3]; - cell_node[3] = temp; + std::swap(cell_node[2], cell_node[3]); + } + if (DIM > 2) + { + std::swap(cell_node[2], cell_node[3]); + std::swap(cell_node[6], cell_node[7]); } - // std::cout << cell_node[0] << " " << cell_node[1] << " " << cell_node[2] // << " " << cell_node[3] << std::endl; @@ -632,7 +703,7 @@ namespace PRISMS cell_node, _node); } - else if (DIM == 3) + else if (DIM > 2) { construct_interpolating_functions(_interp, "Hexahedron", @@ -642,15 +713,15 @@ namespace PRISMS _node); } } - std::cout << " done" << std::endl; + std::cout << "cell creation done" << std::endl; // bin interpolators std::cout << "Bin interpolating functions" << std::endl; std::cout << "num nodes: " << _node.size() << std::endl; for (unsigned int i = 0; i < _interp.size(); i++) { - std::cout << "interp: " << _interp[i] << " " << _interp[i]->min() << " " - << _interp[i]->max() << std::endl; + // std::cout << "interp: " << _interp[i] << " " << _interp[i]->min() << " " + // << _interp[i]->max() << std::endl; _bin.add_range(_interp[i], _interp[i]->min(), _interp[i]->max()); } std::cout << " done max_bin_size: " << _bin.max_size() << std::endl; @@ -855,7 +926,6 @@ namespace PRISMS // std::cout << "finish add_once()" << std::endl; } }; - } // namespace PRISMS #endif diff --git a/include/userInputParameters.h b/include/userInputParameters.h index a1566c625..b7d4c8a51 100644 --- a/include/userInputParameters.h +++ b/include/userInputParameters.h @@ -324,7 +324,10 @@ class userInputParameters double order_parameter_threshold; double buffer_between_grains; - bool load_grain_structure; + bool load_grain_structure; + std::string load_vtk_file_type; // adding this string to know what type of vtk file you + // want to read, it will be passed to + // initialconditions.cc double min_radius_for_loading_grains; std::string grain_structure_filename; std::string grain_structure_variable_name; diff --git a/src/inputFileReader/inputFileReader.cc b/src/inputFileReader/inputFileReader.cc index bbd2de577..00eff5830 100644 --- a/src/inputFileReader/inputFileReader.cc +++ b/src/inputFileReader/inputFileReader.cc @@ -786,6 +786,16 @@ inputFileReader::declare_parameters(dealii::ParameterHandler ¶meter_hand dealii::Patterns::Bool(), "Whether to load a grain structure in from file."); + parameter_handler.declare_entry( + "vtk file type", + "UNSTRUCTURED", + dealii::Patterns::Anything(), + "Whether to load an unstructured file for grain structure."); // reads the type of + // file from the input + // parameters.prm file, + // deafault setting is + // unstructured mesh + parameter_handler.declare_entry( "Grain structure filename", "", diff --git a/src/matrixfree/initialConditions.cc b/src/matrixfree/initialConditions.cc index cab1c2c17..2182fa4bc 100644 --- a/src/matrixfree/initialConditions.cc +++ b/src/matrixfree/initialConditions.cc @@ -90,7 +90,21 @@ MatrixFreePDE::applyInitialConditions() std::string filename = userInputs.grain_structure_filename; filename += ".vtk"; - body.read_vtk(filename); + // new section added for the choice of unstructured mesh and rectilinear mesh + if (userInputs.load_vtk_file_type == "UNSTRUCTURED") + { + body.read_vtk(filename); + } + else if (userInputs.load_vtk_file_type == "RECTILINEAR") + { + body.read_RL_vtk(filename); + } + else + { + pcout << "Error in vtk file type: Use either UNSTRUCTURED OR RECTILINEAR\n"; + abort(); + } // new section ends + ScalarField &id_field = body.find_scalar_field(userInputs.grain_structure_variable_name); @@ -344,7 +358,21 @@ MatrixFreePDE::applyInitialConditions() } std::cout << "Reading " << filename << "\n"; - body.read_vtk(filename); + // Load the data from the file using a PField + // new section added for the choice of unstructured mesh and rectilinear mesh + if (userInputs.load_vtk_file_type == "UNSTRUCTURED") + { + body.read_vtk(filename); + } + else if (userInputs.load_vtk_file_type == "RECTILINEAR") + { + body.read_RL_vtk(filename); + } + else + { + pcout << "Error in vtk file type: Use either UNSTRUCTURED OR RECTILINEAR\n"; + abort(); + } // new section ends for (const auto &index : index_list) { diff --git a/src/userInputParameters/userInputParameters.cc b/src/userInputParameters/userInputParameters.cc index 867648bde..30b565439 100644 --- a/src/userInputParameters/userInputParameters.cc +++ b/src/userInputParameters/userInputParameters.cc @@ -600,7 +600,10 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } } - load_grain_structure = parameter_handler.get_bool("Load grain structure"); + load_grain_structure = parameter_handler.get_bool("Load grain structure"); + load_vtk_file_type = + parameter_handler.get("vtk file type"); // assign the vtk file type and getting it + // ready to send to initialconditions.cc grain_structure_filename = parameter_handler.get("Grain structure filename"); grain_structure_variable_name = parameter_handler.get("Grain structure variable name"); num_grain_smoothing_cycles = parameter_handler.get_integer( From 52f71fca6f8c6452a652b531dff1293cbce499dd Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 4 Nov 2024 12:00:21 -0500 Subject: [PATCH 16/28] updating the number of timesteps in the automatic tests so that it takes less time --- .../gold_integratedFields.txt | 18 +++++----- .../CHAC_anisotropyRegularized/parameters.prm | 2 +- .../cahnHilliard/gold_integratedFields.txt | 20 +++++------ .../cahnHilliard/parameters.prm | 2 +- .../gold_integratedFields.txt | 20 +++++------ .../parameters.prm | 2 +- .../gold_integratedFields.txt | 20 +++++------ .../precipitateEvolution/parameters.prm | 2 +- tests/automatic_tests/test_results.txt | 35 +++++++++++++++++++ 9 files changed, 78 insertions(+), 43 deletions(-) diff --git a/tests/automatic_tests/CHAC_anisotropyRegularized/gold_integratedFields.txt b/tests/automatic_tests/CHAC_anisotropyRegularized/gold_integratedFields.txt index 5180d6c1f..9ae78b0fc 100644 --- a/tests/automatic_tests/CHAC_anisotropyRegularized/gold_integratedFields.txt +++ b/tests/automatic_tests/CHAC_anisotropyRegularized/gold_integratedFields.txt @@ -1,11 +1,11 @@ 0 f_tot 13.75327943 +25 f_tot 13.51630081 +50 f_tot 13.34759857 +75 f_tot 13.20778038 +100 f_tot 13.10931535 +125 f_tot 13.03298241 +150 f_tot 12.970002 +175 f_tot 12.91601893 200 f_tot 12.86862888 -400 f_tot 12.61546875 -600 f_tot 12.47241551 -800 f_tot 12.38346486 -1000 f_tot 12.32727188 -1200 f_tot 12.29142341 -1400 f_tot 12.2682066 -1600 f_tot 12.25308594 -1800 f_tot 12.24307128 -2000 f_tot 12.23634909 +225 f_tot 12.82628958 +250 f_tot 12.78805843 diff --git a/tests/automatic_tests/CHAC_anisotropyRegularized/parameters.prm b/tests/automatic_tests/CHAC_anisotropyRegularized/parameters.prm index b79221d02..dcf513c24 100644 --- a/tests/automatic_tests/CHAC_anisotropyRegularized/parameters.prm +++ b/tests/automatic_tests/CHAC_anisotropyRegularized/parameters.prm @@ -61,7 +61,7 @@ set Time step = 5.0e-2 # The simulation ends when either the number of time steps is reached or the # simulation time is reached. -set Number of time steps = 40000 +set Number of time steps = 5000 # ================================================================================= # Set the boundary conditions diff --git a/tests/automatic_tests/cahnHilliard/gold_integratedFields.txt b/tests/automatic_tests/cahnHilliard/gold_integratedFields.txt index 443234583..406acfea7 100644 --- a/tests/automatic_tests/cahnHilliard/gold_integratedFields.txt +++ b/tests/automatic_tests/cahnHilliard/gold_integratedFields.txt @@ -1,11 +1,11 @@ 0 f_tot 178.4134177 -10 f_tot 164.8375696 -20 f_tot 162.2879298 -30 f_tot 161.0827396 -40 f_tot 160.1467611 -50 f_tot 159.1850197 -60 f_tot 158.180812 -70 f_tot 157.2059481 -80 f_tot 156.3158274 -90 f_tot 155.5147671 -100 f_tot 154.7886179 +0.5 f_tot 172.667371 +1 f_tot 171.2161414 +1.5 f_tot 170.3036306 +2 f_tot 169.6330712 +2.5 f_tot 169.0973261 +3 f_tot 168.6452931 +3.5 f_tot 168.249016 +4 f_tot 167.8918812 +4.5 f_tot 167.5634379 +5 f_tot 167.2568298 diff --git a/tests/automatic_tests/cahnHilliard/parameters.prm b/tests/automatic_tests/cahnHilliard/parameters.prm index a10036331..a463d5567 100644 --- a/tests/automatic_tests/cahnHilliard/parameters.prm +++ b/tests/automatic_tests/cahnHilliard/parameters.prm @@ -35,7 +35,7 @@ set Time step = 1.0e-3 # The simulation ends when either the number of time steps is reached or the # simulation time is reached. -set Number of time steps = 100000 +set Number of time steps = 5000 # ================================================================================= # Set the boundary conditions diff --git a/tests/automatic_tests/coupledCahnHilliardAllenCahn/gold_integratedFields.txt b/tests/automatic_tests/coupledCahnHilliardAllenCahn/gold_integratedFields.txt index 8fd69162b..d27f4d1bf 100644 --- a/tests/automatic_tests/coupledCahnHilliardAllenCahn/gold_integratedFields.txt +++ b/tests/automatic_tests/coupledCahnHilliardAllenCahn/gold_integratedFields.txt @@ -1,11 +1,11 @@ 0 f_tot -17990.96133 -12 f_tot -17993.23453 -24 f_tot -17993.28446 -36 f_tot -17993.34482 -48 f_tot -17993.41925 -60 f_tot -17993.51311 -72 f_tot -17993.63119 -84 f_tot -17993.76989 -96 f_tot -17994.0319 -108 f_tot -17994.95862 -120 f_tot -17995.02466 +0.4 f_tot -17992.9989 +0.8 f_tot -17993.03655 +1.2 f_tot -17993.06419 +1.6 f_tot -17993.08606 +2 f_tot -17993.10394 +2.4 f_tot -17993.11881 +2.8 f_tot -17993.1313 +3.2 f_tot -17993.14186 +3.6 f_tot -17993.15082 +4 f_tot -17993.16868 diff --git a/tests/automatic_tests/coupledCahnHilliardAllenCahn/parameters.prm b/tests/automatic_tests/coupledCahnHilliardAllenCahn/parameters.prm index 96a09c3ab..73e02f02e 100644 --- a/tests/automatic_tests/coupledCahnHilliardAllenCahn/parameters.prm +++ b/tests/automatic_tests/coupledCahnHilliardAllenCahn/parameters.prm @@ -71,7 +71,7 @@ set Time step = 8.0e-4 # The simulation ends when either the number of time steps is reached or the # simulation time is reached. -set Number of time steps = 150000 +set Number of time steps = 5000 # ================================================================================= # Set the boundary conditions diff --git a/tests/automatic_tests/precipitateEvolution/gold_integratedFields.txt b/tests/automatic_tests/precipitateEvolution/gold_integratedFields.txt index 813251e62..7c8d329a5 100644 --- a/tests/automatic_tests/precipitateEvolution/gold_integratedFields.txt +++ b/tests/automatic_tests/precipitateEvolution/gold_integratedFields.txt @@ -1,11 +1,11 @@ 0 f_tot -2961.102683 -1.2 f_tot -2965.677541 -2.4 f_tot -2965.884581 -3.6 f_tot -2966.061709 -4.8 f_tot -2966.199195 -6 f_tot -2966.302869 -7.2 f_tot -2966.375264 -8.4 f_tot -2966.427108 -9.6 f_tot -2966.463559 -10.8 f_tot -2966.488198 -12 f_tot -2966.507931 +0.3 f_tot -2965.48483 +0.6 f_tot -2965.562625 +0.9 f_tot -2965.620716 +1.2 f_tot -2965.677529 +1.5 f_tot -2965.731282 +1.8 f_tot -2965.781551 +2.1 f_tot -2965.832435 +2.4 f_tot -2965.884556 +2.7 f_tot -2965.93272 +3 f_tot -2965.976343 diff --git a/tests/automatic_tests/precipitateEvolution/parameters.prm b/tests/automatic_tests/precipitateEvolution/parameters.prm index fd83ec417..952a83c2c 100644 --- a/tests/automatic_tests/precipitateEvolution/parameters.prm +++ b/tests/automatic_tests/precipitateEvolution/parameters.prm @@ -77,7 +77,7 @@ set Time step = 6.0e-4 # The simulation ends when either the number of time steps is reached or the # simulation time is reached. -set Number of time steps = 20000 +set Number of time steps = 5000 # ================================================================================= # Set the linear solver parameters diff --git a/tests/automatic_tests/test_results.txt b/tests/automatic_tests/test_results.txt index c744424ac..31a30082b 100644 --- a/tests/automatic_tests/test_results.txt +++ b/tests/automatic_tests/test_results.txt @@ -1757,3 +1757,38 @@ Time: 41.89884090423584 Tests Passed: 5/5 --------------------------------------------------------- +--------------------------------------------------------- +Unit test on 2024-11-04 11:55 +--------------------------------------------------------- +Unit Tests Passed: 22/22 +--------------------------------------------------------- +Regression test on 2024-11-04 11:55 +Architecture: x86_64 +Model name: AMD Ryzen 7 7745HX with Radeon Graphics +CPU(s): 16 +CPU max/min MHz: None, None +Hypervisor vendor: Microsoft +Number of processes: 1 +--------------------------------------------------------- +Application: allenCahn +Result: New Gold Standard +Time: 16.540193557739258 + +Application: cahnHilliard +Result: New Gold Standard +Time: 11.50249695777893 + +Application: CHAC_anisotropyRegularized +Result: New Gold Standard +Time: 12.078028440475464 + +Application: coupledCahnHilliardAllenCahn +Result: New Gold Standard +Time: 5.930960178375244 + +Application: precipitateEvolution +Result: New Gold Standard +Time: 66.96555471420288 + +Tests Passed: 5/5 +--------------------------------------------------------- From d78b5da1e93cf6af4f896e4fd040c2538bc80a07 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 4 Nov 2024 12:18:25 -0500 Subject: [PATCH 17/28] loosening tolerance of integrated fields --- tests/automatic_tests/run_automatic_tests.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/tests/automatic_tests/run_automatic_tests.py b/tests/automatic_tests/run_automatic_tests.py index 95ed528c3..5ad59dd81 100644 --- a/tests/automatic_tests/run_automatic_tests.py +++ b/tests/automatic_tests/run_automatic_tests.py @@ -146,7 +146,7 @@ def run_regression_test(application, new_gold_standard, test_dir): rel_diff = abs( (float(gold_last_energy) - float(last_energy)) / float(gold_last_energy) ) - test_passed = rel_diff < 1.0e-9 + test_passed = rel_diff < 1.0e-5 # Determine test result test_result = ( From 760b374fa0bb878c33c4109302cbfacc278cb6ff Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Tue, 5 Nov 2024 11:32:58 -0500 Subject: [PATCH 18/28] newline instead of endl --- src/SolverParameters/SolverParameters.cc | 3 +- src/inputFileReader/inputFileReader.cc | 4 +- src/matrixfree/checkpoint.cc | 4 +- src/matrixfree/init.cc | 12 ++--- src/matrixfree/nucleation.cc | 13 +++-- src/matrixfree/outputResults.cc | 5 +- src/matrixfree/reassignGrains.cc | 4 +- src/matrixfree/reinit.cc | 2 +- src/matrixfree/solveIncrement.cc | 12 ++--- .../parallelNucleationList.cc | 2 +- src/userInputParameters/load_BC_list.cc | 5 +- .../load_user_constants.cc | 34 +++++-------- .../userInputParameters.cc | 51 +++++++------------ src/variableContainer/variableContainer.cc | 24 ++++----- 14 files changed, 72 insertions(+), 103 deletions(-) diff --git a/src/SolverParameters/SolverParameters.cc b/src/SolverParameters/SolverParameters.cc index f1c64c2cc..c92dc55a4 100644 --- a/src/SolverParameters/SolverParameters.cc +++ b/src/SolverParameters/SolverParameters.cc @@ -23,8 +23,7 @@ SolverParametersBase::getEquationIndex(unsigned int global_index) } } std::cerr << "PRISMS-PF Error: Attempted access of a parameter for the " - "nonlinear solver for an ineligible variable index." - << std::endl; + "nonlinear solver for an ineligible variable index.\n"; abort(); } diff --git a/src/inputFileReader/inputFileReader.cc b/src/inputFileReader/inputFileReader.cc index 00eff5830..84411a9c6 100644 --- a/src/inputFileReader/inputFileReader.cc +++ b/src/inputFileReader/inputFileReader.cc @@ -32,8 +32,8 @@ inputFileReader::inputFileReader(const std::string &input_file_name, if (dealii::Utilities::MPI::this_mpi_process(MPI_COMM_WORLD) == 0) { - std::cout << "Number of constants: " << num_constants << std::endl; - std::cout << "Number of post-processing variables: " << num_pp_vars << std::endl; + std::cout << "Number of constants: " << num_constants << "\n"; + std::cout << "Number of post-processing variables: " << num_pp_vars << "\n"; } // Read in all of the parameters now diff --git a/src/matrixfree/checkpoint.cc b/src/matrixfree/checkpoint.cc index 9dc0ad239..125154beb 100644 --- a/src/matrixfree/checkpoint.cc +++ b/src/matrixfree/checkpoint.cc @@ -108,7 +108,7 @@ MatrixFreePDE::save_checkpoint() time_info_file.close(); } - pcout << "*** Checkpoint created! ***" << std::endl << std::endl; + pcout << "*** Checkpoint created! ***\n\n"; computing_timer.leave_subsection("matrixFreePDE: save_checkpoint"); } @@ -122,7 +122,7 @@ MatrixFreePDE::load_checkpoint_triangulation() verify_checkpoint_file_exists("restart.mesh"); verify_checkpoint_file_exists("restart.mesh.info"); - pcout << std::endl << "*** Resuming from a checkpoint! ***" << std::endl << std::endl; + pcout << "\n*** Resuming from a checkpoint! ***\n\n"; try { diff --git a/src/matrixfree/init.cc b/src/matrixfree/init.cc index f12121930..4cd3aef54 100644 --- a/src/matrixfree/init.cc +++ b/src/matrixfree/init.cc @@ -38,15 +38,14 @@ MatrixFreePDE::init() if (dim < 3) { pcout << "problem dimensions: " << userInputs.domain_size[0] << "x" - << userInputs.domain_size[1] << std::endl; + << userInputs.domain_size[1] << "\n"; } else { pcout << "problem dimensions: " << userInputs.domain_size[0] << "x" - << userInputs.domain_size[1] << "x" << userInputs.domain_size[2] << std::endl; + << userInputs.domain_size[1] << "x" << userInputs.domain_size[2] << "\n"; } - pcout << "number of elements: " << triangulation.n_global_active_cells() << std::endl; - pcout << std::endl; + pcout << "number of elements: " << triangulation.n_global_active_cells() << "\n\n"; // Setup system pcout << "initializing matrix free object\n"; @@ -96,8 +95,7 @@ MatrixFreePDE::init() isTimeDependentBVP = true; hasNonExplicitEquation = true; std::cerr << "PRISMS-PF Error: IMPLICIT_TIME_DEPENDENT equation " - "types are not currently supported" - << std::endl; + "types are not currently supported\n"; abort(); } else if (field.pdetype == AUXILIARY) @@ -228,7 +226,7 @@ MatrixFreePDE::init() constraintsDirichlet->n_constraints()); pcout << buffer; } - pcout << "total DOF : " << totalDOFs << std::endl; + pcout << "total DOF : " << totalDOFs << "\n"; // Setup the matrix free object typename MatrixFree::AdditionalData additional_data; diff --git a/src/matrixfree/nucleation.cc b/src/matrixfree/nucleation.cc index 53ed9b214..45f0d6c61 100644 --- a/src/matrixfree/nucleation.cc +++ b/src/matrixfree/nucleation.cc @@ -86,10 +86,10 @@ MatrixFreePDE::getNewNuclei() std::vector> newnuclei; // Get list of prospective new nuclei for the local processor - pcout << "Nucleation attempt for increment " << currentIncrement << std::endl; + pcout << "Nucleation attempt for increment " << currentIncrement << "\n"; getLocalNucleiList(newnuclei); - pcout << "nucleation attempt! " << currentTime << " " << currentIncrement << std::endl; + pcout << "nucleation attempt! " << currentTime << " " << currentIncrement << "\n"; // Generate global list of new nuclei and resolve conflicts between new nuclei parallelNucleationList new_nuclei_parallel(newnuclei); @@ -297,10 +297,10 @@ MatrixFreePDE::getLocalNucleiList(std::vector> &newnuc // Add nucleus to prospective list std::cout << "Prospective nucleation event. Nucleus no. " - << nuclei.size() + 1 << std::endl; - std::cout << "Nucleus center: " << nuc_ele_pos << std::endl; + << nuclei.size() + 1 << "\n"; + std::cout << "Nucleus center: " << nuc_ele_pos << "\n"; std::cout << "Nucleus order parameter: " << variable_index - << std::endl; + << "\n"; auto *temp = new nucleus; temp->index = nuclei.size(); temp->center = nuc_ele_pos; @@ -387,8 +387,7 @@ MatrixFreePDE::safetyCheckNewNuclei(std::vector> newn { isClose = true; std::cout << "Attempted nucleation failed due to " - "overlap w/ existing particle!!!!!!" - << std::endl; + "overlap w/ existing particle!\n"; conflict_ids.push_back(thisNucleus.index); break; } diff --git a/src/matrixfree/outputResults.cc b/src/matrixfree/outputResults.cc index 87904c4bd..8e33b3535 100644 --- a/src/matrixfree/outputResults.cc +++ b/src/matrixfree/outputResults.cc @@ -106,7 +106,7 @@ MatrixFreePDE::outputResults() } if (Utilities::MPI::this_mpi_process(MPI_COMM_WORLD) == 0) { - output_file << std::endl; + output_file << "\n"; } output_file.close(); first_integrated_var_output_complete = true; @@ -243,8 +243,7 @@ MatrixFreePDE::outputResults() else { std::cerr << "PRISMS-PF Error: The parameter 'outputFileType' must be " - "either \"vtu\" or \"vtk\"" - << std::endl; + "either \"vtu\" or \"vtk\"\n"; abort(); } diff --git a/src/matrixfree/reassignGrains.cc b/src/matrixfree/reassignGrains.cc index 6fb6942a5..75baebf32 100644 --- a/src/matrixfree/reassignGrains.cc +++ b/src/matrixfree/reassignGrains.cc @@ -11,7 +11,7 @@ MatrixFreePDE::reassignGrains() // log time computing_timer.enter_subsection("matrixFreePDE: reassignGrains"); - pcout << "Reassigning grains..." << std::endl; + pcout << "Reassigning grains...\n"; // Get the index of the first scalar field (used to get the FE object and // DOFHandler) @@ -106,7 +106,7 @@ MatrixFreePDE::reassignGrains() FESet.at(scalar_field_index)->dofs_per_cell, userInputs.buffer_between_grains); - pcout << "Reassigning grains completed." << std::endl << std::endl; + pcout << "Reassigning grains completed.\n\n"; // end log computing_timer.leave_subsection("matrixFreePDE: reassignGrains"); diff --git a/src/matrixfree/reinit.cc b/src/matrixfree/reinit.cc index f2d88eca9..cab085e8c 100644 --- a/src/matrixfree/reinit.cc +++ b/src/matrixfree/reinit.cc @@ -90,7 +90,7 @@ MatrixFreePDE::reinit() constraintsDirichlet->n_constraints()); pcout << buffer; } - pcout << "total DOF : " << totalDOFs << std::endl; + pcout << "total DOF : " << totalDOFs << "\n"; // Setup the matrix free object typename MatrixFree::AdditionalData additional_data; diff --git a/src/matrixfree/solveIncrement.cc b/src/matrixfree/solveIncrement.cc index 3b6e83bb9..80fdae7a2 100644 --- a/src/matrixfree/solveIncrement.cc +++ b/src/matrixfree/solveIncrement.cc @@ -166,7 +166,7 @@ MatrixFreePDE::solveIncrement(bool skip_time_dependent) pcout << "Relative difference between nonlinear " "iterations: " << diff << " " << nonlinear_it_index << " " - << currentIncrement << std::endl; + << currentIncrement << "\n"; } if (diff > userInputs.nonlinear_solver_parameters @@ -182,8 +182,7 @@ MatrixFreePDE::solveIncrement(bool skip_time_dependent) { std::cerr << "PRISMS-PF Error: Nonlinear solver tolerance " "types other than ABSOLUTE_CHANGE have yet to " - "be implemented." - << std::endl; + "be implemented.\n"; } } } @@ -398,7 +397,7 @@ MatrixFreePDE::updateImplicitSolution(unsigned int fieldIndex, { pcout << " Old residual: " << residual_old << " Damping Coeff: " << damping_coefficient - << " New Residual: " << residual_new << std::endl; + << " New Residual: " << residual_new << "\n"; } // An improved approach would use the @@ -483,7 +482,7 @@ MatrixFreePDE::updateImplicitSolution(unsigned int fieldIndex, pcout << "Relative difference between nonlinear " "iterations: " << diff << " " << nonlinear_it_index << " " << currentIncrement - << std::endl; + << "\n"; } if (diff > @@ -498,8 +497,7 @@ MatrixFreePDE::updateImplicitSolution(unsigned int fieldIndex, { std::cerr << "PRISMS-PF Error: Nonlinear solver tolerance " "types other than ABSOLUTE_CHANGE have yet to " - "be implemented." - << std::endl; + "be implemented.\n"; } } else diff --git a/src/parallelNucleationList/parallelNucleationList.cc b/src/parallelNucleationList/parallelNucleationList.cc index 76865b3dd..398ccfcd7 100644 --- a/src/parallelNucleationList/parallelNucleationList.cc +++ b/src/parallelNucleationList/parallelNucleationList.cc @@ -582,7 +582,7 @@ parallelNucleationList::removeSubsetOfNuclei( for (const unsigned int nuclei : nuclei_to_remove) { - std::cout << thisProc << ": " << nuclei << std::endl; + std::cout << thisProc << ": " << nuclei << "\n"; } // Remove the nuclei from the list diff --git a/src/userInputParameters/load_BC_list.cc b/src/userInputParameters/load_BC_list.cc index 0492cdd84..1c608c53e 100644 --- a/src/userInputParameters/load_BC_list.cc +++ b/src/userInputParameters/load_BC_list.cc @@ -67,9 +67,8 @@ userInputParameters::load_BC_list(const std::vector &list_of_B } else { - std::cout << temp[j].substr(0, 8) << std::endl; - std::cout << "Error: Boundary conditions specified improperly." - << std::endl; + std::cout << temp[j].substr(0, 8) << "\n"; + std::cout << "Error: Boundary conditions specified improperly.\n"; abort(); } diff --git a/src/userInputParameters/load_user_constants.cc b/src/userInputParameters/load_user_constants.cc index 979747197..2b96cdcd0 100644 --- a/src/userInputParameters/load_user_constants.cc +++ b/src/userInputParameters/load_user_constants.cc @@ -30,8 +30,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi if (model_constants_strings.size() < 2) { std::cerr << "PRISMS-PF ERROR: Users must input two fields for " - "user-defined variables (value and type)." - << std::endl; + "user-defined variables (value and type).\n"; abort(); } @@ -61,8 +60,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi { std::cerr << "PRISMS-PF ERROR: The type for user-defined " "variables must be 'double', 'int', 'bool', " - "'tensor', or 'elastic constants'." - << std::endl; + "'tensor', or 'elastic constants'.\n"; abort(); } } @@ -102,8 +100,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi if (open_parentheses != close_parentheses) { std::cerr << "PRISMS-PF ERROR: User-defined constant tensor does not " - "have the same number of open and close parentheses." - << std::endl; + "have the same number of open and close parentheses.\n"; abort(); } // Rank 1 tensor @@ -121,10 +118,10 @@ userInputParameters::load_user_constants(inputFileReader &input_fi } else { - std::cerr << "PRISMS-PF ERROR: The columns in user-defined " - "constant tensors cannot be longer than 3 elements " - "(internally truncated to the number of dimensions)." - << std::endl; + std::cerr + << "PRISMS-PF ERROR: The columns in user-defined " + "constant tensors cannot be longer than 3 elements " + "(internally truncated to the number of dimensions).\n"; abort(); } } @@ -139,8 +136,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi { std::cerr << "PRISMS-PF ERROR: User-defined constant tensor " "does not have enough elements, for 3D " - "calculations matrices must be 3x3." - << std::endl; + "calculations matrices must be 3x3.\n"; abort(); } } @@ -152,8 +148,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi { std::cerr << "PRISMS-PF ERROR: User-defined constant " "tensor does not have the correct number of " - "elements, matrices must be 2x2 or 3x3." - << std::endl; + "elements, matrices must be 2x2 or 3x3.\n"; abort(); } @@ -205,8 +200,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi { std::cerr << "PRISMS-PF ERROR: User-defined elastic constant " "list does not have the same number of open and " - "close parentheses." - << std::endl; + "close parentheses.\n"; abort(); } @@ -220,15 +214,14 @@ userInputParameters::load_user_constants(inputFileReader &input_fi const std::string elastic_const_symmetry = model_constants_type_strings.at(0); - dealii::Tensor<2, 2 *dim - 1 + dim / 3> temp = + dealii::Tensor<2, 2 * dim - 1 + dim / 3> temp = get_Cij_tensor(temp_elastic_constants, elastic_const_symmetry); model_constants.push_back(temp); } else { std::cerr << "PRISMS-PF ERROR: Only user-defined constant " - "tensors may have multiple elements." - << std::endl; + "tensors may have multiple elements.\n"; abort(); } } @@ -265,8 +258,7 @@ userInputParameters::get_Cij_tensor(std::vector elastic_constants, { // Should change to an exception std::cerr << "Elastic material model is invalid, please use isotropic, " - "transverse, orthotropic, or anisotropic" - << std::endl; + "transverse, orthotropic, or anisotropic\n"; } // If the material model is anisotropic for a 2D calculation but the elastic diff --git a/src/userInputParameters/userInputParameters.cc b/src/userInputParameters/userInputParameters.cc index 30b565439..81f33e2be 100644 --- a/src/userInputParameters/userInputParameters.cc +++ b/src/userInputParameters/userInputParameters.cc @@ -53,11 +53,10 @@ userInputParameters::userInputParameters(inputFileReader &input_fi { std::cerr << "PRISMS-PF Error: The initial refinement factor must be " "between the maximum and minimum refinement levels when " - "adaptive meshing is enabled." - << std::endl; + "adaptive meshing is enabled.\n"; std::cerr << "Initial refinement level: " << refine_factor << " Maximum and minimum refinement levels: " << max_refinement_level - << ", " << min_refinement_level << std::endl; + << ", " << min_refinement_level << "\n"; abort(); } @@ -91,8 +90,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi "refinement for variable " << new_criterion.variable_name << " is less than the lower bound. Please " - "correct this in the parameters file." - << std::endl; + "correct this in the parameters file.\n"; } } else if (boost::iequals(crit_type_string, "GRADIENT")) @@ -119,8 +117,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi "refinement for variable " << new_criterion.variable_name << " is less than the lower bound. Please " - "correct this in the parameters file." - << std::endl; + "correct this in the parameters file.\n"; } } else @@ -129,8 +126,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi "found in the parameters file, " << crit_type_string << ", is not an allowed type. The allowed types are " - "VALUE, GRADIENT, VALUE_AND_GRADIENT" - << std::endl; + "VALUE, GRADIENT, VALUE_AND_GRADIENT\n"; abort(); } refinement_criteria.push_back(new_criterion); @@ -172,8 +168,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi std::cerr << "PRISMS-PF Error: Linear solver tolerance type " << type_string << " is not currently implemented, please use either " - "ABSOLUTE_RESIDUAL or RELATIVE_RESIDUAL_CHANGE" - << std::endl; + "ABSOLUTE_RESIDUAL or RELATIVE_RESIDUAL_CHANGE\n"; abort(); } else @@ -181,8 +176,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi std::cerr << "PRISMS-PF Error: Linear solver tolerance type " << type_string << " is not one of the allowed values (ABSOLUTE_RESIDUAL, " - "RELATIVE_RESIDUAL_CHANGE, ABSOLUTE_SOLUTION_CHANGE)" - << std::endl; + "RELATIVE_RESIDUAL_CHANGE, ABSOLUTE_SOLUTION_CHANGE)\n"; abort(); } @@ -237,8 +231,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi std::cerr << "PRISMS-PF Error: Nonlinear solver tolerance type " << type_string << " is not one of the allowed values (ABSOLUTE_RESIDUAL, " - "RELATIVE_RESIDUAL_CHANGE, ABSOLUTE_SOLUTION_CHANGE)" - << std::endl; + "RELATIVE_RESIDUAL_CHANGE, ABSOLUTE_SOLUTION_CHANGE)\n"; abort(); } @@ -282,8 +275,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi "equations. The equation for variable " << var_name[i] << " is not a time independent equation. No initial " - "guess is needed for this equation." - << std::endl; + "guess is needed for this equation.\n"; } } @@ -333,8 +325,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi std::cout << "PRISMS-PF Warning: 'Output file type' given as 'vtk' and " "'Output separate files per process' given as 'false'. Shared " "output files are not supported for the vtk output format. " - "Separate files per process will be created." - << std::endl; + "Separate files per process will be created.\n"; } } @@ -389,9 +380,8 @@ userInputParameters::userInputParameters(inputFileReader &input_fi // Should change to an exception std::cerr << "Invalid selections for the final time and the number " "of increments. At least one should be given in the " - "input file and should be positive." - << std::endl; - std::cout << finalTime << " " << totalIncrements_temp << std::endl; + "input file and should be positive.\n"; + std::cout << finalTime << " " << totalIncrements_temp << "\n"; abort(); } } @@ -502,23 +492,20 @@ userInputParameters::userInputParameters(inputFileReader &input_fi { std::cerr << "PRISMS-PF Error: The number of nucleus semiaxes given in " "the 'parameters.in' file must be at least the number of " - "dimensions and no more than 3." - << std::endl; + "dimensions and no more than 3.\n"; abort(); } if (freeze_semiaxes.size() < dim || freeze_semiaxes.size() > 3) { std::cerr << "PRISMS-PF Error: The number of nucleation freeze zone " "semiaxes given in the 'parameters.in' file must be at " - "least the number of dimensions and no more than 3." - << std::endl; + "least the number of dimensions and no more than 3.\n"; abort(); } if (ellipsoid_rotation.size() != 3) { std::cerr << "PRISMS-PF Error: Exactly three nucleus rotation " - "angles must be given in the 'parameters.in' file." - << std::endl; + "angles must be given in the 'parameters.in' file.\n"; abort(); } } @@ -568,8 +555,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi { std::cerr << "PRISMS-PF Error: If grain reassignment is activated, a " "non-negative buffer distance must be given. See the 'Buffer " - "between grains before reassignment' entry in parameters.in." - << std::endl; + "between grains before reassignment' entry in parameters.in.\n"; abort(); } @@ -593,9 +579,8 @@ userInputParameters::userInputParameters(inputFileReader &input_fi { std::cerr << "PRISMS-PF Error: Entries in the list of order " "parameter fields used for grain reassignment must " - "match the variable names in equations.h." - << std::endl; - std::cerr << field << std::endl; + "match the variable names in equations.h.\n"; + std::cerr << field << "\n"; abort(); } } diff --git a/src/variableContainer/variableContainer.cc b/src/variableContainer/variableContainer.cc index 35ca18ffe..a4f976f44 100644 --- a/src/variableContainer/variableContainer.cc +++ b/src/variableContainer/variableContainer.cc @@ -324,7 +324,7 @@ variableContainer::get_scalar_value( std::cerr << "PRISMS-PF Error: Attempted access of a variable value that " "was not marked as needed in 'equations.cc'. The attempted " "access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -344,7 +344,7 @@ variableContainer::get_scalar_gradient( std::cerr << "PRISMS-PF Error: Attempted access of a variable gradient " "that was not marked as needed in 'equations.cc'. The " "attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -364,7 +364,7 @@ variableContainer::get_scalar_hessian( std::cerr << "PRISMS-PF Error: Attempted access of a variable hessian " "that was not marked as needed in 'equations.cc'. The " "attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -384,7 +384,7 @@ variableContainer::get_vector_value( std::cerr << "PRISMS-PF Error: Attempted access of a variable value that " "was not marked as needed in 'equations.cc'. The attempted " "access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -404,7 +404,7 @@ variableContainer::get_vector_gradient( std::cerr << "PRISMS-PF Error: Attempted access of a variable gradient " "that was not marked as needed in 'equations.cc'. The " "attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -424,7 +424,7 @@ variableContainer::get_vector_hessian( std::cerr << "PRISMS-PF Error: Attempted access of a variable hessian " "that was not marked as needed in 'equations.cc'. The " "attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -446,7 +446,7 @@ variableContainer::get_change_in_scalar_value( std::cerr << "PRISMS-PF Error: Attempted access of a change in variable " "value that was not marked as needed in 'equations.cc'. The " "attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -466,7 +466,7 @@ variableContainer::get_change_in_scalar_gradient( std::cerr << "PRISMS-PF Error: Attempted access of a change in variable " "gradient that was not marked as needed in 'equations.cc'. " "The attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -486,7 +486,7 @@ variableContainer::get_change_in_scalar_hessian( std::cerr << "PRISMS-PF Error: Attempted access of a change in variable " "hessian that was not marked as needed in 'equations.cc'. " "The attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -506,7 +506,7 @@ variableContainer::get_change_in_vector_value( std::cerr << "PRISMS-PF Error: Attempted access of a change in variable " "value that was not marked as needed in 'equations.cc'. The " "attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -526,7 +526,7 @@ variableContainer::get_change_in_vector_gradient( std::cerr << "PRISMS-PF Error: Attempted access of a change in variable " "gradient that was not marked as needed in 'equations.cc'. " "The attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } @@ -546,7 +546,7 @@ variableContainer::get_change_in_vector_hessian( std::cerr << "PRISMS-PF Error: Attempted access of a change in variable " "hessian that was not marked as needed in 'equations.cc'. " "The attempted access was for variable with index " - << global_variable_index << " ." << std::endl; + << global_variable_index << " .\n"; abort(); } } From d1a9ad4da08f83de7ad8267ca2ec4ba8532be58e Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Tue, 5 Nov 2024 11:37:02 -0500 Subject: [PATCH 19/28] Disabling some warnings since they're more trouble than they're worth. Ideally, we should include these, but it is too much to fix right now. --- .clang-tidy | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.clang-tidy b/.clang-tidy index a40848af4..6deb521be 100644 --- a/.clang-tidy +++ b/.clang-tidy @@ -9,9 +9,11 @@ Checks: > cppcoreguidelines-*, -cppcoreguidelines-avoid-const-or-ref-data-members, -cppcoreguidelines-non-private-member-variables-in-classes, + -cppcoreguidelines-avoid-magic-numbers, hicpp-*, misc-*, -misc-non-private-member-variables-in-classes, + -misc-include-cleaner, modernize-*, -modernize-use-trailing-return-type, mpi-*, @@ -20,5 +22,7 @@ Checks: > -readability-else-after-return, -readability-static-accessed-through-instance, -readability-avoid-const-params-in-decls, + -readability-magic-numbers, + -readability-identifier-length, WarningsAsErrors: '*' From 92ee810f2d7da55f67eeec4a89a5b84ee417aec3 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 11 Nov 2024 13:40:34 -0500 Subject: [PATCH 20/28] Misc changes --- src/matrixfree/setNonlinearEqInitialGuess.cc | 6 ++--- .../loadVariableAttributes.cc | 26 +++++++++---------- src/userInputParameters/load_BC_list.cc | 9 +++---- .../load_user_constants.cc | 2 +- src/userInputParameters/setTimeStepList.cc | 5 ++-- .../userInputParameters.cc | 7 ++--- src/utilities/vectorBCFunction.cc | 4 +-- 7 files changed, 30 insertions(+), 29 deletions(-) diff --git a/src/matrixfree/setNonlinearEqInitialGuess.cc b/src/matrixfree/setNonlinearEqInitialGuess.cc index e8ba24f3e..670727ed0 100644 --- a/src/matrixfree/setNonlinearEqInitialGuess.cc +++ b/src/matrixfree/setNonlinearEqInitialGuess.cc @@ -12,7 +12,8 @@ MatrixFreePDE::setNonlinearEqInitialGuess() // log time computing_timer.enter_subsection("matrixFreePDE: setNonlinearEqInitialGuess"); Timer time; - char buffer[200]; + time.start(); + char buffer[200]; for (unsigned int fieldIndex = 0; fieldIndex < fields.size(); fieldIndex++) { @@ -114,8 +115,7 @@ MatrixFreePDE::setNonlinearEqInitialGuess() solver_control.tolerance(), solutionSet[fieldIndex]->l2_norm(), dU_norm); - pcout << buffer; - pcout << std::endl; + pcout << buffer << "\n"; } } } diff --git a/src/userInputParameters/loadVariableAttributes.cc b/src/userInputParameters/loadVariableAttributes.cc index 82355d7e8..88e274ae3 100644 --- a/src/userInputParameters/loadVariableAttributes.cc +++ b/src/userInputParameters/loadVariableAttributes.cc @@ -53,7 +53,7 @@ userInputParameters::loadVariableAttributes( varInfoListExplicitRHS.reserve(num_var_explicit_RHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo { + const variable_info varInfo { var_type[i] == SCALAR, i, variable_attributes.equation_dependency_parser.eval_flags_explicit_RHS[i], @@ -78,7 +78,7 @@ userInputParameters::loadVariableAttributes( varInfoListNonexplicitRHS.reserve(num_var_nonexplicit_RHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo { + const variable_info varInfo { var_type[i] == SCALAR, i, variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_RHS[i], @@ -104,7 +104,7 @@ userInputParameters::loadVariableAttributes( varInfoListLHS.reserve(num_var_LHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo { + const variable_info varInfo { var_type[i] == SCALAR, i, variable_attributes.equation_dependency_parser.eval_flags_nonexplicit_LHS[i], @@ -118,14 +118,14 @@ userInputParameters::loadVariableAttributes( varChangeInfoListLHS.reserve(num_var_LHS); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo {var_type[i] == SCALAR, - i, - variable_attributes.equation_dependency_parser - .eval_flags_change_nonexplicit_LHS[i], - variable_attributes.equation_dependency_parser - .eval_flags_residual_nonexplicit_LHS[i], - !static_cast(varInfo.evaluation_flags & - dealii::EvaluationFlags::nothing)}; + const variable_info varInfo {var_type[i] == SCALAR, + i, + variable_attributes.equation_dependency_parser + .eval_flags_change_nonexplicit_LHS[i], + variable_attributes.equation_dependency_parser + .eval_flags_residual_nonexplicit_LHS[i], + !static_cast(varInfo.evaluation_flags & + dealii::EvaluationFlags::nothing)}; varChangeInfoListLHS.push_back(varInfo); } @@ -135,7 +135,7 @@ userInputParameters::loadVariableAttributes( pp_baseVarInfoList.reserve(number_of_variables); for (unsigned int i = 0; i < number_of_variables; i++) { - variable_info varInfo { + const variable_info varInfo { var_type[i] == SCALAR, i, variable_attributes.equation_dependency_parser.eval_flags_postprocess[i], @@ -164,7 +164,7 @@ userInputParameters::loadVariableAttributes( pp_varInfoList.reserve(pp_number_of_variables); for (unsigned int i = 0; i < pp_number_of_variables; i++) { - variable_info varInfo { + const variable_info varInfo { pp_var_type[i] == SCALAR, i, dealii::EvaluationFlags::nothing, diff --git a/src/userInputParameters/load_BC_list.cc b/src/userInputParameters/load_BC_list.cc index 1c608c53e..2976486db 100644 --- a/src/userInputParameters/load_BC_list.cc +++ b/src/userInputParameters/load_BC_list.cc @@ -6,6 +6,7 @@ #include #include "../../include/userInputParameters.h" +#include template void @@ -28,7 +29,7 @@ userInputParameters::load_BC_list(const std::vector &list_of_B // the same BC is applied for all boundaries if (temp.size() == 1) { - temp.resize(2 * dim, temp[0]); + temp.resize(static_cast(2 * dim), temp[0]); } // Load the BC for each boundary into 'newBC'. @@ -76,10 +77,8 @@ userInputParameters::load_BC_list(const std::vector &list_of_B // domain if (j % 2 == 0) { - AssertThrow(!((boost::iequals(temp[j], "PERIODIC") && - !boost::iequals(temp[j + 1], "PERIODIC")) || - (!boost::iequals(temp[j], "PERIODIC") && - boost::iequals(temp[j + 1], "PERIODIC"))), + AssertThrow(boost::iequals(temp[j], "PERIODIC") == + boost::iequals(temp[j + 1], "PERIODIC"), dealii::ExcMessage( std::string("Periodic boundary condition must be " "specified on both sides of domain"))); diff --git a/src/userInputParameters/load_user_constants.cc b/src/userInputParameters/load_user_constants.cc index 2b96cdcd0..39c516adc 100644 --- a/src/userInputParameters/load_user_constants.cc +++ b/src/userInputParameters/load_user_constants.cc @@ -214,7 +214,7 @@ userInputParameters::load_user_constants(inputFileReader &input_fi const std::string elastic_const_symmetry = model_constants_type_strings.at(0); - dealii::Tensor<2, 2 * dim - 1 + dim / 3> temp = + dealii::Tensor<2, 2 *dim - 1 + dim / 3> temp = get_Cij_tensor(temp_elastic_constants, elastic_const_symmetry); model_constants.push_back(temp); } diff --git a/src/userInputParameters/setTimeStepList.cc b/src/userInputParameters/setTimeStepList.cc index 0382a8443..241187b68 100644 --- a/src/userInputParameters/setTimeStepList.cc +++ b/src/userInputParameters/setTimeStepList.cc @@ -64,8 +64,9 @@ userInputParameters::setTimeStepList( timeStepList.push_back(1); for (unsigned int iter = 2; iter <= totalIncrements; iter++) { - const unsigned int decade = std::ceil(std::log10(iter)); - const unsigned int step_size = std::pow(10, decade) / numberOfOutputs; + const unsigned int decade = std::ceil(std::log10(iter)); + const auto step_size = + static_cast(std::pow(10, decade) / numberOfOutputs); if (iter % step_size == 0) { timeStepList.push_back(iter); diff --git a/src/userInputParameters/userInputParameters.cc b/src/userInputParameters/userInputParameters.cc index 81f33e2be..9a168a6c2 100644 --- a/src/userInputParameters/userInputParameters.cc +++ b/src/userInputParameters/userInputParameters.cc @@ -136,9 +136,10 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } // Time stepping parameters - dtValue = parameter_handler.get_double("Time step"); - const int totalIncrements_temp = parameter_handler.get_integer("Number of time steps"); - finalTime = parameter_handler.get_double("Simulation end time"); + dtValue = parameter_handler.get_double("Time step"); + const int totalIncrements_temp = + static_cast(parameter_handler.get_integer("Number of time steps")); + finalTime = parameter_handler.get_double("Simulation end time"); // Linear solver parameters for (unsigned int i = 0; i < number_of_variables; i++) diff --git a/src/utilities/vectorBCFunction.cc b/src/utilities/vectorBCFunction.cc index fe683b7d0..950c946c7 100644 --- a/src/utilities/vectorBCFunction.cc +++ b/src/utilities/vectorBCFunction.cc @@ -18,8 +18,8 @@ vectorBCFunction::vectorBCFunction(std::vector input_values) template void -vectorBCFunction::vector_value(const dealii::Point &p, - dealii::Vector &values) const +vectorBCFunction::vector_value([[maybe_unused]] const dealii::Point &p, + dealii::Vector &values) const { for (unsigned int i = 0; i < dim; i++) { From 8c005cd926787dc0ceb4a3d46abebebf4f4644bb Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 11 Nov 2024 14:13:37 -0500 Subject: [PATCH 21/28] more misc changes --- include/vectorBCFunction.h | 4 ++-- src/userInputParameters/load_user_constants.cc | 11 ++++++----- src/userInputParameters/setTimeStepList.cc | 5 +---- src/utilities/vectorBCFunction.cc | 4 ++-- 4 files changed, 11 insertions(+), 13 deletions(-) diff --git a/include/vectorBCFunction.h b/include/vectorBCFunction.h index d504c9116..63b3a3aa5 100644 --- a/include/vectorBCFunction.h +++ b/include/vectorBCFunction.h @@ -16,7 +16,7 @@ template class vectorBCFunction : public dealii::Function { public: - vectorBCFunction(const std::vector BC_values); + vectorBCFunction(const std::vector &BC_values); virtual void vector_value(const dealii::Point &p, dealii::Vector &values) const override; @@ -29,4 +29,4 @@ class vectorBCFunction : public dealii::Function const std::vector BC_values; }; -#endif /* INCLUDE_VECTORBCFUNCTION_H_ */ +#endif \ No newline at end of file diff --git a/src/userInputParameters/load_user_constants.cc b/src/userInputParameters/load_user_constants.cc index 39c516adc..a71cc3eda 100644 --- a/src/userInputParameters/load_user_constants.cc +++ b/src/userInputParameters/load_user_constants.cc @@ -475,13 +475,14 @@ userInputParameters::getCIJMatrix(const elasticityModel model, } // print CIJ to terminal pcout << "Elasticity matrix (Voigt notation):\n"; - char buffer[100]; - for (unsigned int i = 0; i < 2 * dim - 1 + dim / 3; i++) + constexpr unsigned int voight_matrix_size = 2 * dim - 1 + dim / 3; + std::array buffer; + for (unsigned int i = 0; i < voight_matrix_size; i++) { - for (unsigned int j = 0; j < 2 * dim - 1 + dim / 3; j++) + for (unsigned int j = 0; j < voight_matrix_size; j++) { - snprintf(buffer, sizeof(buffer), "%8.3e ", CIJ[i][j]); - pcout << buffer; + snprintf(buffer.data(), buffer.size(), "%8.3e ", CIJ[i][j]); + pcout << buffer.data(); } pcout << "\n"; } diff --git a/src/userInputParameters/setTimeStepList.cc b/src/userInputParameters/setTimeStepList.cc index 241187b68..e9d15006d 100644 --- a/src/userInputParameters/setTimeStepList.cc +++ b/src/userInputParameters/setTimeStepList.cc @@ -14,10 +14,7 @@ userInputParameters::setTimeStepList( std::vector timeStepList; // The number of outputs cannot be greater than the number increments - if (numberOfOutputs > totalIncrements) - { - numberOfOutputs = totalIncrements; - } + numberOfOutputs = std::min(numberOfOutputs, totalIncrements); // Prevent divide by zero in subsequent output types by returning the a vector where the // only entry is one greater than the number of increments. This way, we effectively diff --git a/src/utilities/vectorBCFunction.cc b/src/utilities/vectorBCFunction.cc index 950c946c7..2e9f65194 100644 --- a/src/utilities/vectorBCFunction.cc +++ b/src/utilities/vectorBCFunction.cc @@ -11,9 +11,9 @@ #include template -vectorBCFunction::vectorBCFunction(std::vector input_values) +vectorBCFunction::vectorBCFunction(const std::vector &BC_values) : dealii::Function(dim) - , BC_values(std::move(input_values)) + , BC_values(BC_values) {} template From c3b5a366cdb70fc716ce1b366e90382e7ca93987 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 11 Nov 2024 14:29:33 -0500 Subject: [PATCH 22/28] some more changes --- src/userInputParameters/load_user_constants.cc | 2 +- src/userInputParameters/userInputParameters.cc | 7 +++---- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/src/userInputParameters/load_user_constants.cc b/src/userInputParameters/load_user_constants.cc index a71cc3eda..3e1875467 100644 --- a/src/userInputParameters/load_user_constants.cc +++ b/src/userInputParameters/load_user_constants.cc @@ -476,7 +476,7 @@ userInputParameters::getCIJMatrix(const elasticityModel model, // print CIJ to terminal pcout << "Elasticity matrix (Voigt notation):\n"; constexpr unsigned int voight_matrix_size = 2 * dim - 1 + dim / 3; - std::array buffer; + std::array buffer {}; for (unsigned int i = 0; i < voight_matrix_size; i++) { for (unsigned int j = 0; j < voight_matrix_size; j++) diff --git a/src/userInputParameters/userInputParameters.cc b/src/userInputParameters/userInputParameters.cc index 9a168a6c2..aebc38759 100644 --- a/src/userInputParameters/userInputParameters.cc +++ b/src/userInputParameters/userInputParameters.cc @@ -153,7 +153,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.enter_subsection(subsection_text); { // Set the tolerance type - SolverToleranceType temp_type; + SolverToleranceType temp_type = ABSOLUTE_RESIDUAL; const std::string type_string = parameter_handler.get("Tolerance type"); if (boost::iequals(type_string, "ABSOLUTE_RESIDUAL")) { @@ -213,7 +213,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.enter_subsection(subsection_text); { // Set the tolerance type - SolverToleranceType temp_type; + SolverToleranceType temp_type = ABSOLUTE_RESIDUAL; const std::string type_string = parameter_handler.get("Tolerance type"); if (boost::iequals(type_string, "ABSOLUTE_RESIDUAL")) { @@ -260,7 +260,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi // Set whether to use the solution of Laplace's equation instead of // the IC in ICs_and_BCs.h as the initial guess for nonlinear, time // independent equations - bool temp_laplace_for_initial_guess; + bool temp_laplace_for_initial_guess = false; if (var_eq_type[i] == TIME_INDEPENDENT) { temp_laplace_for_initial_guess = parameter_handler.get_bool( @@ -268,7 +268,6 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } else { - temp_laplace_for_initial_guess = false; if (dealii::Utilities::MPI::this_mpi_process(MPI_COMM_WORLD) == 0) { std::cout << "PRISMS-PF Warning: Laplace's equation is only used " From a09aab375cf4d21f5903977a2c3c9f6cb63b4a4d Mon Sep 17 00:00:00 2001 From: landinjm Date: Fri, 22 Nov 2024 14:29:13 -0500 Subject: [PATCH 23/28] more fixes --- include/model_variables.h | 13 ++++---- .../loadVariableAttributes.cc | 30 +++++++++++-------- 2 files changed, 26 insertions(+), 17 deletions(-) diff --git a/include/model_variables.h b/include/model_variables.h index 6f3da0c2e..9e5fe3da3 100644 --- a/include/model_variables.h +++ b/include/model_variables.h @@ -33,11 +33,14 @@ class modelResidual struct variable_info { - bool is_scalar; - unsigned int global_var_index; - dealii::EvaluationFlags::EvaluationFlags evaluation_flags; - dealii::EvaluationFlags::EvaluationFlags residual_flags; - bool var_needed; + unsigned int global_var_index = 0; + bool is_scalar = true; + bool var_needed = false; + + dealii::EvaluationFlags::EvaluationFlags evaluation_flags = + dealii::EvaluationFlags::nothing; + dealii::EvaluationFlags::EvaluationFlags residual_flags = + dealii::EvaluationFlags::nothing; }; #endif /* INCLUDE_MODELVARIABLE_H_ */ diff --git a/src/userInputParameters/loadVariableAttributes.cc b/src/userInputParameters/loadVariableAttributes.cc index 237bed8f0..9ed4ede82 100644 --- a/src/userInputParameters/loadVariableAttributes.cc +++ b/src/userInputParameters/loadVariableAttributes.cc @@ -26,7 +26,8 @@ userInputParameters::loadVariableAttributes( num_var_explicit_RHS = 0; for (const auto &[index, variable] : variable_attributes.attributes) { - if (!(variable.eval_flags_explicit_RHS & dealii::EvaluationFlags::nothing)) + if (!static_cast(variable.eval_flags_explicit_RHS & + dealii::EvaluationFlags::nothing)) { num_var_explicit_RHS++; } @@ -34,7 +35,7 @@ userInputParameters::loadVariableAttributes( varInfoListExplicitRHS.reserve(num_var_explicit_RHS); for (const auto &[index, variable] : variable_attributes.attributes) { - variable_info varInfo; + variable_info varInfo {}; varInfo.evaluation_flags = variable.eval_flags_explicit_RHS; @@ -42,7 +43,8 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = index; - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); varInfo.is_scalar = variable.var_type == SCALAR; @@ -61,7 +63,7 @@ userInputParameters::loadVariableAttributes( varInfoListNonexplicitRHS.reserve(num_var_nonexplicit_RHS); for (const auto &[index, variable] : variable_attributes.attributes) { - variable_info varInfo; + variable_info varInfo {}; varInfo.evaluation_flags = variable.eval_flags_nonexplicit_RHS; @@ -69,7 +71,8 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = index; - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); varInfo.is_scalar = variable.var_type == SCALAR; @@ -89,7 +92,7 @@ userInputParameters::loadVariableAttributes( varInfoListLHS.reserve(num_var_LHS); for (const auto &[index, variable] : variable_attributes.attributes) { - variable_info varInfo; + variable_info varInfo {}; varInfo.evaluation_flags = variable.eval_flags_nonexplicit_LHS; @@ -97,7 +100,8 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = index; - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); varInfo.is_scalar = variable.var_type == SCALAR; @@ -107,7 +111,7 @@ userInputParameters::loadVariableAttributes( varChangeInfoListLHS.reserve(num_var_LHS); for (const auto &[index, variable] : variable_attributes.attributes) { - variable_info varInfo; + variable_info varInfo {}; varInfo.evaluation_flags = variable.eval_flags_change_nonexplicit_LHS; @@ -116,7 +120,8 @@ userInputParameters::loadVariableAttributes( varInfo.global_var_index = index; - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); varInfo.is_scalar = variable.var_type == SCALAR; @@ -128,13 +133,14 @@ userInputParameters::loadVariableAttributes( pp_baseVarInfoList.reserve(number_of_variables); for (const auto &[index, variable] : variable_attributes.attributes) { - variable_info varInfo; + variable_info varInfo {}; varInfo.evaluation_flags = variable.eval_flags_postprocess; varInfo.global_var_index = index; - varInfo.var_needed = !(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); varInfo.is_scalar = variable.var_type == SCALAR; @@ -160,7 +166,7 @@ userInputParameters::loadVariableAttributes( pp_varInfoList.reserve(pp_number_of_variables); for (const auto &[pp_index, pp_variable] : variable_attributes.pp_attributes) { - variable_info varInfo; + variable_info varInfo {}; varInfo.var_needed = true; From 0f9d049559917d659c62b63d46921f5e6d9f2835 Mon Sep 17 00:00:00 2001 From: landinjm Date: Fri, 22 Nov 2024 14:35:19 -0500 Subject: [PATCH 24/28] fix --- src/userInputParameters/loadVariableAttributes.cc | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/src/userInputParameters/loadVariableAttributes.cc b/src/userInputParameters/loadVariableAttributes.cc index 9ed4ede82..c815a9f80 100644 --- a/src/userInputParameters/loadVariableAttributes.cc +++ b/src/userInputParameters/loadVariableAttributes.cc @@ -55,7 +55,8 @@ userInputParameters::loadVariableAttributes( num_var_nonexplicit_RHS = 0; for (const auto &[index, variable] : variable_attributes.attributes) { - if (!(variable.eval_flags_nonexplicit_RHS & dealii::EvaluationFlags::nothing)) + if (!static_cast(variable.eval_flags_nonexplicit_RHS & + dealii::EvaluationFlags::nothing)) { num_var_nonexplicit_RHS++; } @@ -83,7 +84,8 @@ userInputParameters::loadVariableAttributes( num_var_LHS = 0; for (const auto &[index, variable] : variable_attributes.attributes) { - if (!(variable.eval_flags_nonexplicit_LHS & dealii::EvaluationFlags::nothing)) + if (!static_cast(variable.eval_flags_nonexplicit_LHS & + dealii::EvaluationFlags::nothing)) { num_var_LHS++; } From e43c13812c8f6ac9947af59f7a7473bba5c5d8f2 Mon Sep 17 00:00:00 2001 From: landinjm Date: Fri, 22 Nov 2024 14:49:56 -0500 Subject: [PATCH 25/28] more fixes --- .../userInputParameters.cc | 2 +- .../variableAttributeLoader.cc | 4 ++-- src/variableAttributes/variableAttributes.cc | 24 +++++++++---------- 3 files changed, 15 insertions(+), 15 deletions(-) diff --git a/src/userInputParameters/userInputParameters.cc b/src/userInputParameters/userInputParameters.cc index 726edd889..be0e4d421 100644 --- a/src/userInputParameters/userInputParameters.cc +++ b/src/userInputParameters/userInputParameters.cc @@ -258,7 +258,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi // Set whether to use the solution of Laplace's equation instead of // the IC in ICs_and_BCs.h as the initial guess for nonlinear, time // independent equations - bool temp_laplace_for_initial_guess; + bool temp_laplace_for_initial_guess = false; if (variable.eq_type == TIME_INDEPENDENT) { temp_laplace_for_initial_guess = parameter_handler.get_bool( diff --git a/src/variableAttributeLoader/variableAttributeLoader.cc b/src/variableAttributeLoader/variableAttributeLoader.cc index 8a376c737..a2942d8e6 100644 --- a/src/variableAttributeLoader/variableAttributeLoader.cc +++ b/src/variableAttributeLoader/variableAttributeLoader.cc @@ -6,9 +6,9 @@ variableAttributeLoader::variableAttributeLoader() { relevant_attributes = &attributes; - loadVariableAttributes(); // This is a user-facing function + loadVariableAttributes(); relevant_attributes = &pp_attributes; - loadPostProcessorVariableAttributes(); // This is a user-facing function + loadPostProcessorVariableAttributes(); relevant_attributes = nullptr; for (auto &[pp_index, pp_variable] : pp_attributes) diff --git a/src/variableAttributes/variableAttributes.cc b/src/variableAttributes/variableAttributes.cc index 396856b6b..1b62d6503 100644 --- a/src/variableAttributes/variableAttributes.cc +++ b/src/variableAttributes/variableAttributes.cc @@ -49,9 +49,9 @@ variableAttributes::parse_residual_dependencies() if (is_pp) { - EvalFlags &residual_flags = eval_flags_residual_postprocess; - std::set &value_dependency_set = dependencies_value_PP; - std::set &gradient_dependency_set = dependencies_gradient_PP; + EvalFlags &residual_flags = eval_flags_residual_postprocess; + const std::set &value_dependency_set = dependencies_value_PP; + const std::set &gradient_dependency_set = dependencies_gradient_PP; if (!value_dependency_set.empty()) { @@ -68,10 +68,10 @@ variableAttributes::parse_residual_dependencies() std::pair *, std::set *>> &eval_dep_pair : dependencies_for.at(eq_type)) { - EvalFlags &residual_flags = *(eval_dep_pair.first); - auto &dep_pair = eval_dep_pair.second; - std::set &value_dependency_set = *(dep_pair.first); - std::set &gradient_dependency_set = *(dep_pair.second); + EvalFlags &residual_flags = *(eval_dep_pair.first); + const auto &dep_pair = eval_dep_pair.second; + const std::set &value_dependency_set = *(dep_pair.first); + const std::set &gradient_dependency_set = *(dep_pair.second); if (!value_dependency_set.empty()) { @@ -107,9 +107,9 @@ variableAttributes::parse_dependencies( for (const auto &[variation, delimiter] : delimiters) { - bool is_change = variation == "val_change" || variation == "grad_change" || - variation == "hess_change"; - std::string possible_dependency = delimiter.first + name + delimiter.second; + const bool is_change = variation == "val_change" || variation == "grad_change" || + variation == "hess_change"; + const std::string possible_dependency = delimiter.first + name + delimiter.second; if (is_change && dependency_set.find(possible_dependency) != dependency_set.end()) { eval_flags_change_nonexplicit_LHS |= relevant_flag.at(variation); @@ -121,7 +121,7 @@ variableAttributes::parse_dependencies( if (other_variable.dependency_set.find(possible_dependency) != other_variable.dependency_set.end()) { - for (auto &eval_flag : eval_flags_for_eq_type(other_variable)) + for (const auto &eval_flag : eval_flags_for_eq_type(other_variable)) { *eval_flag |= relevant_flag.at(variation); } @@ -138,7 +138,7 @@ variableAttributes::parse_dependencies( std::set variableAttributes::eval_flags_for_eq_type(const variableAttributes &other_variable) { - PDEType other_eq_type = other_variable.eq_type; + const PDEType other_eq_type = other_variable.eq_type; if (other_variable.is_pp) { return {&eval_flags_postprocess}; From faf3a251948cc3a205e8d9bfb980080cc560d826 Mon Sep 17 00:00:00 2001 From: Xander <102053371+fractalsbyx@users.noreply.github.com> Date: Fri, 22 Nov 2024 13:41:25 -0500 Subject: [PATCH 26/28] initialize num_pp_vars which gets printed during initialization --- src/inputFileReader/inputFileReader.cc | 1 + 1 file changed, 1 insertion(+) diff --git a/src/inputFileReader/inputFileReader.cc b/src/inputFileReader/inputFileReader.cc index 93bedf6f2..76178d978 100644 --- a/src/inputFileReader/inputFileReader.cc +++ b/src/inputFileReader/inputFileReader.cc @@ -15,6 +15,7 @@ inputFileReader::inputFileReader(const std::string &input_file_name, : variable_attributes(_variable_attributes) { num_constants = get_number_of_entries(input_file_name, "set", "Model constant"); + num_pp_vars = variable_attributes.pp_attributes.size(); model_constant_names = get_entry_name_ending_list(input_file_name, "set", "Model constant"); From fd9e7ccf937caaeffd0f17a7d43e95326c442d57 Mon Sep 17 00:00:00 2001 From: landinjm Date: Fri, 22 Nov 2024 15:40:22 -0500 Subject: [PATCH 27/28] more fixes --- include/inputFileReader.h | 44 +- include/userInputParameters.h | 139 +- ...rInputParameters_template_instantiations.h | 7 - include/variableAttributeLoader.h | 61 +- src/inputFileReader/inputFileReader.cc | 71 +- .../parallelNucleationList.cc | 231 ++-- .../loadVariableAttributes.cc | 186 --- src/userInputParameters/load_BC_list.cc | 92 -- .../load_user_constants.cc | 494 -------- src/userInputParameters/setTimeStepList.cc | 84 -- .../userInputParameters.cc | 1115 +++++++++++++++-- .../variableAttributeLoader.cc | 254 ++-- tests/unit_tests/unitTest.h | 4 - 13 files changed, 1524 insertions(+), 1258 deletions(-) delete mode 100644 include/userInputParameters_template_instantiations.h delete mode 100644 src/userInputParameters/loadVariableAttributes.cc delete mode 100644 src/userInputParameters/load_BC_list.cc delete mode 100644 src/userInputParameters/load_user_constants.cc delete mode 100644 src/userInputParameters/setTimeStepList.cc diff --git a/include/inputFileReader.h b/include/inputFileReader.h index 13477b81b..6972e3ebd 100644 --- a/include/inputFileReader.h +++ b/include/inputFileReader.h @@ -11,40 +11,55 @@ #include #include +/** + * \brief Input file reader. + */ class inputFileReader { public: - // Constructor + /** + * \brief Constructor. + */ inputFileReader(const std::string &input_file_name, variableAttributeLoader &_variable_attributes); - // Method to get a list of entry values from multiple subsections in an input - // file + /** + * \brief Method to get a list of entry values from multiple subsections in an input + * file. + */ [[nodiscard]] static std::vector get_subsection_entry_list(const std::string ¶meters_file_name, const std::string &subsec_name, const std::string &entry_name, const std::string &default_entry); - // Method to count the number of related entries in an input file + /** + * \brief Method to count the number of related entries in an input file. + */ [[nodiscard]] static unsigned int get_number_of_entries(const std::string ¶meters_file_name, const std::string &keyword, const std::string &entry_name); - // Get the trailing part of the entry name after a specified string (used to - // extract the model constant names) + /** + * \brief Get the trailing part of the entry name after a specified string (used to + * extract the model constant names). + */ [[nodiscard]] static std::vector get_entry_name_ending_list(const std::string ¶meters_file_name, const std::string &keyword, const std::string &entry_name_begining); - // Method to declare the parameters to be read from an input file + /** + * \brief Method to declare the parameters to be read from an input file. + */ void declare_parameters(dealii::ParameterHandler ¶meter_handler, const unsigned int num_of_constants) const; - // Method to check if a line has the desired contents and if so, extract it + /** + * \brief Method to check if a line has the desired contents and if so, extract it. + */ static bool parse_line(std::string line, const std::string &keyword, @@ -52,7 +67,18 @@ class inputFileReader std::string &out_string, bool expect_equals_sign); - // Variables + /** + * \brief Strip spaces from the front and back of a string. + */ + static void + strip_spaces(std::string &line); + + /** + * \brief Check whether a string starts with a keyword. + */ + static bool + check_keyword_match(std::string &line, const std::string &keyword); + variableAttributeLoader &variable_attributes; dealii::ParameterHandler parameter_handler; unsigned int num_pp_vars; diff --git a/include/userInputParameters.h b/include/userInputParameters.h index b4a9527ed..ede49518b 100644 --- a/include/userInputParameters.h +++ b/include/userInputParameters.h @@ -41,17 +41,28 @@ template class userInputParameters { public: - // Method to read the input parameters from a file and load them into the - // class member variables + /** + * \brief Constructor. Reads in user input parameters from file and loads them into + * member variables. + */ userInputParameters(inputFileReader &input_file_reader, dealii::ParameterHandler ¶meter_handler, variableAttributeLoader variable_attributes); - // Method to create the list of BCs from the user input strings (called from - // the constructor) + /** + * \brief Creates a list of BCs to store in BC_list object. + */ void load_BC_list(const std::vector &list_of_BCs); + /** + * \brief Assign the boundary condition to the varBC object given some boundary + * condition string vector. + */ + void + assign_boundary_conditions(std::vector &boundary_condition_list, + varBCs &boundary_condition); + // Map linking the model constant name to its index std::unordered_map model_constant_name_map; @@ -62,7 +73,7 @@ class userInputParameters * \param constant_name Name of the constant to retrieve. */ [[nodiscard]] double - get_model_constant_double(const std::string constant_name) const + get_model_constant_double(const std::string &constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), dealii::ExcMessage( @@ -80,7 +91,7 @@ class userInputParameters * \param constant_name Name of the constant to retrieve. */ [[nodiscard]] int - get_model_constant_int(const std::string constant_name) const + get_model_constant_int(const std::string &constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), dealii::ExcMessage( @@ -98,7 +109,7 @@ class userInputParameters * \param constant_name Name of the constant to retrieve. */ [[nodiscard]] bool - get_model_constant_bool(const std::string constant_name) const + get_model_constant_bool(const std::string &constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), dealii::ExcMessage( @@ -116,7 +127,7 @@ class userInputParameters * \param constant_name Name of the constant to retrieve. */ [[nodiscard]] dealii::Tensor<1, dim> - get_model_constant_rank_1_tensor(const std::string constant_name) const + get_model_constant_rank_1_tensor(const std::string &constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), dealii::ExcMessage( @@ -135,7 +146,7 @@ class userInputParameters * \param constant_name Name of the constant to retrieve. */ [[nodiscard]] dealii::Tensor<2, dim> - get_model_constant_rank_2_tensor(const std::string constant_name) const + get_model_constant_rank_2_tensor(const std::string &constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), dealii::ExcMessage( @@ -154,7 +165,7 @@ class userInputParameters * \param constant_name Name of the constant to retrieve. */ [[nodiscard]] dealii::Tensor<2, 2 * dim - 1 + dim / 3> - get_model_constant_elasticity_tensor(const std::string constant_name) const + get_model_constant_elasticity_tensor(const std::string &constant_name) const { Assert(model_constant_name_map.find(constant_name) != model_constant_name_map.end(), dealii::ExcMessage( @@ -324,6 +335,75 @@ class userInputParameters unsigned int num_grain_smoothing_cycles; private: + /** + * \brief Assign the provided user inputs to parameters for anything related to the + * spatial discretiziation. + */ + void + assign_spatial_discretization_parameters(dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes); + + /** + * \brief Assign the provided user inputs to parameters for anything related to the + * temporal discretiziation. + */ + void + assign_temporal_discretization_parameters(dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes); + /** + * \brief Assign the provided user inputs to parameters for anything related to linear + * solves. + */ + void + assign_linear_solve_parameters(dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes); + + /** + * \brief Assign the provided user inputs to parameters for anything related to + * nonlinear solves. + */ + void + assign_nonlinear_solve_parameters(dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes); + + /** + * \brief Assign the provided user inputs to parameters for anything related to + * outputs. + */ + void + assign_output_parameters(dealii::ParameterHandler ¶meter_handler); + + /** + * \brief Assign the provided user inputs to parameters for anything related to + * loading in initial condition. + */ + void + assign_load_initial_condition_parameters(dealii::ParameterHandler ¶meter_handler); + + /** + * \brief Assign the provided user inputs to parameters for anything related to + * nucleation. + */ + void + assign_nucleation_parameters(dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes); + + /** + * \brief Assign the provided user inputs to parameters for anything related to + * grain remapping and grain vtk load-in. + */ + void + assign_grain_parameters(dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes); + + /** + * \brief Assign the provided user inputs to parameters for anything related to + * boundary conditions. + */ + void + assign_boundary_condition_parameters(dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes); + // Method to create the list of time steps where the results should be output // (called from loadInputParameters) std::vector @@ -335,6 +415,45 @@ class userInputParameters load_user_constants(inputFileReader &input_file_reader, dealii::ParameterHandler ¶meter_handler); + /** + * \brief Compute the number of tensor rows. + */ + unsigned int + compute_tensor_parentheses(const unsigned int n_elements, + const std::vector &tensor_elements); + + /** + * \brief Remove and leading and trailing parentheses. + */ + void + remove_parentheses(std::vector &tensor_elements); + + /** + * \brief Compute a 1st rank tensor from user inputs . + */ + dealii::Tensor<1, dim> + compute_rank_1_tensor_constant(const unsigned int n_elements, + std::vector tensor_elements); + + /** + * \brief Compute a 2nd rank tensor from user inputs . + */ + dealii::Tensor<2, dim> + compute_rank_2_tensor_constant(const unsigned int n_elements, + std::vector tensor_elements); + + /** + * \brief Assign the specified user constant to whatever type. + */ + void + assign_user_constant(std::vector &model_constants_strings); + + /** + * \brief Assign the primitive user constants (e.g., int, double, bool). + */ + void + assign_primitive_user_constant(std::vector &model_constants_strings); + [[nodiscard]] dealii::Tensor<2, 2 * dim - 1 + dim / 3> get_Cij_tensor(std::vector elastic_constants, const std::string &elastic_const_symmetry) const; diff --git a/include/userInputParameters_template_instantiations.h b/include/userInputParameters_template_instantiations.h deleted file mode 100644 index bc965eaa5..000000000 --- a/include/userInputParameters_template_instantiations.h +++ /dev/null @@ -1,7 +0,0 @@ -#ifndef INCLUDE_USERINPUTPARAMETERS_TEMPLATE_INSTANTIATIONS_H_ -#define INCLUDE_USERINPUTPARAMETERS_TEMPLATE_INSTANTIATIONS_H_ - -template class userInputParameters<2>; -template class userInputParameters<3>; - -#endif diff --git a/include/variableAttributeLoader.h b/include/variableAttributeLoader.h index 3bd8d2d4c..0ccc93fa7 100644 --- a/include/variableAttributeLoader.h +++ b/include/variableAttributeLoader.h @@ -40,7 +40,7 @@ class variableAttributeLoader * \param name Name of variable at `index` */ void - set_variable_name(const unsigned int &index, const std::string &name); + set_variable_name(const unsigned int &index, const std::string &name) const; /** * \brief Set the field type of the variable at `index` to `var_type` where `var_type` @@ -50,7 +50,7 @@ class variableAttributeLoader * \param var_type Field type of variable at `index` (`SCALAR` or `VECTOR`). */ void - set_variable_type(const unsigned int &index, const fieldType &var_type); + set_variable_type(const unsigned int &index, const fieldType &var_type) const; /** * \brief Set the PDE type of the variable at `index` to `var_eq_type` where @@ -61,7 +61,7 @@ class variableAttributeLoader * \param var_eq_type PDE type of variable at `index`. */ void - set_variable_equation_type(const unsigned int &index, const PDEType &var_eq_type); + set_variable_equation_type(const unsigned int &index, const PDEType &var_eq_type) const; /** * \brief Set the dependencies for the value term of the RHS equation of the variable at @@ -97,7 +97,7 @@ class variableAttributeLoader */ void set_dependencies_value_term_LHS(const unsigned int &index, - const std::string &dependencies); + const std::string &dependencies) const; /** * \brief Set the dependencies for the gradient term of the LHS equation of the variable @@ -109,7 +109,7 @@ class variableAttributeLoader */ void set_dependencies_gradient_term_LHS(const unsigned int &index, - const std::string &dependencies); + const std::string &dependencies) const; /** * \brief Flag whether the variable at `index` is needed to calculate the nucleation @@ -119,7 +119,7 @@ class variableAttributeLoader * \param flag true: variable is needed, false: variable is not needed. */ void - set_need_value_nucleation(const unsigned int &index, const bool &flag); + set_need_value_nucleation(const unsigned int &index, const bool &flag) const; /** * \brief Flag whether the variable at `index` is can have a nucleation event. @@ -128,7 +128,7 @@ class variableAttributeLoader * \param flag true: variable can nucleate, false: variable can not nucleate. */ void - set_allowed_to_nucleate(const unsigned int &index, const bool &flag); + set_allowed_to_nucleate(const unsigned int &index, const bool &flag) const; /** * \brief (Postprocess only) Flag whether the postprocessing variable at `index` should @@ -139,7 +139,7 @@ class variableAttributeLoader * false: do nothing */ void - set_output_integral(const unsigned int &index, const bool &flag); + set_output_integral(const unsigned int &index, const bool &flag) const; /** * \brief The solutions variable attributes @@ -165,10 +165,53 @@ class variableAttributeLoader void validate_attributes(); + /** + * \brief Validate that the variable name is not empty and does not contain any + * forbidden substrings (names). + */ + static void + validate_variable_name(const std::string &name, + const std::set &forbidden_names, + const std::string &context, + unsigned int index); + + /** + * \brief Populate dependencies that we should expect from the user. + */ + static void + populate_dependencies( + const std::set> ®_delimiters, + const std::string &variable_name, + unsigned int index, + std::set ®_possible_deps, + std::map> &change_possible_deps); + + /** + * \brief Validate the dependencies (RHS or LHS) that the user has provided. + */ + static void + validate_dependencies( + const std::set &dependencies, + const std::string &context, + unsigned int index, + const std::string &variable_name, + const std::set ®_possible_deps, + const std::map> &change_possible_deps); + + /** + * \brief Validate the postprocess variables. + */ + static void + validate_postprocess_variable(const std::string &name, + const std::set &name_list, + const std::set ®_possible_deps, + const variableAttributes &pp_variable, + unsigned int index); + /** * \brief Utility to remove whitespace from strings */ - std::string + static std::string strip_whitespace(const std::string &text); // The above function should be moved to a 'utilities' module }; diff --git a/src/inputFileReader/inputFileReader.cc b/src/inputFileReader/inputFileReader.cc index 76178d978..126003601 100644 --- a/src/inputFileReader/inputFileReader.cc +++ b/src/inputFileReader/inputFileReader.cc @@ -1,21 +1,17 @@ -// Methods for the inputFileReader class #include "../../include/inputFileReader.h" #include #include -// #include "variableAttributeLoader.h" - #include "../../include/RefinementCriterion.h" #include -// Constructor inputFileReader::inputFileReader(const std::string &input_file_name, variableAttributeLoader &_variable_attributes) : variable_attributes(_variable_attributes) + , num_pp_vars(_variable_attributes.pp_attributes.size()) { num_constants = get_number_of_entries(input_file_name, "set", "Model constant"); - num_pp_vars = variable_attributes.pp_attributes.size(); model_constant_names = get_entry_name_ending_list(input_file_name, "set", "Model constant"); @@ -36,15 +32,9 @@ inputFileReader::inputFileReader(const std::string &input_file_name, number_of_dimensions = parameter_handler.get_integer("Number of dimensions"); } -// Method to parse a single line to find a target key value pair -bool -inputFileReader::parse_line(std::string line, - const std::string &keyword, - const std::string &entry_name, - std::string &out_string, - const bool expect_equals_sign) +void +inputFileReader::strip_spaces(std::string &line) { - // Strip spaces at the front and back while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) { line.erase(0, 1); @@ -54,15 +44,18 @@ inputFileReader::parse_line(std::string line, { line.erase(line.size() - 1, std::string::npos); } +} - // now see whether the line starts with 'keyword' followed by multiple spaces - // if not, try next line (if the entry is "", then zero spaces after the - // keyword is ok) +bool +inputFileReader::check_keyword_match(std::string &line, const std::string &keyword) +{ + // Early return if the line is less than the keyword size if (line.size() < keyword.size()) { return false; } + // Check that the line begins with the keyword for (unsigned int i = 0; i < keyword.size(); i++) { if (line[i] != keyword[i]) @@ -70,6 +63,27 @@ inputFileReader::parse_line(std::string line, return false; } } + + return true; +} + +bool +inputFileReader::parse_line(std::string line, + const std::string &keyword, + const std::string &entry_name, + std::string &out_string, + const bool expect_equals_sign) +{ + // Remove spaces from the front and back + strip_spaces(line); + + // Check whether the line starts with 'keyword'. If not, try next line (if the entry is + // "", then zero spaces after the keyword is ok) + if (!check_keyword_match(line, keyword)) + { + return false; + } + if (!entry_name.empty()) { if (line[keyword.size()] != ' ' && line[keyword.size()] != '\t') @@ -78,12 +92,10 @@ inputFileReader::parse_line(std::string line, } } - // delete the "keyword" and then delete more spaces if present + // Delete the "keyword" and any more spaces, if present line.erase(0, keyword.size()); - while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) - { - line.erase(0, 1); - } + strip_spaces(line); + // now see whether the next word is the word we look for if (line.find(entry_name) != 0) { @@ -91,10 +103,7 @@ inputFileReader::parse_line(std::string line, } line.erase(0, entry_name.size()); - while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) - { - line.erase(0, 1); - } + strip_spaces(line); // we'd expect an equals size here if expect_equals_sign is true if (expect_equals_sign) @@ -118,17 +127,7 @@ inputFileReader::parse_line(std::string line, { line.erase(0, 1); } - - while ((!line.empty()) && (line[0] == ' ' || line[0] == '\t')) - { - line.erase(0, 1); - } - - while ((!line.empty()) && - (line[line.size() - 1] == ' ' || line[line.size() - 1] == '\t')) - { - line.erase(line.size() - 1, std::string::npos); - } + strip_spaces(line); out_string = line; return true; diff --git a/src/parallelNucleationList/parallelNucleationList.cc b/src/parallelNucleationList/parallelNucleationList.cc index 398ccfcd7..7d8c7fbef 100644 --- a/src/parallelNucleationList/parallelNucleationList.cc +++ b/src/parallelNucleationList/parallelNucleationList.cc @@ -315,147 +315,130 @@ parallelNucleationList::broadcastUpdate(int broadcastProc, int thisProc) // OTHERS int currnonucs = newnuclei.size(); MPI_Bcast(&currnonucs, 1, MPI_INT, broadcastProc, MPI_COMM_WORLD); - if (currnonucs > 0) + + if (currnonucs == 0) { - // Creating vectors of each quantity in nuclei. Each numbered acording to - // the tags used for MPI_Send/MPI_Recv - unsigned int initial_vec_size = 0; - if (thisProc == broadcastProc) - { - initial_vec_size = 0; - } - else - { - initial_vec_size = currnonucs; - } + return; + } - // 1 - index - std::vector r_index(initial_vec_size, 0); - // 2 - "x" componenet of center - std::vector r_center_x(initial_vec_size, 0.0); - // 3 - "y" componenet of center - std::vector r_center_y(initial_vec_size, 0.0); - // 4 - "z" componenet of center - std::vector r_center_z(initial_vec_size, 0.0); - // 5 - radius - std::vector r_semiaxis_a(initial_vec_size, 0.0); - std::vector r_semiaxis_b(initial_vec_size, 0.0); - std::vector r_semiaxis_c(initial_vec_size, 0.0); - // 6 - seededTime - std::vector r_seededTime(initial_vec_size, 0.0); - // 7 - seedingTime - std::vector r_seedingTime(initial_vec_size, 0.0); - // 8 - seedingTimestep - std::vector r_seedingTimestep(initial_vec_size, 0); - // 9 - orderParameterIndex - std::vector r_orderParameterIndex(initial_vec_size, 0); + // Creating vectors of each quantity in nuclei. Each numbered acording to + // the tags used for MPI_Send/MPI_Recv + unsigned int initial_vec_size = 0; + if (thisProc == broadcastProc) + { + initial_vec_size = 0; + } + else + { + initial_vec_size = currnonucs; + } - if (thisProc == broadcastProc) + // 1 - index + std::vector r_index(initial_vec_size, 0); + // 2 - "x" componenet of center + std::vector r_center_x(initial_vec_size, 0.0); + // 3 - "y" componenet of center + std::vector r_center_y(initial_vec_size, 0.0); + // 4 - "z" componenet of center + std::vector r_center_z(initial_vec_size, 0.0); + // 5 - radius + std::vector r_semiaxis_a(initial_vec_size, 0.0); + std::vector r_semiaxis_b(initial_vec_size, 0.0); + std::vector r_semiaxis_c(initial_vec_size, 0.0); + // 6 - seededTime + std::vector r_seededTime(initial_vec_size, 0.0); + // 7 - seedingTime + std::vector r_seedingTime(initial_vec_size, 0.0); + // 8 - seedingTimestep + std::vector r_seedingTimestep(initial_vec_size, 0); + // 9 - orderParameterIndex + std::vector r_orderParameterIndex(initial_vec_size, 0); + + if (thisProc == broadcastProc) + { + for (const auto &thisNuclei : newnuclei) { - for (const auto &thisNuclei : newnuclei) + r_index.push_back(thisNuclei.index); + dealii::Point s_center = thisNuclei.center; + r_center_x.push_back(s_center[0]); + r_center_y.push_back(s_center[1]); + if (dim == 3) { - r_index.push_back(thisNuclei.index); - dealii::Point s_center = thisNuclei.center; - r_center_x.push_back(s_center[0]); - r_center_y.push_back(s_center[1]); - if (dim == 3) - { - r_center_z.push_back(s_center[2]); - } - - r_semiaxis_a.push_back(thisNuclei.semiaxes[0]); - r_semiaxis_b.push_back(thisNuclei.semiaxes[1]); - if (dim == 3) - { - r_semiaxis_c.push_back(thisNuclei.semiaxes[2]); - } - - r_seededTime.push_back(thisNuclei.seededTime); - r_seedingTime.push_back(thisNuclei.seedingTime); - r_seedingTimestep.push_back(thisNuclei.seedingTimestep); - r_orderParameterIndex.push_back(thisNuclei.orderParameterIndex); + r_center_z.push_back(s_center[2]); } - } - // Recieve vectors from processor procno - MPI_Bcast(r_index.data(), currnonucs, MPI_UNSIGNED, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(r_center_x.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); - MPI_Bcast(r_center_y.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); - if (dim == 3) - { - MPI_Bcast(r_center_z.data(), - currnonucs, - MPI_DOUBLE, - broadcastProc, - MPI_COMM_WORLD); + r_semiaxis_a.push_back(thisNuclei.semiaxes[0]); + r_semiaxis_b.push_back(thisNuclei.semiaxes[1]); + if (dim == 3) + { + r_semiaxis_c.push_back(thisNuclei.semiaxes[2]); + } + + r_seededTime.push_back(thisNuclei.seededTime); + r_seedingTime.push_back(thisNuclei.seedingTime); + r_seedingTimestep.push_back(thisNuclei.seedingTimestep); + r_orderParameterIndex.push_back(thisNuclei.orderParameterIndex); } - MPI_Bcast(r_semiaxis_a.data(), - currnonucs, - MPI_DOUBLE, - broadcastProc, - MPI_COMM_WORLD); - MPI_Bcast(r_semiaxis_b.data(), + } + + // Recieve vectors from processor procno + MPI_Bcast(r_index.data(), currnonucs, MPI_UNSIGNED, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_center_x.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_center_y.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + if (dim == 3) + { + MPI_Bcast(r_center_z.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + } + MPI_Bcast(r_semiaxis_a.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_semiaxis_b.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + if (dim == 3) + { + MPI_Bcast(r_semiaxis_c.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + } + MPI_Bcast(r_seededTime.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_seedingTime.data(), currnonucs, MPI_DOUBLE, broadcastProc, MPI_COMM_WORLD); + MPI_Bcast(r_seedingTimestep.data(), + currnonucs, + MPI_UNSIGNED, + broadcastProc, + MPI_COMM_WORLD); + MPI_Bcast(r_orderParameterIndex.data(), + currnonucs, + MPI_UNSIGNED, + broadcastProc, + MPI_COMM_WORLD); + + newnuclei.clear(); + + // Loop to store info in vectors onto the nuclei structure + for (int jnuc = 0; jnuc <= currnonucs - 1; jnuc++) + { + auto temp = std::make_unique>(); + + temp->index = r_index[jnuc]; + dealii::Point r_center; + r_center[0] = r_center_x[jnuc]; + r_center[1] = r_center_y[jnuc]; if (dim == 3) { - MPI_Bcast(r_semiaxis_c.data(), - currnonucs, - MPI_DOUBLE, - broadcastProc, - MPI_COMM_WORLD); + r_center[2] = r_center_z[jnuc]; } - MPI_Bcast(r_seededTime.data(), - currnonucs, - MPI_DOUBLE, - broadcastProc, - MPI_COMM_WORLD); - MPI_Bcast(r_seedingTime.data(), - currnonucs, - MPI_DOUBLE, - broadcastProc, - MPI_COMM_WORLD); - MPI_Bcast(r_seedingTimestep.data(), - currnonucs, - MPI_UNSIGNED, - broadcastProc, - MPI_COMM_WORLD); - MPI_Bcast(r_orderParameterIndex.data(), - currnonucs, - MPI_UNSIGNED, - broadcastProc, - MPI_COMM_WORLD); - - newnuclei.clear(); - - // Loop to store info in vectors onto the nuclei structure - for (int jnuc = 0; jnuc <= currnonucs - 1; jnuc++) + temp->center = r_center; + temp->semiaxes.push_back(r_semiaxis_a[jnuc]); + temp->semiaxes.push_back(r_semiaxis_b[jnuc]); + if (dim == 3) { - auto temp = std::make_unique>(); - - temp->index = r_index[jnuc]; - dealii::Point r_center; - r_center[0] = r_center_x[jnuc]; - r_center[1] = r_center_y[jnuc]; - if (dim == 3) - { - r_center[2] = r_center_z[jnuc]; - } - temp->center = r_center; - temp->semiaxes.push_back(r_semiaxis_a[jnuc]); - temp->semiaxes.push_back(r_semiaxis_b[jnuc]); - if (dim == 3) - { - temp->semiaxes.push_back(r_semiaxis_c[jnuc]); - } - temp->seededTime = r_seededTime[jnuc]; - temp->seedingTime = r_seedingTime[jnuc]; - temp->seedingTimestep = r_seedingTimestep[jnuc]; - temp->orderParameterIndex = r_orderParameterIndex[jnuc]; - newnuclei.push_back(*temp); + temp->semiaxes.push_back(r_semiaxis_c[jnuc]); } + temp->seededTime = r_seededTime[jnuc]; + temp->seedingTime = r_seedingTime[jnuc]; + temp->seedingTimestep = r_seedingTimestep[jnuc]; + temp->orderParameterIndex = r_orderParameterIndex[jnuc]; + newnuclei.push_back(*temp); } } diff --git a/src/userInputParameters/loadVariableAttributes.cc b/src/userInputParameters/loadVariableAttributes.cc deleted file mode 100644 index c815a9f80..000000000 --- a/src/userInputParameters/loadVariableAttributes.cc +++ /dev/null @@ -1,186 +0,0 @@ -#include "../../include/userInputParameters.h" - -template -void -userInputParameters::loadVariableAttributes( - const variableAttributeLoader &variable_attributes) -{ - number_of_variables = variable_attributes.attributes.size(); - pp_number_of_variables = variable_attributes.pp_attributes.size(); - // Load some nucleation parameters - for (const auto &[index, variable] : variable_attributes.attributes) - { - if (variable.nucleating_variable) - { - nucleating_variable_indices.push_back(index); - } - if (variable.need_value_nucleation || variable.nucleating_variable) - { - nucleation_need_value.push_back(index); - } - } - - nucleation_occurs = !nucleating_variable_indices.empty(); - - // Load variable information for calculating the RHS for explicit equations - num_var_explicit_RHS = 0; - for (const auto &[index, variable] : variable_attributes.attributes) - { - if (!static_cast(variable.eval_flags_explicit_RHS & - dealii::EvaluationFlags::nothing)) - { - num_var_explicit_RHS++; - } - } - varInfoListExplicitRHS.reserve(num_var_explicit_RHS); - for (const auto &[index, variable] : variable_attributes.attributes) - { - variable_info varInfo {}; - - varInfo.evaluation_flags = variable.eval_flags_explicit_RHS; - - varInfo.residual_flags = variable.eval_flags_residual_explicit_RHS; - - varInfo.global_var_index = index; - - varInfo.var_needed = - !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = variable.var_type == SCALAR; - - varInfoListExplicitRHS.push_back(varInfo); - } - - // Load variable information for calculating the RHS for nonexplicit equations - num_var_nonexplicit_RHS = 0; - for (const auto &[index, variable] : variable_attributes.attributes) - { - if (!static_cast(variable.eval_flags_nonexplicit_RHS & - dealii::EvaluationFlags::nothing)) - { - num_var_nonexplicit_RHS++; - } - } - varInfoListNonexplicitRHS.reserve(num_var_nonexplicit_RHS); - for (const auto &[index, variable] : variable_attributes.attributes) - { - variable_info varInfo {}; - - varInfo.evaluation_flags = variable.eval_flags_nonexplicit_RHS; - - varInfo.residual_flags = variable.eval_flags_residual_nonexplicit_RHS; - - varInfo.global_var_index = index; - - varInfo.var_needed = - !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = variable.var_type == SCALAR; - - varInfoListNonexplicitRHS.push_back(varInfo); - } - - // Load variable information for calculating the LHS - num_var_LHS = 0; - for (const auto &[index, variable] : variable_attributes.attributes) - { - if (!static_cast(variable.eval_flags_nonexplicit_LHS & - dealii::EvaluationFlags::nothing)) - { - num_var_LHS++; - } - } - - varInfoListLHS.reserve(num_var_LHS); - for (const auto &[index, variable] : variable_attributes.attributes) - { - variable_info varInfo {}; - - varInfo.evaluation_flags = variable.eval_flags_nonexplicit_LHS; - - varInfo.residual_flags = variable.eval_flags_residual_nonexplicit_LHS; - - varInfo.global_var_index = index; - - varInfo.var_needed = - !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = variable.var_type == SCALAR; - - varInfoListLHS.push_back(varInfo); - } - - varChangeInfoListLHS.reserve(num_var_LHS); - for (const auto &[index, variable] : variable_attributes.attributes) - { - variable_info varInfo {}; - - varInfo.evaluation_flags = variable.eval_flags_change_nonexplicit_LHS; - - // FOR NOW, TAKING THESE FROM THE VARIABLE ITSELF!! - varInfo.residual_flags = variable.eval_flags_residual_nonexplicit_LHS; - - varInfo.global_var_index = index; - - varInfo.var_needed = - !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = variable.var_type == SCALAR; - - varChangeInfoListLHS.push_back(varInfo); - } - - // Load variable information for postprocessing - // First, the info list for the base field variables - pp_baseVarInfoList.reserve(number_of_variables); - for (const auto &[index, variable] : variable_attributes.attributes) - { - variable_info varInfo {}; - - varInfo.evaluation_flags = variable.eval_flags_postprocess; - - varInfo.global_var_index = index; - - varInfo.var_needed = - !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); - - varInfo.is_scalar = variable.var_type == SCALAR; - - pp_baseVarInfoList.push_back(varInfo); - } - - // Now load the information for the post-processing variables - // Parameters for postprocessing - - postProcessingRequired = pp_number_of_variables > 0; - - num_integrated_fields = 0; - for (const auto &[pp_index, pp_variable] : variable_attributes.pp_attributes) - { - if (pp_variable.calc_integral) - { - num_integrated_fields++; - integrated_field_indices.push_back(pp_index); - } - } - - // The info list for the postprocessing field variables - pp_varInfoList.reserve(pp_number_of_variables); - for (const auto &[pp_index, pp_variable] : variable_attributes.pp_attributes) - { - variable_info varInfo {}; - - varInfo.var_needed = true; - - varInfo.residual_flags = pp_variable.eval_flags_residual_postprocess; - - varInfo.global_var_index = pp_index; - - varInfo.is_scalar = pp_variable.var_type == SCALAR; - - pp_varInfoList.push_back(varInfo); - } -} - -// Template instantiations -#include "../../include/userInputParameters_template_instantiations.h" diff --git a/src/userInputParameters/load_BC_list.cc b/src/userInputParameters/load_BC_list.cc deleted file mode 100644 index 2976486db..000000000 --- a/src/userInputParameters/load_BC_list.cc +++ /dev/null @@ -1,92 +0,0 @@ -// ------------------------------------------------------------------------ -// Method to extract the list of boundary conditions from input parameters -// and store them in BC_list object -// ------------------------------------------------------------------------ - -#include - -#include "../../include/userInputParameters.h" -#include - -template -void -userInputParameters::load_BC_list(const std::vector &list_of_BCs) -{ - // Loop over the list of boundary conditions specified in parameters - // and provided in the input list_of_BCs. Process the BCs and place - // them into the vector BC_list - std::vector temp; - for (const auto &boundary_condition : list_of_BCs) - { - // Ensure all variables have BCs specified in parameters.prm - AssertThrow(!boundary_condition.empty(), - dealii::ExcMessage(std::string("Boundary condition not specified."))); - - varBCs newBC; - temp = dealii::Utilities::split_string_list(boundary_condition); - - // If there is only one BC listed, make another 2*dim-1 copies of it so that - // the same BC is applied for all boundaries - if (temp.size() == 1) - { - temp.resize(static_cast(2 * dim), temp[0]); - } - - // Load the BC for each boundary into 'newBC'. - for (unsigned int j = 0; j < (2 * dim); j++) - { - if (boost::iequals(temp[j], "NATURAL")) - { - newBC.var_BC_type.push_back(NATURAL); - newBC.var_BC_val.push_back(0.0); - } - else if (boost::iequals(temp[j], "PERIODIC")) - { - newBC.var_BC_type.push_back(PERIODIC); - newBC.var_BC_val.push_back(0.0); - } - else if (boost::iequals(temp[j], "NON_UNIFORM_DIRICHLET")) - { - newBC.var_BC_type.push_back(NON_UNIFORM_DIRICHLET); - newBC.var_BC_val.push_back(0.0); - } - else if (boost::iequals(temp[j].substr(0, 9), "DIRICHLET")) - { - newBC.var_BC_type.push_back(DIRICHLET); - std::string dirichlet_val = temp[j].substr(10, temp[j].size()); - dirichlet_val = dealii::Utilities::trim(dirichlet_val); - newBC.var_BC_val.push_back( - dealii::Utilities::string_to_double(dirichlet_val)); - } - else if (boost::iequals(temp[j].substr(0, 7), "NEUMANN")) - { - newBC.var_BC_type.push_back(NEUMANN); - std::string neumann_val = temp[j].substr(8, temp[j].size()); - neumann_val = dealii::Utilities::trim(neumann_val); - newBC.var_BC_val.push_back( - dealii::Utilities::string_to_double(neumann_val)); - } - else - { - std::cout << temp[j].substr(0, 8) << "\n"; - std::cout << "Error: Boundary conditions specified improperly.\n"; - abort(); - } - - // If periodic BCs are used, ensure they are applied on both sides of - // domain - if (j % 2 == 0) - { - AssertThrow(boost::iequals(temp[j], "PERIODIC") == - boost::iequals(temp[j + 1], "PERIODIC"), - dealii::ExcMessage( - std::string("Periodic boundary condition must be " - "specified on both sides of domain"))); - } - } - // Append BCs for current field to total list - BC_list.push_back(newBC); - } -} - -#include "../../include/userInputParameters_template_instantiations.h" \ No newline at end of file diff --git a/src/userInputParameters/load_user_constants.cc b/src/userInputParameters/load_user_constants.cc deleted file mode 100644 index 3e1875467..000000000 --- a/src/userInputParameters/load_user_constants.cc +++ /dev/null @@ -1,494 +0,0 @@ -#include -#include - -#include "../../include/userInputParameters.h" - -// ========================================================================================== -// Method to extract the user-defined model constants -// ========================================================================================== -template -void -userInputParameters::load_user_constants(inputFileReader &input_file_reader, - dealii::ParameterHandler ¶meter_handler) -{ - const unsigned int number_of_constants = input_file_reader.num_constants; - - for (unsigned int i = 0; i < input_file_reader.model_constant_names.size(); i++) - { - model_constant_name_map[input_file_reader.model_constant_names[i]] = i; - } - - for (unsigned int i = 0; i < number_of_constants; i++) - { - std::string constants_text = "Model constant "; - constants_text.append(input_file_reader.model_constant_names[i]); - // std::cout << input_file_reader.model_constant_names[i] << std::endl; - std::vector model_constants_strings = - dealii::Utilities::split_string_list(parameter_handler.get(constants_text)); - - // Ensure that the input includes a value and a type - if (model_constants_strings.size() < 2) - { - std::cerr << "PRISMS-PF ERROR: Users must input two fields for " - "user-defined variables (value and type).\n"; - abort(); - } - - std::vector model_constants_type_strings = - dealii::Utilities::split_string_list(model_constants_strings.at( - model_constants_strings.size() - 1), - ' '); - - if (model_constants_strings.size() == 2) - { - if (boost::iequals(model_constants_type_strings.at(0), "double")) - { - model_constants.push_back( - dealii::Utilities::string_to_double(model_constants_strings.at(0))); - } - else if (boost::iequals(model_constants_type_strings.at(0), "int")) - { - model_constants.push_back( - dealii::Utilities::string_to_int(model_constants_strings.at(0))); - } - else if (boost::iequals(model_constants_type_strings.at(0), "bool")) - { - bool temp = boost::iequals(model_constants_strings.at(0), "true"); - model_constants.push_back(temp); - } - else - { - std::cerr << "PRISMS-PF ERROR: The type for user-defined " - "variables must be 'double', 'int', 'bool', " - "'tensor', or 'elastic constants'.\n"; - abort(); - } - } - else - { - if (boost::iequals(model_constants_type_strings.at(0), "tensor")) - { - const unsigned int num_elements = model_constants_strings.size() - 1; - - // Strip parentheses from the input, counting how many rows there - // are - unsigned int open_parentheses = 0; - unsigned int close_parentheses = 0; - for (unsigned int element = 0; element < num_elements; element++) - { - std::size_t index = 0; - while (index != std::string::npos) - { - index = model_constants_strings.at(element).find('('); - if (index != std::string::npos) - { - model_constants_strings.at(element).erase(index, 1); - open_parentheses++; - } - } - index = 0; - while (index != std::string::npos) - { - index = model_constants_strings.at(element).find(')'); - if (index != std::string::npos) - { - model_constants_strings.at(element).erase(index, 1); - close_parentheses++; - } - } - } - if (open_parentheses != close_parentheses) - { - std::cerr << "PRISMS-PF ERROR: User-defined constant tensor does not " - "have the same number of open and close parentheses.\n"; - abort(); - } - // Rank 1 tensor - if (open_parentheses < 3) - { - if (num_elements > 1 && num_elements < 4) - { - dealii::Tensor<1, dim> temp; - for (unsigned int i = 0; i < dim; i++) - { - temp[i] = dealii::Utilities::string_to_double( - model_constants_strings.at(i)); - } - model_constants.push_back(temp); - } - else - { - std::cerr - << "PRISMS-PF ERROR: The columns in user-defined " - "constant tensors cannot be longer than 3 elements " - "(internally truncated to the number of dimensions).\n"; - abort(); - } - } - // Rank 2 tensor - else if (open_parentheses < 5) - { - unsigned int row_length = 0; - if (num_elements == 4) - { - row_length = 2; - if (dim > 2) - { - std::cerr << "PRISMS-PF ERROR: User-defined constant tensor " - "does not have enough elements, for 3D " - "calculations matrices must be 3x3.\n"; - abort(); - } - } - else if (num_elements == 9) - { - row_length = 3; - } - else - { - std::cerr << "PRISMS-PF ERROR: User-defined constant " - "tensor does not have the correct number of " - "elements, matrices must be 2x2 or 3x3.\n"; - abort(); - } - - dealii::Tensor<2, dim> temp; - for (unsigned int i = 0; i < dim; i++) - { - for (unsigned int j = 0; j < dim; j++) - { - temp[i][j] = dealii::Utilities::string_to_double( - model_constants_strings.at(i * row_length + j)); - } - } - model_constants.push_back(temp); - } - } - else if (boost::iequals(model_constants_type_strings.at(1), "elastic") && - boost::iequals(model_constants_type_strings.at(2), "constants")) - { - const unsigned int num_elements = model_constants_strings.size() - 1; - - // Strip parentheses from the input, counting how many rows there - // are - unsigned int open_parentheses = 0; - unsigned int close_parentheses = 0; - for (unsigned int element = 0; element < num_elements; element++) - { - std::size_t index = 0; - while (index != std::string::npos) - { - index = model_constants_strings.at(element).find('('); - if (index != std::string::npos) - { - model_constants_strings.at(element).erase(index, 1); - open_parentheses++; - } - } - index = 0; - while (index != std::string::npos) - { - index = model_constants_strings.at(element).find(')'); - if (index != std::string::npos) - { - model_constants_strings.at(element).erase(index, 1); - close_parentheses++; - } - } - } - if (open_parentheses != close_parentheses) - { - std::cerr << "PRISMS-PF ERROR: User-defined elastic constant " - "list does not have the same number of open and " - "close parentheses.\n"; - abort(); - } - - // Load in the elastic constants as a vector - std::vector temp_elastic_constants; - for (unsigned int i = 0; i < num_elements; i++) - { - temp_elastic_constants.push_back( - dealii::Utilities::string_to_double(model_constants_strings.at(i))); - } - - const std::string elastic_const_symmetry = - model_constants_type_strings.at(0); - dealii::Tensor<2, 2 *dim - 1 + dim / 3> temp = - get_Cij_tensor(temp_elastic_constants, elastic_const_symmetry); - model_constants.push_back(temp); - } - else - { - std::cerr << "PRISMS-PF ERROR: Only user-defined constant " - "tensors may have multiple elements.\n"; - abort(); - } - } - } -} - -// ========================================================================================== -// Method to build the elasticity tensor from a list of elastic constants -// ========================================================================================== -template -dealii::Tensor<2, 2 * dim - 1 + dim / 3> -userInputParameters::get_Cij_tensor(std::vector elastic_constants, - const std::string &elastic_const_symmetry) const -{ - // First set the material model - elasticityModel mat_model = ISOTROPIC; - if (elastic_const_symmetry == "isotropic") - { - mat_model = ISOTROPIC; - } - else if (elastic_const_symmetry == "transverse") - { - mat_model = TRANSVERSE; - } - else if (elastic_const_symmetry == "orthotropic") - { - mat_model = ORTHOTROPIC; - } - else if (elastic_const_symmetry == "anisotropic") - { - mat_model = ANISOTROPIC; - } - else - { - // Should change to an exception - std::cerr << "Elastic material model is invalid, please use isotropic, " - "transverse, orthotropic, or anisotropic\n"; - } - - // If the material model is anisotropic for a 2D calculation but the elastic - // constants are given for a 3D calculation, change the elastic constant - // vector to the 2D form - if ((mat_model == ANISOTROPIC) && (dim == 2) && elastic_constants.size() == 21) - { - std::vector elastic_constants_temp = elastic_constants; - elastic_constants.clear(); - const std::vector indices_2D = {0, 1, 5, 6, 10, 14}; - for (const auto &index : indices_2D) - { - elastic_constants.push_back(elastic_constants_temp.at(index)); - } - } - - dealii::ConditionalOStream pcout(std::cout, - dealii::Utilities::MPI::this_mpi_process( - MPI_COMM_WORLD) == 0); - - return getCIJMatrix(mat_model, elastic_constants, pcout); -} - -// implementation of various models of anisotropy for -// st.venant-kirchoff material model of elasticity - -// #include - -// Each material model is characterized by the number of independent -// constants required to characterize its elasticity tensor in the Voigt -// notation - -// 3D models: -// ISOTROPIC - 2 constants [E, nu], where E-modulus and nu-poisson's ratio -// TRANSVERSE- 5 constants [C11 C33 C44 C12 C13] -// ORTHOTROPIC- 9 constants [C11 C22 C33 C44 C55 C66 C12 C13 C23] -// ANISOTROPIC- 21 constants [C11 C22 C33 C44 C55 C66 C12 C13 C14 C15 -// C16 C23 C24 C25 C26 C34 C35 C36 C45 C46 C56] - -// 2D models: -// ISOTROPIC- 2 constants [E, nu] (Plane Strain) -// ANISOTROPIC- 6 constants [C11 C22 C66 C12 C16 C26] (Plane Strain) - -// 1D models: -// ISOTROPIC- 1 constant [E] - -template -dealii::Tensor<2, 2 * dim - 1 + dim / 3> -userInputParameters::getCIJMatrix(const elasticityModel model, - const std::vector &constants, - dealii::ConditionalOStream &pcout) const -{ - // CIJ.fill(0.0); - dealii::Tensor<2, 2 * dim - 1 + dim / 3> CIJ; - - pcout << "Reading material model:"; - switch (dim) - { - case 1: - { - pcout << " 1D "; - // 1D models - switch (model) - { - case ISOTROPIC: - { - pcout << " ISOTROPIC \n"; - CIJ[0][0] = constants[0]; - break; - } - default: - { - std::cout << "\nelasticityModels: Supported models in 1D - " - "ISOTROPIC\n"; - std::cout << "See /src/elasticityModels.h\n"; - exit(-1); - } - } - break; - } - case 2: - { - pcout << " 2D "; - // 2D models - switch (model) - { - case ISOTROPIC: - { - pcout << " ISOTROPIC \n"; - const double E = constants[0]; - const double nu = constants[1]; - const double mu = E / (2 * (1 + nu)); - const double lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); - CIJ[0][0] = lambda + 2 * mu; - CIJ[1][1] = lambda + 2 * mu; - CIJ[2][2] = mu; - CIJ[0][1] = CIJ[1][0] = lambda; - break; - } - case ANISOTROPIC: - { - pcout << " ANISOTROPIC \n"; - CIJ[0][0] = constants[0]; // C11 - CIJ[1][1] = constants[1]; // C22 - CIJ[2][2] = constants[2]; // C33 - CIJ[0][1] = CIJ[1][0] = constants[3]; // C12 - CIJ[0][2] = CIJ[2][0] = constants[4]; // C13 - CIJ[1][2] = CIJ[2][1] = constants[5]; // C23 - break; - } - default: - { - std::cout << "\nelasticityModels: Supported models in 2D - " - "ISOTROPIC/ANISOTROPIC\n"; - std::cout << "See /src/elasticityModels.h\n"; - exit(-1); - } - } - break; - } - case 3: - { - pcout << " 3D "; - // 3D models - switch (model) - { - case ISOTROPIC: - { - pcout << " ISOTROPIC \n"; - const double E = constants[0]; - const double nu = constants[1]; - const double mu = E / (2 * (1 + nu)); - const double lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); - CIJ[0][0] = lambda + 2 * mu; - CIJ[1][1] = lambda + 2 * mu; - CIJ[2][2] = lambda + 2 * mu; - CIJ[3][3] = mu; - CIJ[4][4] = mu; - CIJ[5][5] = mu; - CIJ[0][1] = CIJ[1][0] = lambda; - CIJ[0][2] = CIJ[2][0] = lambda; - CIJ[1][2] = CIJ[2][1] = lambda; - break; - } - case TRANSVERSE: - { - pcout << " TRANSVERSE \n"; - CIJ[0][0] = constants[0]; // C11 - CIJ[1][1] = constants[0]; // C11 - CIJ[2][2] = constants[1]; // C33 - CIJ[3][3] = constants[2]; // C44 - CIJ[4][4] = constants[2]; // C44 - CIJ[5][5] = (constants[0] - constants[3]) / 2.0; //(C11-C12)/2 - CIJ[0][1] = CIJ[1][0] = constants[3]; // C12 - CIJ[0][2] = CIJ[2][0] = constants[4]; // C13 - CIJ[1][2] = CIJ[2][1] = constants[4]; // C13 - break; - } - case ORTHOTROPIC: - { - pcout << " ORTHOTROPIC \n"; - CIJ[0][0] = constants[0]; // C11 - CIJ[1][1] = constants[1]; // C22 - CIJ[2][2] = constants[2]; // C33 - CIJ[3][3] = constants[3]; // C44 - CIJ[4][4] = constants[4]; // C55 - CIJ[5][5] = constants[5]; // C66 - CIJ[0][1] = CIJ[1][0] = constants[6]; // C12 - CIJ[0][2] = CIJ[2][0] = constants[7]; // C13 - CIJ[1][2] = CIJ[2][1] = constants[8]; // C23 - break; - } - case ANISOTROPIC: - { - pcout << " ANISOTROPIC \n"; - CIJ[0][0] = constants[0]; // C11 - CIJ[1][1] = constants[1]; // C22 - CIJ[2][2] = constants[2]; // C33 - CIJ[3][3] = constants[3]; // C44 - CIJ[4][4] = constants[4]; // C55 - CIJ[5][5] = constants[5]; // C66 - CIJ[0][1] = CIJ[1][0] = constants[6]; // C12 - CIJ[0][2] = CIJ[2][0] = constants[7]; // C13 - CIJ[0][3] = CIJ[3][0] = constants[8]; // C14 - CIJ[0][4] = CIJ[4][0] = constants[9]; // C15 - CIJ[0][5] = CIJ[5][0] = constants[10]; // C16 - CIJ[1][2] = CIJ[2][1] = constants[11]; // C23 - CIJ[1][3] = CIJ[3][1] = constants[12]; // C24 - CIJ[1][4] = CIJ[4][1] = constants[13]; // C25 - CIJ[1][5] = CIJ[5][1] = constants[14]; // C26 - CIJ[2][3] = CIJ[3][2] = constants[15]; // C34 - CIJ[2][4] = CIJ[4][2] = constants[16]; // C35 - CIJ[2][5] = CIJ[5][2] = constants[17]; // C36 - CIJ[3][4] = CIJ[4][3] = constants[18]; // C45 - CIJ[3][5] = CIJ[5][3] = constants[19]; // C46 - CIJ[4][5] = CIJ[5][4] = constants[20]; // C56 - break; - } - default: - { - std::cout << "\nelasticityModels: Supported models in 3D - " - "ISOTROPIC/TRANSVERSE/ORTHOTROPIC/ANISOTROPIC\n"; - std::cout << "See /src/elasticityModels.h\n"; - exit(-1); - } - } - break; - } - default: - { - std::cout << "\nelasticityModels: DIM is not 1/2/3\n"; - exit(-1); - } - } - // print CIJ to terminal - pcout << "Elasticity matrix (Voigt notation):\n"; - constexpr unsigned int voight_matrix_size = 2 * dim - 1 + dim / 3; - std::array buffer {}; - for (unsigned int i = 0; i < voight_matrix_size; i++) - { - for (unsigned int j = 0; j < voight_matrix_size; j++) - { - snprintf(buffer.data(), buffer.size(), "%8.3e ", CIJ[i][j]); - pcout << buffer.data(); - } - pcout << "\n"; - } - pcout << "\n"; - return CIJ; -} - -// Template instantiations -#include "../../include/userInputParameters_template_instantiations.h" diff --git a/src/userInputParameters/setTimeStepList.cc b/src/userInputParameters/setTimeStepList.cc deleted file mode 100644 index e9d15006d..000000000 --- a/src/userInputParameters/setTimeStepList.cc +++ /dev/null @@ -1,84 +0,0 @@ -#include - -#include "../../include/userInputParameters.h" -#include - -template -std::vector -userInputParameters::setTimeStepList( - const std::string &outputSpacingType, - unsigned int numberOfOutputs, - const std::vector &userGivenTimeStepList) -{ - // Initialize timestep list - std::vector timeStepList; - - // The number of outputs cannot be greater than the number increments - numberOfOutputs = std::min(numberOfOutputs, totalIncrements); - - // Prevent divide by zero in subsequent output types by returning the a vector where the - // only entry is one greater than the number of increments. This way, we effectively - // have no outputs. While this condition can be ignored for the LIST type, the user - // should just ignore the parameter `set Number of outputs` and use the default value - // of 10. - if (numberOfOutputs == 0) - { - timeStepList.push_back(totalIncrements + 1); - return timeStepList; - } - - // Set output list for all the output list types - if (outputSpacingType == "LIST") - { - timeStepList = userGivenTimeStepList; - } - else if (outputSpacingType == "EQUAL_SPACING") - { - for (unsigned int iter = 0; iter <= totalIncrements; - iter += totalIncrements / numberOfOutputs) - { - timeStepList.push_back(iter); - } - } - else if (outputSpacingType == "LOG_SPACING") - { - timeStepList.push_back(0); - for (unsigned int output = 1; output <= numberOfOutputs; output++) - { - timeStepList.push_back(round(std::pow(static_cast(totalIncrements), - static_cast(output) / - static_cast(numberOfOutputs)))); - } - } - else if (outputSpacingType == "N_PER_DECADE") - { - AssertThrow(totalIncrements > 1, - dealii::ExcMessage( - std::string("PRISMS-PF Error: For n per decaded spaced outputs, " - "the number of increments must be greater than 1."))); - - timeStepList.push_back(0); - timeStepList.push_back(1); - for (unsigned int iter = 2; iter <= totalIncrements; iter++) - { - const unsigned int decade = std::ceil(std::log10(iter)); - const auto step_size = - static_cast(std::pow(10, decade) / numberOfOutputs); - if (iter % step_size == 0) - { - timeStepList.push_back(iter); - } - } - } - else - { - AssertThrow(false, - dealii::ExcMessage( - std::string("PRISMS-PF Error: Invalid output spacing type."))); - } - - return timeStepList; -} - -// Template instantiations -#include "../../include/userInputParameters_template_instantiations.h" diff --git a/src/userInputParameters/userInputParameters.cc b/src/userInputParameters/userInputParameters.cc index be0e4d421..21ae5aed3 100644 --- a/src/userInputParameters/userInputParameters.cc +++ b/src/userInputParameters/userInputParameters.cc @@ -1,35 +1,31 @@ // Methods for the userInputParameters class #include "../../include/userInputParameters.h" +#include #include #include +#include +#include + template -userInputParameters::userInputParameters(inputFileReader &input_file_reader, - dealii::ParameterHandler ¶meter_handler, - variableAttributeLoader variable_attributes) +void +userInputParameters::assign_spatial_discretization_parameters( + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes) { - loadVariableAttributes(variable_attributes); - - // Load the inputs into the class member variables - - // Meshing parameters + // Domain size & subdivisions domain_size.push_back(parameter_handler.get_double("Domain size X")); - if (dim > 1) - { - domain_size.push_back(parameter_handler.get_double("Domain size Y")); - if (dim > 2) - { - domain_size.push_back(parameter_handler.get_double("Domain size Z")); - } - } - subdivisions.push_back(parameter_handler.get_integer("Subdivisions X")); + if (dim > 1) { + domain_size.push_back(parameter_handler.get_double("Domain size Y")); subdivisions.push_back(parameter_handler.get_integer("Subdivisions Y")); + if (dim > 2) { + domain_size.push_back(parameter_handler.get_double("Domain size Z")); subdivisions.push_back(parameter_handler.get_integer("Subdivisions Z")); } } @@ -68,7 +64,7 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.enter_subsection(subsection_text); { - std::string crit_type_string = parameter_handler.get("Criterion type"); + const std::string crit_type_string = parameter_handler.get("Criterion type"); if (!crit_type_string.empty()) { RefinementCriterion new_criterion; @@ -134,14 +130,79 @@ userInputParameters::userInputParameters(inputFileReader &input_fi } parameter_handler.leave_subsection(); } +} - // Time stepping parameters +template +void +userInputParameters::assign_temporal_discretization_parameters( + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes) +{ dtValue = parameter_handler.get_double("Time step"); const int totalIncrements_temp = static_cast(parameter_handler.get_integer("Number of time steps")); finalTime = parameter_handler.get_double("Simulation end time"); - // Linear solver parameters + // If all of the variables are ELLIPTIC, then totalIncrements should be 1 and + // finalTime should be 0 + bool only_time_independent_pdes = true; + for (const auto &[index, variable] : variable_attributes.attributes) + { + if (variable.eq_type == EXPLICIT_TIME_DEPENDENT || + variable.eq_type == IMPLICIT_TIME_DEPENDENT) + { + only_time_independent_pdes = false; + break; + } + } + + // Determine the maximum number of time steps + if (only_time_independent_pdes) + { + totalIncrements = 1; + finalTime = 0.0; + } + else + { + if ((totalIncrements_temp >= 0) && (finalTime >= 0.0)) + { + if (std::ceil(finalTime / dtValue) > totalIncrements_temp) + { + totalIncrements = totalIncrements_temp; + finalTime = totalIncrements * dtValue; + } + else + { + totalIncrements = std::ceil(finalTime / dtValue); + } + } + else if ((totalIncrements_temp >= 0) && (finalTime < 0.0)) + { + totalIncrements = totalIncrements_temp; + finalTime = totalIncrements * dtValue; + } + else if ((totalIncrements_temp < 0) && (finalTime >= 0.0)) + { + totalIncrements = std::ceil(finalTime / dtValue); + } + else + { + // Should change to an exception + std::cerr << "Invalid selections for the final time and the number " + "of increments. At least one should be given in the " + "input file and should be positive.\n"; + std::cout << finalTime << " " << totalIncrements_temp << "\n"; + abort(); + } + } +} + +template +void +userInputParameters::assign_linear_solve_parameters( + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes) +{ for (const auto &[index, variable] : variable_attributes.attributes) { if (variable.eq_type == TIME_INDEPENDENT || @@ -196,8 +257,14 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.leave_subsection(); } } +} - // Non-linear solver parameters +template +void +userInputParameters::assign_nonlinear_solve_parameters( + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes) +{ nonlinear_solver_parameters.setMaxIterations( parameter_handler.get_integer("Maximum nonlinear solver iterations")); @@ -300,8 +367,13 @@ userInputParameters::userInputParameters(inputFileReader &input_fi { nonlinear_solver_parameters.setMaxIterations(0); } +} - // Output parameters +template +void +userInputParameters::assign_output_parameters( + dealii::ParameterHandler ¶meter_handler) +{ const std::string output_condition = parameter_handler.get("Output condition"); const unsigned int num_outputs = parameter_handler.get_integer("Number of outputs"); const std::vector user_given_time_step_list_temp = @@ -337,65 +409,37 @@ userInputParameters::userInputParameters(inputFileReader &input_fi // Field variable definitions - // If all of the variables are ELLIPTIC, then totalIncrements should be 1 and - // finalTime should be 0 - bool only_time_independent_pdes = true; - for (const auto &[index, variable] : variable_attributes.attributes) - { - if (variable.eq_type == EXPLICIT_TIME_DEPENDENT || - variable.eq_type == IMPLICIT_TIME_DEPENDENT) - { - only_time_independent_pdes = false; - break; - } - } - - // Determine the maximum number of time steps - if (only_time_independent_pdes) - { - totalIncrements = 1; - finalTime = 0.0; - } - else - { - if ((totalIncrements_temp >= 0) && (finalTime >= 0.0)) - { - if (std::ceil(finalTime / dtValue) > totalIncrements_temp) - { - totalIncrements = totalIncrements_temp; - finalTime = totalIncrements * dtValue; - } - else - { - totalIncrements = std::ceil(finalTime / dtValue); - } - } - else if ((totalIncrements_temp >= 0) && (finalTime < 0.0)) - { - totalIncrements = totalIncrements_temp; - finalTime = totalIncrements * dtValue; - } - else if ((totalIncrements_temp < 0) && (finalTime >= 0.0)) - { - totalIncrements = std::ceil(finalTime / dtValue); - } - else - { - // Should change to an exception - std::cerr << "Invalid selections for the final time and the number " - "of increments. At least one should be given in the " - "input file and should be positive.\n"; - std::cout << finalTime << " " << totalIncrements_temp << "\n"; - abort(); - } - } - // Use these inputs to create a list of time steps where the code should // output, stored in the member outputTimeStepList = setTimeStepList(output_condition, num_outputs, user_given_time_step_list); - // Variables for loading in PField ICs + // Parameters for checkpoint/restart + resume_from_checkpoint = parameter_handler.get_bool("Load from a checkpoint"); + const std::string checkpoint_condition = parameter_handler.get("Checkpoint condition"); + const unsigned int num_checkpoints = + parameter_handler.get_integer("Number of checkpoints"); + + const std::vector user_given_checkpoint_time_step_list_temp = + dealii::Utilities::string_to_int(dealii::Utilities::split_string_list( + parameter_handler.get("List of time steps to save checkpoints"))); + std::vector user_given_checkpoint_time_step_list; + user_given_checkpoint_time_step_list.reserve( + user_given_checkpoint_time_step_list_temp.size()); + for (const auto &checkpoint_step : user_given_checkpoint_time_step_list_temp) + { + user_given_checkpoint_time_step_list.push_back(checkpoint_step); + } + checkpointTimeStepList = setTimeStepList(checkpoint_condition, + num_checkpoints, + user_given_checkpoint_time_step_list); +} + +template +void +userInputParameters::assign_load_initial_condition_parameters( + dealii::ParameterHandler ¶meter_handler) +{ // Variables for loading in PField ICs std::vector load_ICs_temp = dealii::Utilities::split_string_list( parameter_handler.get("Load initial conditions")); std::vector load_parallel_file_temp = @@ -436,29 +480,14 @@ userInputParameters::userInputParameters(inputFileReader &input_fi dealii::Utilities::split_string_list(parameter_handler.get("File names")); load_field_name = dealii::Utilities::split_string_list( parameter_handler.get("Variable names in the files")); +} - // Parameters for checkpoint/restart - resume_from_checkpoint = parameter_handler.get_bool("Load from a checkpoint"); - const std::string checkpoint_condition = parameter_handler.get("Checkpoint condition"); - const unsigned int num_checkpoints = - parameter_handler.get_integer("Number of checkpoints"); - - const std::vector user_given_checkpoint_time_step_list_temp = - dealii::Utilities::string_to_int(dealii::Utilities::split_string_list( - parameter_handler.get("List of time steps to save checkpoints"))); - std::vector user_given_checkpoint_time_step_list; - user_given_checkpoint_time_step_list.reserve( - user_given_checkpoint_time_step_list_temp.size()); - for (const auto &checkpoint_step : user_given_checkpoint_time_step_list_temp) - { - user_given_checkpoint_time_step_list.push_back(checkpoint_step); - } - checkpointTimeStepList = setTimeStepList(checkpoint_condition, - num_checkpoints, - user_given_checkpoint_time_step_list); - - // Parameters for nucleation - +template +void +userInputParameters::assign_nucleation_parameters( + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes) +{ for (const auto &[index, variable] : variable_attributes.attributes) { if (variable.nucleating_variable) @@ -468,8 +497,8 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.enter_subsection(nucleation_text); { - unsigned int var_index = index; - std::vector semiaxes = + const unsigned int var_index = index; + const std::vector semiaxes = dealii::Utilities::string_to_double(dealii::Utilities::split_string_list( parameter_handler.get("Nucleus semiaxes (x, y, z)"))); const std::vector ellipsoid_rotation = @@ -543,8 +572,14 @@ userInputParameters::userInputParameters(inputFileReader &input_fi parameter_handler.get_integer("Time steps between nucleation attempts"); nucleation_start_time = parameter_handler.get_double("Nucleation start time"); nucleation_end_time = parameter_handler.get_double("Nucleation end time"); +} - // Load the grain remapping parameters +template +void +userInputParameters::assign_grain_parameters( + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes) +{ // Load the grain remapping parameters grain_remapping_activated = parameter_handler.get_bool("Activate grain reassignment"); skip_grain_reassignment_steps = @@ -598,7 +633,14 @@ userInputParameters::userInputParameters(inputFileReader &input_fi "Number of smoothing cycles after grain structure loading"); min_radius_for_loading_grains = parameter_handler.get_double("Minimum radius for loaded grains"); +} +template +void +userInputParameters::assign_boundary_condition_parameters( + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader &variable_attributes) +{ // Load the boundary condition variables into list of BCs (where each element // of the vector is one component of one variable) std::vector list_of_BCs; @@ -665,10 +707,877 @@ userInputParameters::userInputParameters(inputFileReader &input_fi // Load the BC information from the strings into a varBCs object load_BC_list(list_of_BCs); +} + +// NOLINTBEGIN(cppcoreguidelines-pro-type-member-init, hicpp-member-init) +template +userInputParameters::userInputParameters(inputFileReader &input_file_reader, + dealii::ParameterHandler ¶meter_handler, + variableAttributeLoader variable_attributes) +{ + loadVariableAttributes(variable_attributes); + + // Spatial discretization + assign_spatial_discretization_parameters(parameter_handler, variable_attributes); + + // Time stepping parameters + assign_temporal_discretization_parameters(parameter_handler, variable_attributes); + + // Linear solver parameters + assign_linear_solve_parameters(parameter_handler, variable_attributes); + + // Non-linear solver parameters + assign_nonlinear_solve_parameters(parameter_handler, variable_attributes); + + // Output parameters + assign_output_parameters(parameter_handler); + + // Initial condition parameters + assign_load_initial_condition_parameters(parameter_handler); + + // Nucleation parameters + assign_nucleation_parameters(parameter_handler, variable_attributes); + + // Grain remapping & vtk load-in parameters + assign_grain_parameters(parameter_handler, variable_attributes); + + // Boundary conditions + assign_boundary_condition_parameters(parameter_handler, variable_attributes); // Load the user-defined constants load_user_constants(input_file_reader, parameter_handler); } -// Template instantiations -#include "../../include/userInputParameters_template_instantiations.h" +// NOLINTEND(cppcoreguidelines-pro-type-member-init, hicpp-member-init) + +template +void +userInputParameters::assign_boundary_conditions( + std::vector &boundary_condition_list, + varBCs &boundary_condition) +{ + // If there is only one boundary condition, copy it to have 2*dim copies. + if (boundary_condition_list.size() == 1) + { + boundary_condition_list.resize(static_cast(2 * dim), + boundary_condition_list[0]); + } + + // Assign the boundary condition into the varBCs object. + for (unsigned int j = 0; j < (2 * dim); j++) + { + if (boost::iequals(boundary_condition_list[j], "NATURAL")) + { + boundary_condition.var_BC_type.push_back(NATURAL); + boundary_condition.var_BC_val.push_back(0.0); + } + else if (boost::iequals(boundary_condition_list[j], "PERIODIC")) + { + boundary_condition.var_BC_type.push_back(PERIODIC); + boundary_condition.var_BC_val.push_back(0.0); + } + else if (boost::iequals(boundary_condition_list[j], "NON_UNIFORM_DIRICHLET")) + { + boundary_condition.var_BC_type.push_back(NON_UNIFORM_DIRICHLET); + boundary_condition.var_BC_val.push_back(0.0); + } + else if (boost::iequals(boundary_condition_list[j].substr(0, 9), "DIRICHLET")) + { + boundary_condition.var_BC_type.push_back(DIRICHLET); + std::string dirichlet_val = + boundary_condition_list[j].substr(10, boundary_condition_list[j].size()); + dirichlet_val = dealii::Utilities::trim(dirichlet_val); + boundary_condition.var_BC_val.push_back( + dealii::Utilities::string_to_double(dirichlet_val)); + } + else if (boost::iequals(boundary_condition_list[j].substr(0, 7), "NEUMANN")) + { + boundary_condition.var_BC_type.push_back(NEUMANN); + std::string neumann_val = + boundary_condition_list[j].substr(8, boundary_condition_list[j].size()); + neumann_val = dealii::Utilities::trim(neumann_val); + boundary_condition.var_BC_val.push_back( + dealii::Utilities::string_to_double(neumann_val)); + } + else + { + std::cout << boundary_condition_list[j].substr(0, 8) << "\n"; + std::cout << "Error: Boundary conditions specified improperly.\n"; + abort(); + } + + // If periodic BCs are used, ensure they are applied on both sides of + // domain + if (j % 2 == 0) + { + AssertThrow(boost::iequals(boundary_condition_list[j], "PERIODIC") == + boost::iequals(boundary_condition_list[j + 1], "PERIODIC"), + dealii::ExcMessage( + std::string("Periodic boundary condition must be " + "specified on both sides of domain"))); + } + } +} + +template +void +userInputParameters::load_BC_list(const std::vector &list_of_BCs) +{ + // Loop over the list of boundary conditions specified in parameters + // and provided in the input list_of_BCs. Process the BCs and place + // them into the vector BC_list + std::vector split_boundary_conditions; + for (const auto &boundary_condition : list_of_BCs) + { + // Ensure all variables have BCs specified in parameters.prm + AssertThrow(!boundary_condition.empty(), + dealii::ExcMessage(std::string("Boundary condition not specified."))); + + // Create object to store BCs + varBCs newBC; + + // Split string of boundary conditions + split_boundary_conditions = + dealii::Utilities::split_string_list(boundary_condition); + + // Assign the boundaries into the object + assign_boundary_conditions(split_boundary_conditions, newBC); + + // Append BCs for current field to total list + BC_list.push_back(newBC); + } +} + +template +std::vector +userInputParameters::setTimeStepList( + const std::string &outputSpacingType, + unsigned int numberOfOutputs, + const std::vector &userGivenTimeStepList) +{ + // Initialize timestep list + std::vector timeStepList; + + // The number of outputs cannot be greater than the number increments + numberOfOutputs = std::min(numberOfOutputs, totalIncrements); + + // Prevent divide by zero in subsequent output types by returning the a vector where the + // only entry is one greater than the number of increments. This way, we effectively + // have no outputs. While this condition can be ignored for the LIST type, the user + // should just ignore the parameter `set Number of outputs` and use the default value + // of 10. + if (numberOfOutputs == 0) + { + timeStepList.push_back(totalIncrements + 1); + return timeStepList; + } + + // Set output list for all the output list types + if (outputSpacingType == "LIST") + { + timeStepList = userGivenTimeStepList; + } + else if (outputSpacingType == "EQUAL_SPACING") + { + for (unsigned int iter = 0; iter <= totalIncrements; + iter += totalIncrements / numberOfOutputs) + { + timeStepList.push_back(iter); + } + } + else if (outputSpacingType == "LOG_SPACING") + { + timeStepList.push_back(0); + for (unsigned int output = 1; output <= numberOfOutputs; output++) + { + timeStepList.push_back(round(std::pow(static_cast(totalIncrements), + static_cast(output) / + static_cast(numberOfOutputs)))); + } + } + else if (outputSpacingType == "N_PER_DECADE") + { + AssertThrow(totalIncrements > 1, + dealii::ExcMessage( + std::string("PRISMS-PF Error: For n per decaded spaced outputs, " + "the number of increments must be greater than 1."))); + + timeStepList.push_back(0); + timeStepList.push_back(1); + for (unsigned int iter = 2; iter <= totalIncrements; iter++) + { + const unsigned int decade = std::ceil(std::log10(iter)); + const auto step_size = + static_cast(std::pow(10, decade) / numberOfOutputs); + if (iter % step_size == 0) + { + timeStepList.push_back(iter); + } + } + } + else + { + AssertThrow(false, + dealii::ExcMessage( + std::string("PRISMS-PF Error: Invalid output spacing type."))); + } + + return timeStepList; +} + +template +void +userInputParameters::loadVariableAttributes( + const variableAttributeLoader &variable_attributes) +{ + number_of_variables = variable_attributes.attributes.size(); + pp_number_of_variables = variable_attributes.pp_attributes.size(); + // Load some nucleation parameters + for (const auto &[index, variable] : variable_attributes.attributes) + { + if (variable.nucleating_variable) + { + nucleating_variable_indices.push_back(index); + } + if (variable.need_value_nucleation || variable.nucleating_variable) + { + nucleation_need_value.push_back(index); + } + } + + nucleation_occurs = !nucleating_variable_indices.empty(); + + // Load variable information for calculating the RHS for explicit equations + num_var_explicit_RHS = 0; + for (const auto &[index, variable] : variable_attributes.attributes) + { + if (!static_cast(variable.eval_flags_explicit_RHS & + dealii::EvaluationFlags::nothing)) + { + num_var_explicit_RHS++; + } + } + varInfoListExplicitRHS.reserve(num_var_explicit_RHS); + for (const auto &[index, variable] : variable_attributes.attributes) + { + variable_info varInfo {}; + + varInfo.evaluation_flags = variable.eval_flags_explicit_RHS; + + varInfo.residual_flags = variable.eval_flags_residual_explicit_RHS; + + varInfo.global_var_index = index; + + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + + varInfo.is_scalar = variable.var_type == SCALAR; + + varInfoListExplicitRHS.push_back(varInfo); + } + + // Load variable information for calculating the RHS for nonexplicit equations + num_var_nonexplicit_RHS = 0; + for (const auto &[index, variable] : variable_attributes.attributes) + { + if (!static_cast(variable.eval_flags_nonexplicit_RHS & + dealii::EvaluationFlags::nothing)) + { + num_var_nonexplicit_RHS++; + } + } + varInfoListNonexplicitRHS.reserve(num_var_nonexplicit_RHS); + for (const auto &[index, variable] : variable_attributes.attributes) + { + variable_info varInfo {}; + + varInfo.evaluation_flags = variable.eval_flags_nonexplicit_RHS; + + varInfo.residual_flags = variable.eval_flags_residual_nonexplicit_RHS; + + varInfo.global_var_index = index; + + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + + varInfo.is_scalar = variable.var_type == SCALAR; + + varInfoListNonexplicitRHS.push_back(varInfo); + } + + // Load variable information for calculating the LHS + num_var_LHS = 0; + for (const auto &[index, variable] : variable_attributes.attributes) + { + if (!static_cast(variable.eval_flags_nonexplicit_LHS & + dealii::EvaluationFlags::nothing)) + { + num_var_LHS++; + } + } + + varInfoListLHS.reserve(num_var_LHS); + for (const auto &[index, variable] : variable_attributes.attributes) + { + variable_info varInfo {}; + + varInfo.evaluation_flags = variable.eval_flags_nonexplicit_LHS; + + varInfo.residual_flags = variable.eval_flags_residual_nonexplicit_LHS; + + varInfo.global_var_index = index; + + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + + varInfo.is_scalar = variable.var_type == SCALAR; + + varInfoListLHS.push_back(varInfo); + } + + varChangeInfoListLHS.reserve(num_var_LHS); + for (const auto &[index, variable] : variable_attributes.attributes) + { + variable_info varInfo {}; + + varInfo.evaluation_flags = variable.eval_flags_change_nonexplicit_LHS; + + // FOR NOW, TAKING THESE FROM THE VARIABLE ITSELF!! + varInfo.residual_flags = variable.eval_flags_residual_nonexplicit_LHS; + + varInfo.global_var_index = index; + + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + + varInfo.is_scalar = variable.var_type == SCALAR; + + varChangeInfoListLHS.push_back(varInfo); + } + + // Load variable information for postprocessing + // First, the info list for the base field variables + pp_baseVarInfoList.reserve(number_of_variables); + for (const auto &[index, variable] : variable_attributes.attributes) + { + variable_info varInfo {}; + + varInfo.evaluation_flags = variable.eval_flags_postprocess; + + varInfo.global_var_index = index; + + varInfo.var_needed = + !static_cast(varInfo.evaluation_flags & dealii::EvaluationFlags::nothing); + + varInfo.is_scalar = variable.var_type == SCALAR; + + pp_baseVarInfoList.push_back(varInfo); + } + + // Now load the information for the post-processing variables + // Parameters for postprocessing + + postProcessingRequired = pp_number_of_variables > 0; + + num_integrated_fields = 0; + for (const auto &[pp_index, pp_variable] : variable_attributes.pp_attributes) + { + if (pp_variable.calc_integral) + { + num_integrated_fields++; + integrated_field_indices.push_back(pp_index); + } + } + + // The info list for the postprocessing field variables + pp_varInfoList.reserve(pp_number_of_variables); + for (const auto &[pp_index, pp_variable] : variable_attributes.pp_attributes) + { + variable_info varInfo {}; + + varInfo.var_needed = true; + + varInfo.residual_flags = pp_variable.eval_flags_residual_postprocess; + + varInfo.global_var_index = pp_index; + + varInfo.is_scalar = pp_variable.var_type == SCALAR; + + pp_varInfoList.push_back(varInfo); + } +} + +template +unsigned int +userInputParameters::compute_tensor_parentheses( + const unsigned int n_elements, + const std::vector &tensor_elements) +{ + unsigned int open_parentheses = 0; + unsigned int close_parentheses = 0; + + for (unsigned int element = 0; element < n_elements; element++) + { + for (const char c : tensor_elements.at(element)) + { + if (c == '(') + { + ++open_parentheses; + } + else if (c == ')') + { + ++close_parentheses; + } + } + } + + if (open_parentheses != close_parentheses) + { + std::cerr << "PRISMS-PF ERROR: User-defined elastic constant " + "list does not have the same number of open and " + "close parentheses.\n"; + abort(); + } + + return open_parentheses; +} + +template +void +userInputParameters::remove_parentheses(std::vector &tensor_elements) +{ + for (std::string &element : tensor_elements) + { + element.erase(std::remove(element.begin(), element.end(), '('), element.end()); + element.erase(std::remove(element.begin(), element.end(), ')'), element.end()); + } +} + +template +dealii::Tensor<1, dim> +userInputParameters::compute_rank_1_tensor_constant( + const unsigned int n_elements, + std::vector tensor_elements) +{ + AssertThrow(n_elements > 1 && n_elements < 4, + dealii::ExcMessage("PRISMS-PF Error: The columns in user-defined constant " + "tensors cannot be longer than 3 elements (internally " + "truncated to the number of dimensions).")); + + dealii::Tensor<1, dim> temp; + for (unsigned int i = 0; i < dim; i++) + { + temp[i] = dealii::Utilities::string_to_double(tensor_elements.at(i)); + } + + return temp; +} + +template +dealii::Tensor<2, dim> +userInputParameters::compute_rank_2_tensor_constant( + const unsigned int n_elements, + std::vector tensor_elements) +{ + unsigned int row_length = 0; + if (n_elements == 4) + { + AssertThrow(dim < 3, + dealii::ExcMessage( + "PRISMS-PF ERROR: User-defined constant tensor does not have " + "enough elements. For 3D calculations matrices must be 3x3.")); + + row_length = 2; + } + else if (n_elements == 9) + { + row_length = 3; + } + else + { + AssertThrow(false, + dealii::ExcMessage("PRISMS-PF ERROR: User-defined constant tensor does " + "not have the correct number of elements, matrices " + "must be 2x2 or 3x3.")); + } + + dealii::Tensor<2, dim> temp; + for (unsigned int i = 0; i < dim; i++) + { + for (unsigned int j = 0; j < dim; j++) + { + temp[i][j] = + dealii::Utilities::string_to_double(tensor_elements.at(i * row_length + j)); + } + } + + return temp; +} + +template +void +userInputParameters::assign_user_constant( + std::vector &model_constants_strings) +{ + // Ensure that the input includes a value and a type + AssertThrow(model_constants_strings.size() > 1, + dealii::ExcMessage("PRISMS-PF Error: At least two fields are required for " + "user-defined variables (value and type).")); + + std::vector model_constants_type_strings = + dealii::Utilities::split_string_list(model_constants_strings.at( + model_constants_strings.size() - 1), + ' '); + + if (model_constants_strings.size() == 2) + { + assign_primitive_user_constant(model_constants_strings); + } + else + { + if (boost::iequals(model_constants_type_strings.at(0), "tensor")) + { + const unsigned int n_elements = model_constants_strings.size() - 1; + + const unsigned int open_parentheses = + compute_tensor_parentheses(n_elements, model_constants_strings); + remove_parentheses(model_constants_strings); + + // Rank 1 tensor + if (open_parentheses < 3) + { + model_constants.push_back( + compute_rank_1_tensor_constant(n_elements, model_constants_strings)); + } + // Rank 2 tensor + else if (open_parentheses < 5) + { + model_constants.push_back( + compute_rank_2_tensor_constant(n_elements, model_constants_strings)); + } + } + else if (boost::iequals(model_constants_type_strings.at(1), "elastic") && + boost::iequals(model_constants_type_strings.at(2), "constants")) + { + const unsigned int n_elements = model_constants_strings.size() - 1; + + remove_parentheses(model_constants_strings); + + // Load in the elastic constants as a vector + std::vector temp_elastic_constants; + for (unsigned int i = 0; i < n_elements; i++) + { + temp_elastic_constants.push_back( + dealii::Utilities::string_to_double(model_constants_strings.at(i))); + } + + const std::string elastic_const_symmetry = model_constants_type_strings.at(0); + dealii::Tensor<2, 2 *dim - 1 + dim / 3> temp = + get_Cij_tensor(temp_elastic_constants, elastic_const_symmetry); + model_constants.push_back(temp); + } + else + { + AssertThrow(false, + dealii::ExcMessage( + "PRISMS-PF ERROR: Only user-defined constant tensors may " + "have multiple elements.")); + } + } +} + +template +void +userInputParameters::assign_primitive_user_constant( + std::vector &model_constants_strings) +{ + std::vector model_constants_type_strings = + dealii::Utilities::split_string_list(model_constants_strings.at( + model_constants_strings.size() - 1), + ' '); + + if (boost::iequals(model_constants_type_strings.at(0), "double")) + { + model_constants.push_back( + dealii::Utilities::string_to_double(model_constants_strings.at(0))); + } + else if (boost::iequals(model_constants_type_strings.at(0), "int")) + { + model_constants.push_back( + dealii::Utilities::string_to_int(model_constants_strings.at(0))); + } + else if (boost::iequals(model_constants_type_strings.at(0), "bool")) + { + bool temp = boost::iequals(model_constants_strings.at(0), "true"); + model_constants.push_back(temp); + } + else + { + AssertThrow(false, + dealii::ExcMessage( + "PRISMS-PF Error: The type for user-defined variables must be " + "`double`, `int`, `bool`, `tensor`, or `elastic constants`.")); + } +} + +template +void +userInputParameters::load_user_constants(inputFileReader &input_file_reader, + dealii::ParameterHandler ¶meter_handler) +{ + const unsigned int number_of_constants = input_file_reader.num_constants; + + for (unsigned int i = 0; i < input_file_reader.model_constant_names.size(); i++) + { + model_constant_name_map[input_file_reader.model_constant_names[i]] = i; + } + + for (unsigned int i = 0; i < number_of_constants; i++) + { + std::string constants_text = "Model constant "; + constants_text.append(input_file_reader.model_constant_names[i]); + + std::vector model_constants_strings = + dealii::Utilities::split_string_list(parameter_handler.get(constants_text)); + + assign_user_constant(model_constants_strings); + } +} + +template +dealii::Tensor<2, 2 * dim - 1 + dim / 3> +userInputParameters::get_Cij_tensor(std::vector elastic_constants, + const std::string &elastic_const_symmetry) const +{ + // First set the material model + elasticityModel mat_model = ISOTROPIC; + if (elastic_const_symmetry == "isotropic") + { + mat_model = ISOTROPIC; + } + else if (elastic_const_symmetry == "transverse") + { + mat_model = TRANSVERSE; + } + else if (elastic_const_symmetry == "orthotropic") + { + mat_model = ORTHOTROPIC; + } + else if (elastic_const_symmetry == "anisotropic") + { + mat_model = ANISOTROPIC; + } + else + { + // Should change to an exception + std::cerr << "Elastic material model is invalid, please use isotropic, " + "transverse, orthotropic, or anisotropic\n"; + } + + // If the material model is anisotropic for a 2D calculation but the elastic + // constants are given for a 3D calculation, change the elastic constant + // vector to the 2D form + if ((mat_model == ANISOTROPIC) && (dim == 2) && elastic_constants.size() == 21) + { + std::vector elastic_constants_temp = elastic_constants; + elastic_constants.clear(); + const std::vector indices_2D = {0, 1, 5, 6, 10, 14}; + for (const auto &index : indices_2D) + { + elastic_constants.push_back(elastic_constants_temp.at(index)); + } + } + + dealii::ConditionalOStream pcout(std::cout, + dealii::Utilities::MPI::this_mpi_process( + MPI_COMM_WORLD) == 0); + + return getCIJMatrix(mat_model, elastic_constants, pcout); +} + +template +dealii::Tensor<2, 2 * dim - 1 + dim / 3> +userInputParameters::getCIJMatrix(const elasticityModel model, + const std::vector &constants, + dealii::ConditionalOStream &pcout) const +{ + // CIJ.fill(0.0); + dealii::Tensor<2, 2 * dim - 1 + dim / 3> CIJ; + + pcout << "Reading material model:"; + switch (dim) + { + case 1: + { + pcout << " 1D "; + // 1D models + switch (model) + { + case ISOTROPIC: + { + pcout << " ISOTROPIC \n"; + CIJ[0][0] = constants[0]; + break; + } + default: + { + std::cout << "\nelasticityModels: Supported models in 1D - " + "ISOTROPIC\n"; + std::cout << "See /src/elasticityModels.h\n"; + exit(-1); + } + } + break; + } + case 2: + { + pcout << " 2D "; + // 2D models + switch (model) + { + case ISOTROPIC: + { + pcout << " ISOTROPIC \n"; + const double E = constants[0]; + const double nu = constants[1]; + const double mu = E / (2 * (1 + nu)); + const double lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); + CIJ[0][0] = lambda + 2 * mu; + CIJ[1][1] = lambda + 2 * mu; + CIJ[2][2] = mu; + CIJ[0][1] = CIJ[1][0] = lambda; + break; + } + case ANISOTROPIC: + { + pcout << " ANISOTROPIC \n"; + CIJ[0][0] = constants[0]; // C11 + CIJ[1][1] = constants[1]; // C22 + CIJ[2][2] = constants[2]; // C33 + CIJ[0][1] = CIJ[1][0] = constants[3]; // C12 + CIJ[0][2] = CIJ[2][0] = constants[4]; // C13 + CIJ[1][2] = CIJ[2][1] = constants[5]; // C23 + break; + } + default: + { + std::cout << "\nelasticityModels: Supported models in 2D - " + "ISOTROPIC/ANISOTROPIC\n"; + std::cout << "See /src/elasticityModels.h\n"; + exit(-1); + } + } + break; + } + case 3: + { + pcout << " 3D "; + // 3D models + switch (model) + { + case ISOTROPIC: + { + pcout << " ISOTROPIC \n"; + const double E = constants[0]; + const double nu = constants[1]; + const double mu = E / (2 * (1 + nu)); + const double lambda = nu * E / ((1 + nu) * (1 - 2 * nu)); + CIJ[0][0] = lambda + 2 * mu; + CIJ[1][1] = lambda + 2 * mu; + CIJ[2][2] = lambda + 2 * mu; + CIJ[3][3] = mu; + CIJ[4][4] = mu; + CIJ[5][5] = mu; + CIJ[0][1] = CIJ[1][0] = lambda; + CIJ[0][2] = CIJ[2][0] = lambda; + CIJ[1][2] = CIJ[2][1] = lambda; + break; + } + case TRANSVERSE: + { + pcout << " TRANSVERSE \n"; + CIJ[0][0] = constants[0]; // C11 + CIJ[1][1] = constants[0]; // C11 + CIJ[2][2] = constants[1]; // C33 + CIJ[3][3] = constants[2]; // C44 + CIJ[4][4] = constants[2]; // C44 + CIJ[5][5] = (constants[0] - constants[3]) / 2.0; //(C11-C12)/2 + CIJ[0][1] = CIJ[1][0] = constants[3]; // C12 + CIJ[0][2] = CIJ[2][0] = constants[4]; // C13 + CIJ[1][2] = CIJ[2][1] = constants[4]; // C13 + break; + } + case ORTHOTROPIC: + { + pcout << " ORTHOTROPIC \n"; + CIJ[0][0] = constants[0]; // C11 + CIJ[1][1] = constants[1]; // C22 + CIJ[2][2] = constants[2]; // C33 + CIJ[3][3] = constants[3]; // C44 + CIJ[4][4] = constants[4]; // C55 + CIJ[5][5] = constants[5]; // C66 + CIJ[0][1] = CIJ[1][0] = constants[6]; // C12 + CIJ[0][2] = CIJ[2][0] = constants[7]; // C13 + CIJ[1][2] = CIJ[2][1] = constants[8]; // C23 + break; + } + case ANISOTROPIC: + { + pcout << " ANISOTROPIC \n"; + CIJ[0][0] = constants[0]; // C11 + CIJ[1][1] = constants[1]; // C22 + CIJ[2][2] = constants[2]; // C33 + CIJ[3][3] = constants[3]; // C44 + CIJ[4][4] = constants[4]; // C55 + CIJ[5][5] = constants[5]; // C66 + CIJ[0][1] = CIJ[1][0] = constants[6]; // C12 + CIJ[0][2] = CIJ[2][0] = constants[7]; // C13 + CIJ[0][3] = CIJ[3][0] = constants[8]; // C14 + CIJ[0][4] = CIJ[4][0] = constants[9]; // C15 + CIJ[0][5] = CIJ[5][0] = constants[10]; // C16 + CIJ[1][2] = CIJ[2][1] = constants[11]; // C23 + CIJ[1][3] = CIJ[3][1] = constants[12]; // C24 + CIJ[1][4] = CIJ[4][1] = constants[13]; // C25 + CIJ[1][5] = CIJ[5][1] = constants[14]; // C26 + CIJ[2][3] = CIJ[3][2] = constants[15]; // C34 + CIJ[2][4] = CIJ[4][2] = constants[16]; // C35 + CIJ[2][5] = CIJ[5][2] = constants[17]; // C36 + CIJ[3][4] = CIJ[4][3] = constants[18]; // C45 + CIJ[3][5] = CIJ[5][3] = constants[19]; // C46 + CIJ[4][5] = CIJ[5][4] = constants[20]; // C56 + break; + } + default: + { + std::cout << "\nelasticityModels: Supported models in 3D - " + "ISOTROPIC/TRANSVERSE/ORTHOTROPIC/ANISOTROPIC\n"; + std::cout << "See /src/elasticityModels.h\n"; + exit(-1); + } + } + break; + } + default: + { + std::cout << "\nelasticityModels: DIM is not 1/2/3\n"; + exit(-1); + } + } + // print CIJ to terminal + pcout << "Elasticity matrix (Voigt notation):\n"; + constexpr unsigned int voight_matrix_size = 2 * dim - 1 + dim / 3; + for (unsigned int i = 0; i < voight_matrix_size; i++) + { + for (unsigned int j = 0; j < voight_matrix_size; j++) + { + pcout << std::setw(8) << std::setprecision(3) << std::scientific << CIJ[i][j] + << " "; + } + pcout << "\n"; + } + pcout << "\n"; + return CIJ; +} + +template class userInputParameters<2>; +template class userInputParameters<3>; diff --git a/src/variableAttributeLoader/variableAttributeLoader.cc b/src/variableAttributeLoader/variableAttributeLoader.cc index a2942d8e6..739ca0572 100644 --- a/src/variableAttributeLoader/variableAttributeLoader.cc +++ b/src/variableAttributeLoader/variableAttributeLoader.cc @@ -3,6 +3,7 @@ #include #include +// NOLINTBEGIN(cppcoreguidelines-prefer-member-initializer) variableAttributeLoader::variableAttributeLoader() { relevant_attributes = &attributes; @@ -44,44 +45,47 @@ variableAttributeLoader::variableAttributeLoader() } } +// NOLINTEND(cppcoreguidelines-prefer-member-initializer) + // Methods to set the various variable attributes void variableAttributeLoader::set_variable_name(const unsigned int &index, - const std::string &name) + const std::string &name) const { (*relevant_attributes)[index].name = name; } void variableAttributeLoader::set_variable_type(const unsigned int &index, - const fieldType &var_type) + const fieldType &var_type) const { (*relevant_attributes)[index].var_type = var_type; } void variableAttributeLoader::set_variable_equation_type(const unsigned int &index, - const PDEType &var_eq_type) + const PDEType &var_eq_type) const { (*relevant_attributes)[index].eq_type = var_eq_type; } void variableAttributeLoader::set_need_value_nucleation(const unsigned int &index, - const bool &flag) + const bool &flag) const { (*relevant_attributes)[index].need_value_nucleation = flag; } void variableAttributeLoader::set_allowed_to_nucleate(const unsigned int &index, - const bool &flag) + const bool &flag) const { (*relevant_attributes)[index].nucleating_variable = flag; } void -variableAttributeLoader::set_output_integral(const unsigned int &index, const bool &flag) +variableAttributeLoader::set_output_integral(const unsigned int &index, + const bool &flag) const { (*relevant_attributes)[index].output_integral = flag; (*relevant_attributes)[index].calc_integral = flag; @@ -129,8 +133,9 @@ variableAttributeLoader::set_dependencies_gradient_term_RHS( } void -variableAttributeLoader::set_dependencies_value_term_LHS(const unsigned int &index, - const std::string &dependencies) +variableAttributeLoader::set_dependencies_value_term_LHS( + const unsigned int &index, + const std::string &dependencies) const { std::vector dependencies_set = dealii::Utilities::split_string_list(strip_whitespace(dependencies)); @@ -141,7 +146,7 @@ variableAttributeLoader::set_dependencies_value_term_LHS(const unsigned int &ind void variableAttributeLoader::set_dependencies_gradient_term_LHS( const unsigned int &index, - const std::string &dependencies) + const std::string &dependencies) const { std::vector dependencies_set = dealii::Utilities::split_string_list(strip_whitespace(dependencies)); @@ -149,6 +154,105 @@ variableAttributeLoader::set_dependencies_gradient_term_LHS( std::set(dependencies_set.begin(), dependencies_set.end()); } +void +variableAttributeLoader::validate_variable_name( + const std::string &name, + const std::set &forbidden_names, + const std::string &context, + unsigned int index) +{ + Assert(!name.empty(), + dealii::ExcMessage("PRISMS-PF Error: " + context + + " Variable names must not be empty.\nProblem index: " + + std::to_string(index))); + + for (const std::string &forbidden_name : forbidden_names) + { + std::string error_message = "PRISMS-PF Error: " + context + + " Variable names must not contain \"grad()\", " + "\"hess()\", \"change()\".\nProblem index: "; + error_message.append(std::to_string(index).append(", Variable name: " + name)); + + Assert(name.find(forbidden_name) == std::string::npos, + dealii::ExcMessage(error_message)); + } +} + +void +variableAttributeLoader::populate_dependencies( + const std::set> ®_delimiters, + const std::string &variable_name, + unsigned int index, + std::set ®_possible_deps, + std::map> &change_possible_deps) +{ + for (const auto &delims : reg_delimiters) + { + reg_possible_deps.insert(delims.first + variable_name + delims.second); + change_possible_deps[index].insert(delims.first + "change(" + variable_name + ")" + + delims.second); + } +} + +void +variableAttributeLoader::validate_dependencies( + const std::set &dependencies, + const std::string &context, + unsigned int index, + const std::string &variable_name, + const std::set ®_possible_deps, + const std::map> &change_possible_deps) +{ + for (const std::string &dependency : dependencies) + { + std::string error_message = + "PRISMS-PF Error: Invalid " + context + " dependency.\nProblem index: "; + error_message.append( + std::to_string(index).append(", Variable name: " + variable_name)); + error_message.append( + ", Invalid dependency name: " + dependency + + "\n(HINT: Dependencies that contain \"change(variable_A)\" can only be " + "used for the field \"variable_A\")\n"); + + Assert(reg_possible_deps.find(dependency) != reg_possible_deps.end() || + change_possible_deps.at(index).find(dependency) != + change_possible_deps.at(index).end(), + dealii::ExcMessage(error_message)); + } +} + +void +variableAttributeLoader::variableAttributeLoader::validate_postprocess_variable( + const std::string &name, + const std::set &name_list, + const std::set ®_possible_deps, + const variableAttributes &pp_variable, + unsigned int index) +{ + Assert(name_list.find(name) == name_list.end(), + dealii::ExcMessage("PRISMS-PF Error: Postprocess variable names must be " + "different from solution variable names.\nProblem index: " + + std::to_string(index) + ", Variable name: " + name + "\n")); + for (const auto &PP_dep : pp_variable.dependencies_PP) + { + std::string error_message = + "PRISMS-PF Error: Invalid postprocessing RHS dependency.\nProblem index: "; + error_message.append(std::to_string(index).append(", Variable name: " + name)); + error_message.append(", Invalid dependency name: " + PP_dep + "\n"); + + Assert(reg_possible_deps.find(PP_dep) != reg_possible_deps.end(), + dealii::ExcMessage(error_message)); + } + Assert(pp_variable.dependencies_LHS.empty(), + dealii::ExcMessage("PRISMS-PF Error: Postprocess variables can only have RHS " + "dependencies.\nProblem index: " + + std::to_string(index) + ", Variable name: " + name + "\n")); + Assert(!pp_variable.nucleating_variable && !pp_variable.need_value_nucleation, + dealii::ExcMessage("PRISMS-PF Error: Postprocess variables cannot be used for " + "nucleation.\nProblem index: " + + std::to_string(index) + ", Variable name: " + name + "\n")); +} + void variableAttributeLoader::validate_attributes() { @@ -161,108 +265,58 @@ variableAttributeLoader::validate_attributes() {"hess(", ")"} }; const std::set forbidden_names = {"grad(", "hess(", "change("}; - std::set name_list, pp_name_list, reg_possible_deps; + std::set name_list; + std::set pp_name_list; + std::set reg_possible_deps; std::map> change_possible_deps; - // Populate name_list, pp_name_list, reg_possible_deps, change_possible_deps - // Check that variable names are mostly well-formed + + // Populate the expected variable dependencies and check that variable names are mostly + // well-formed. for (const auto &[index, variable] : attributes) { name_list.insert(variable.name); - for (const auto &delims : reg_delimiters) - { - reg_possible_deps.insert(delims.first + variable.name + delims.second); - change_possible_deps[index].insert(delims.first + "change(" + variable.name + - ")" + delims.second); - } - Assert(!variable.name.empty(), - dealii::ExcMessage( - "PRISMS-PF Error: Variable names must not be empty.\nProblem index: " + - std::to_string(index) + "\n")); - for ([[maybe_unused]] const std::string &forbidden_name : forbidden_names) - { - Assert(variable.name.find(forbidden_name) == std::string::npos, - dealii::ExcMessage( - "PRISMS-PF Error: Variable names must not contain \"grad()\", " - "\"hess()\", \"change()\".\nProblem index: " + - std::to_string(index) + ", Variable name: " + variable.name + "\n")); - } + + populate_dependencies(reg_delimiters, + variable.name, + index, + reg_possible_deps, + change_possible_deps); + + validate_variable_name(variable.name, forbidden_names, "", index); } + + // Validate the postprocessed variables for (const auto &[pp_index, pp_variable] : pp_attributes) { pp_name_list.insert(pp_variable.name); - Assert(!pp_variable.name.empty(), - dealii::ExcMessage( - "PRISMS-PF Error: (postprocess) Variable names must not be " - "empty.\nProblem index: " + - std::to_string(pp_index) + "\n")); - for ([[maybe_unused]] const std::string &forbidden_name : forbidden_names) - { - Assert(pp_variable.name.find(forbidden_name) == std::string::npos, - dealii::ExcMessage("PRISMS-PF Error: (postprocess) Variable names must " - "not contain \"grad()\", " - "\"hess()\", \"change()\".\nProblem index: " + - std::to_string(pp_index) + - ", Variable name: " + pp_variable.name + "\n")); - } + + validate_variable_name(pp_variable.name, + forbidden_names, + "(postprocess)", + pp_index); + + validate_postprocess_variable(pp_variable.name, + name_list, + reg_possible_deps, + pp_variable, + pp_index); } - // Check Dependencies & PP + // Check dependencies for (const auto &[index, variable] : attributes) { - for ([[maybe_unused]] const std::string &RHS_dep : variable.dependencies_RHS) - { - Assert( - reg_possible_deps.find(RHS_dep) != reg_possible_deps.end() || - change_possible_deps.at(index).find(RHS_dep) != - change_possible_deps.at(index).end(), - dealii::ExcMessage( - "PRISMS-PF Error: Invalid RHS dependency.\nProblem index: " + - std::to_string(index) + ", Variable name: " + variable.name + - ", Invalid dependency name: " + RHS_dep + - "\n(HINT: Dependencies that contain \"change(variable_A)\" can only be " - "used for the " - "field \"variable_A\")\n")); - } - for ([[maybe_unused]] const std::string &LHS_dep : variable.dependencies_LHS) - { - Assert( - reg_possible_deps.find(LHS_dep) != reg_possible_deps.end() || - change_possible_deps.at(index).find(LHS_dep) != - change_possible_deps.at(index).end(), - dealii::ExcMessage( - "PRISMS-PF Error: Invalid LHS dependency.\nProblem index: " + - std::to_string(index) + ", Variable name: " + variable.name + - ", Invalid dependency name: " + LHS_dep + - "\n(HINT: Dependencies that contain \"change(variable_A)\" can only be " - "used for the " - "field \"variable_A\")\n")); - } - } - for (const auto &[pp_index, pp_variable] : pp_attributes) - { - Assert(name_list.find(pp_variable.name) == name_list.end(), - dealii::ExcMessage( - "PRISMS-PF Error: Postprocess variable names must be named differently " - "than solution variable names.\nProblem postprocessing index: " + - std::to_string(pp_index) + ", Variable name: " + pp_variable.name + "\n")); - for ([[maybe_unused]] const std::string &PP_dep : pp_variable.dependencies_PP) - { - Assert(reg_possible_deps.find(PP_dep) != reg_possible_deps.end(), - dealii::ExcMessage( - "PRISMS-PF Error: Invalid postprocessing RHS dependency.\nProblem " - "postprocessing index: " + - std::to_string(pp_index) + ", Variable name: " + pp_variable.name + - ", Invalid dependency name: " + PP_dep + "\n")); - } - Assert(pp_variable.dependencies_LHS.empty(), - dealii::ExcMessage( - "PRISMS-PF Error: Warning: Postprocess variables can only have RHS " - "dependencies.\nProblem postprocessing index: " + - std::to_string(pp_index) + ", Variable name: " + pp_variable.name + "\n")); - Assert(!pp_variable.nucleating_variable && !pp_variable.need_value_nucleation, - dealii::ExcMessage( - "PRISMS-PF Error: Warning: Postprocess variables cannot " - "be used for nucleation.\nProblem postprocessing index: " + - std::to_string(pp_index) + ", Variable name: " + pp_variable.name + "\n")); + validate_dependencies(variable.dependencies_RHS, + "RHS", + index, + variable.name, + reg_possible_deps, + change_possible_deps); + + validate_dependencies(variable.dependencies_LHS, + "LHS", + index, + variable.name, + reg_possible_deps, + change_possible_deps); } } diff --git a/tests/unit_tests/unitTest.h b/tests/unit_tests/unitTest.h index 22963c43a..6fba21c48 100644 --- a/tests/unit_tests/unitTest.h +++ b/tests/unit_tests/unitTest.h @@ -59,10 +59,6 @@ computeStress(const dealii::Table<2, double> &CIJ, #include "../../src/matrixfree/utilities.cc" #include "../../src/models/mechanics/computeStress.h" #include "../../src/parallelNucleationList/parallelNucleationList.cc" -#include "../../src/userInputParameters/loadVariableAttributes.cc" -#include "../../src/userInputParameters/load_BC_list.cc" -#include "../../src/userInputParameters/load_user_constants.cc" -#include "../../src/userInputParameters/setTimeStepList.cc" #include "../../src/variableAttributeLoader/variableAttributeLoader.cc" #include "../../src/variableContainer/variableContainer.cc" From eb44fb291a3a890151e74a9cdedb88cccfa2dd65 Mon Sep 17 00:00:00 2001 From: Jason Landini Date: Mon, 25 Nov 2024 18:39:09 -0500 Subject: [PATCH 28/28] update workflow --- .github/workflows/clangtidy.yml | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/.github/workflows/clangtidy.yml b/.github/workflows/clangtidy.yml index 014a7adf5..d0373d4b3 100644 --- a/.github/workflows/clangtidy.yml +++ b/.github/workflows/clangtidy.yml @@ -3,16 +3,17 @@ name: Clang-tidy on: push: branches: - -master + - master pull_request: branches: - - master - - development + - master types: - - opened - - reopened - - synchronize - - ready_for_review + - opened + - reopened + - synchronize + - ready_for_review + paths-ignore: + - 'applications/**' concurrency: group: ${{ github.event_name }}-${{ github.workflow }}-${{ github.ref }}