From 0a53013499eb4bc752b76da23b5ebc11afb243f7 Mon Sep 17 00:00:00 2001 From: Mark Olesen Date: Wed, 12 Mar 2025 18:17:32 +0100 Subject: [PATCH] BUG: foamReport mesh quantities are not parallel (fixes #3338) --- .../utilities/foamReport/foamReport.C | 46 +++++++++++++------ 1 file changed, 33 insertions(+), 13 deletions(-) diff --git a/src/functionObjects/utilities/foamReport/foamReport.C b/src/functionObjects/utilities/foamReport/foamReport.C index 349fbf777b..e033d065f1 100644 --- a/src/functionObjects/utilities/foamReport/foamReport.C +++ b/src/functionObjects/utilities/foamReport/foamReport.C @@ -5,7 +5,7 @@ \\ / A nd | www.openfoam.com \\/ M anipulation | ------------------------------------------------------------------------------- - Copyright (C) 2024 OpenCFD Ltd. + Copyright (C) 2024-2025 OpenCFD Ltd. ------------------------------------------------------------------------------- License This file is part of OpenFOAM. @@ -32,6 +32,7 @@ License #include "cloud.H" #include "foamVersion.H" #include "fvMesh.H" +#include "globalMeshData.H" #include "IFstream.H" #include "stringOps.H" #include "substitutionModel.H" @@ -56,7 +57,7 @@ void Foam::functionObjects::foamReport::setStaticBuiltins() substitutionModel::addBuiltinStr ( "OF_PROC_ZERO_DIR", - Pstream::parRun() ? "processor0" : "" + UPstream::parRun() ? "processor0" : "" ); substitutionModel::addBuiltin("OF_API", foamVersion::api); @@ -72,26 +73,45 @@ void Foam::functionObjects::foamReport::setStaticBuiltins() substitutionModel::addBuiltinStr("OF_CASE_PATH", argList::envGlobalPath()); substitutionModel::addBuiltinStr("OF_CASE_NAME", time().globalCaseName()); - substitutionModel::addBuiltin("OF_NPROCS", Pstream::nProcs()); + substitutionModel::addBuiltin("OF_NPROCS", UPstream::nProcs()); // Set mesh builtins when there is only 1 mesh - const auto meshes = time_.lookupClass(); + const auto meshes = time_.csorted(); + if (meshes.size() == 1) { - const auto& mesh = *(meshes.begin().val()); - substitutionModel::addBuiltin("OF_MESH_NCELLS", mesh.nCells()); - substitutionModel::addBuiltin("OF_MESH_NFACES", mesh.nFaces()); - substitutionModel::addBuiltin("OF_MESH_NEDGES", mesh.nEdges()); - substitutionModel::addBuiltin("OF_MESH_NPOINTS", mesh.nPoints()); + const auto& mesh = meshes[0]; + + substitutionModel::addBuiltin + ( + "OF_MESH_NCELLS", + mesh.globalData().nTotalCells() + ); + substitutionModel::addBuiltin + ( + "OF_MESH_NFACES", + mesh.globalData().nTotalFaces() + ); + substitutionModel::addBuiltin + ( + "OF_MESH_NEDGES", + returnReduce(mesh.nEdges(), sumOp