/*---------------------------------------------------------------------------*\ ========= | \\ / F ield | OpenFOAM: The Open Source CFD Toolbox \\ / O peration | \\ / A nd | www.openfoam.com \\/ M anipulation | ------------------------------------------------------------------------------- Copyright (C) 2011-2016 OpenFOAM Foundation Copyright (C) 2017-2023 OpenCFD Ltd. ------------------------------------------------------------------------------- License This file is part of OpenFOAM. OpenFOAM is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. OpenFOAM is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenFOAM. If not, see . \*---------------------------------------------------------------------------*/ #include "pointZone.H" #include "addToRunTimeSelectionTable.H" #include "pointZoneMesh.H" #include "polyMesh.H" #include "primitiveMesh.H" #include "syncTools.H" // * * * * * * * * * * * * * * Static Data Members * * * * * * * * * * * * * // namespace Foam { defineTypeNameAndDebug(pointZone, 0); defineRunTimeSelectionTable(pointZone, dictionary); addToRunTimeSelectionTable(pointZone, pointZone, dictionary); } const char* const Foam::pointZone::labelsName = "pointLabels"; // * * * * * * * * * * * * * * * * Constructors * * * * * * * * * * * * * * // Foam::pointZone::pointZone(const pointZoneMesh& zm) : pointZone(word::null, 0, zm) {} Foam::pointZone::pointZone ( const word& name, const label index, const pointZoneMesh& zm ) : zone(name, index), zoneMesh_(zm) {} Foam::pointZone::pointZone ( const word& name, const labelUList& addr, const label index, const pointZoneMesh& zm ) : zone(name, addr, index), zoneMesh_(zm) {} Foam::pointZone::pointZone ( const word& name, labelList&& addr, const label index, const pointZoneMesh& zm ) : zone(name, std::move(addr), index), zoneMesh_(zm) {} Foam::pointZone::pointZone ( const word& name, const dictionary& dict, const label index, const pointZoneMesh& zm ) : zone(name, dict, this->labelsName, index), zoneMesh_(zm) {} Foam::pointZone::pointZone ( const pointZone& originalZone, const Foam::zero, const pointZoneMesh& zm, const label newIndex ) : zone(originalZone, labelList(), newIndex), zoneMesh_(zm) {} Foam::pointZone::pointZone ( const pointZone& originalZone, const Foam::zero, const label index, const pointZoneMesh& zm ) : zone(originalZone, labelList(), index), zoneMesh_(zm) {} Foam::pointZone::pointZone ( const pointZone& originalZone, const labelUList& addr, const label index, const pointZoneMesh& zm ) : pointZone(originalZone, Foam::zero{}, index, zm) { labelList::operator=(addr); } Foam::pointZone::pointZone ( const pointZone& originalZone, labelList&& addr, const label index, const pointZoneMesh& zm ) : pointZone(originalZone, Foam::zero{}, index, zm) { labelList::transfer(addr); } // * * * * * * * * * * * * * * * Member Functions * * * * * * * * * * * * * // Foam::label Foam::pointZone::whichPoint(const label globalPointID) const { return zone::localID(globalPointID); } bool Foam::pointZone::checkDefinition(const bool report) const { return zone::checkDefinition(zoneMesh_.mesh().points().size(), report); } bool Foam::pointZone::checkParallelSync(const bool report) const { const polyMesh& mesh = zoneMesh().mesh(); labelList maxZone(mesh.nPoints(), label(-1)); labelList minZone(mesh.nPoints(), labelMax); const labelList& addr = *this; for (const label pointi : addr) { maxZone[pointi] = index(); minZone[pointi] = index(); } syncTools::syncPointList(mesh, maxZone, maxEqOp