Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026 #include "boxToCell.H"
00027 #include <OpenFOAM/polyMesh.H>
00028
00029 #include <OpenFOAM/addToRunTimeSelectionTable.H>
00030
00031
00032
00033 namespace Foam
00034 {
00035
00036 defineTypeNameAndDebug(boxToCell, 0);
00037
00038 addToRunTimeSelectionTable(topoSetSource, boxToCell, word);
00039
00040 addToRunTimeSelectionTable(topoSetSource, boxToCell, istream);
00041
00042 }
00043
00044
00045 Foam::topoSetSource::addToUsageTable Foam::boxToCell::usage_
00046 (
00047 boxToCell::typeName,
00048 "\n Usage: boxToCell (minx miny minz) (maxx maxy maxz)\n\n"
00049 " Select all cells with cellCentre within bounding box\n\n"
00050 );
00051
00052
00053
00054
00055 void Foam::boxToCell::combine(topoSet& set, const bool add) const
00056 {
00057 const pointField& ctrs = mesh_.cellCentres();
00058
00059 forAll(ctrs, cellI)
00060 {
00061 if (bb_.contains(ctrs[cellI]))
00062 {
00063 addOrDelete(set, cellI, add);
00064 }
00065 }
00066 }
00067
00068
00069
00070
00071
00072 Foam::boxToCell::boxToCell
00073 (
00074 const polyMesh& mesh,
00075 const treeBoundBox& bb
00076 )
00077 :
00078 topoSetSource(mesh),
00079 bb_(bb)
00080 {}
00081
00082
00083
00084 Foam::boxToCell::boxToCell
00085 (
00086 const polyMesh& mesh,
00087 const dictionary& dict
00088 )
00089 :
00090 topoSetSource(mesh),
00091 bb_(dict.lookup("box"))
00092 {}
00093
00094
00095
00096 Foam::boxToCell::boxToCell
00097 (
00098 const polyMesh& mesh,
00099 Istream& is
00100 )
00101 :
00102 topoSetSource(mesh),
00103 bb_(checkIs(is))
00104 {}
00105
00106
00107
00108 Foam::boxToCell::~boxToCell()
00109 {}
00110
00111
00112
00113
00114 void Foam::boxToCell::applyToSet
00115 (
00116 const topoSetSource::setAction action,
00117 topoSet& set
00118 ) const
00119 {
00120 if ((action == topoSetSource::NEW) || (action == topoSetSource::ADD))
00121 {
00122 Info<< " Adding cells with center within box " << bb_ << endl;
00123
00124 combine(set, true);
00125 }
00126 else if (action == topoSetSource::DELETE)
00127 {
00128 Info<< " Removing cells with center within box " << bb_ << endl;
00129
00130 combine(set, false);
00131 }
00132 }
00133
00134
00135