1 label cohesivePatchID = -1;
3 solidCohesiveFvPatchVectorField* cohesivePatchUPtr = NULL;
4 solidCohesiveFixedModeMixFvPatchVectorField* cohesivePatchUFixedModePtr = NULL;
6 forAll (U.boundaryField(), patchI)
8 if (isA<solidCohesiveFvPatchVectorField>(U.boundaryField()[patchI]))
10 cohesivePatchID = patchI;
12 &refCast<solidCohesiveFvPatchVectorField>
14 U.boundaryField()[cohesivePatchID]
18 else if (isA<solidCohesiveFixedModeMixFvPatchVectorField>(U.boundaryField()[patchI]))
20 cohesivePatchID = patchI;
21 cohesivePatchUFixedModePtr =
22 &refCast<solidCohesiveFixedModeMixFvPatchVectorField>
24 U.boundaryField()[cohesivePatchID]
30 if(cohesivePatchID == -1)
32 FatalErrorIn(args.executable())
33 << "Can't find cohesiveLawFvPatch" << nl
34 << "One of the boundary patches in " << U.name() << ".boundaryField() "
35 << "should be of type " << solidCohesiveFvPatchVectorField::typeName
36 << "or " << solidCohesiveFixedModeMixFvPatchVectorField::typeName
40 // solidCohesiveFvPatchVectorField& cohesivePatchU =
41 // refCast<solidCohesiveFvPatchVectorField>
43 // U.boundaryField()[cohesivePatchID]
46 // philipc: I have moved cohesive stuff to constitutiveModel
47 // cohesiveZone is an index field
48 // which allows the user to limit the crack to certain areas at runtime
49 // 1 for faces within cohesiveZone
50 // 0 for faces outside cohesiveZone
51 surfaceScalarField cohesiveZone
58 IOobject::READ_IF_PRESENT,
62 dimensionedScalar("zero", dimless, 0.0)
65 // limit crack to specified boxes
67 const dictionary& stressControl =
68 mesh.solutionDict().subDict("solidMechanics");
70 List<boundBox> userBoxes(stressControl.lookup("crackLimitingBoxes"));
71 const surfaceVectorField& Cf = mesh.Cf();
72 forAll(cohesiveZone.internalField(), faceI)
74 bool faceInsideBox = false;
76 forAll(userBoxes, boxi)
78 if(userBoxes[boxi].contains(Cf.internalField()[faceI])) faceInsideBox = true;
83 cohesiveZone.internalField()[faceI] = 1.0;
87 forAll(cohesiveZone.boundaryField(), patchI)
89 // cracks may go along proc boundaries
90 if(mesh.boundaryMesh()[patchI].type() == processorPolyPatch::typeName)
92 forAll(cohesiveZone.boundaryField()[patchI], faceI)
94 bool faceInsideBox = false;
96 forAll(userBoxes, boxi)
98 if(userBoxes[boxi].contains(Cf.boundaryField()[patchI][faceI])) faceInsideBox = true;
103 cohesiveZone.boundaryField()[patchI][faceI] = 1.0;
109 Info << "\nThere are " << gSum(cohesiveZone.internalField()) << " potential internal crack faces" << nl << endl;
110 Info << "\nThere are " << gSum(cohesiveZone.boundaryField())/2 << " potential coupled boundary crack faces" << nl << endl;
112 // write field for visualisation
113 volScalarField cohesiveZoneVol
124 dimensionedScalar("zero", dimless, 0.0)
127 forAll(cohesiveZone.internalField(), facei)
129 if(cohesiveZone.internalField()[facei])
131 cohesiveZoneVol.internalField()[mesh.owner()[facei]] = 1.0;
132 cohesiveZoneVol.internalField()[mesh.neighbour()[facei]] = 1.0;
136 forAll(cohesiveZone.boundaryField(), patchi)
138 forAll(cohesiveZone.boundaryField()[patchi], facei)
140 if(cohesiveZone.boundaryField()[patchi][facei] > 0.0)
142 cohesiveZoneVol.boundaryField()[patchi][facei] = 1.0;
146 Info << "Writing cohesiveZone field" << endl;
147 cohesiveZoneVol.write();
151 Switch initialiseSolution(false);
155 mesh.solutionDict().subDict("solidMechanics")
156 .found("initialiseSolution")
162 mesh.solutionDict().subDict("solidMechanics").lookup
170 Switch breakOnlyOneFacePerTopologyChange(true);
174 mesh.solutionDict().subDict("solidMechanics")
175 .found("breakOnlyOneFacePerTopologyChange")
178 breakOnlyOneFacePerTopologyChange =
181 mesh.solutionDict().subDict("solidMechanics").lookup
183 "breakOnlyOneFacePerTopologyChange"
189 Switch crackPropagationFromSpecifiedPatches
191 mesh.solutionDict().subDict("solidMechanics").lookup
193 "crackPropagationFromSpecifiedPatches"
197 wordList crackPropagationPatchNames
199 mesh.solutionDict().subDict("solidMechanics").lookup
201 "crackPropagationPatches"
205 labelList crackPropagationPatches(crackPropagationPatchNames.size(), -1);
207 forAll(crackPropagationPatchNames, patchI)
209 crackPropagationPatches[patchI] =
210 mesh.boundaryMesh().findPatchID
212 crackPropagationPatchNames[patchI]
215 if(crackPropagationPatches[patchI] == -1)
217 FatalErrorIn(args.executable())
218 << "Can't find " << crackPropagationPatchNames[patchI]
219 << " patch" << abort(FatalError);
223 // Internal faces next to selected crack propagation patches
224 labelList crackPropagationPatchesInternalFaces;
226 # include "updateCrackPropagationPatchesInternalFaces.H"