<!doctype HTML public "-//W3C//DTD HTML 4.0 Frameset//EN">

<html>

<head>
<title>Transforming Meshes</title>
<meta http-equiv="content-type" content="text/html; charset=windows-1252">
<meta name="generator" content="RoboHelp by eHelp Corporation www.ehelp.com"><style type="text/css">
<!--
h3.whs1 { margin-top:0pt; margin-bottom:0pt; }
h4.whs2 { margin-top:0pt; margin-bottom:0pt; }
p.whs3 { font-family:'Lucida Console' , monospace; margin-top:0pt; margin-bottom:0pt; }
p.whs4 { margin-top:0pt; margin-bottom:0pt; font-family:'Lucida Console' , monospace; }
p.whs5 { margin-top:0pt; margin-bottom:0pt; font-family:'Times New Roman' , serif; }
p.whs6 { margin-top:0pt; margin-bottom:0pt; }
-->
</style><script type="text/javascript" language="JavaScript">
<!--
if ((navigator.appName == "Netscape") && (parseInt(navigator.appVersion) == 4))
{
  var strNSS = "<style type='text/css'>";
  strNSS += "h3.whs1 {margin-top:1pt;margin-bottom:1pt; }";
  strNSS += "h4.whs2 {margin-top:1pt;margin-bottom:1pt; }";
  strNSS += "p.whs3 {margin-top:1pt;margin-bottom:1pt; }";
  strNSS += "p.whs4 {margin-top:1pt;margin-bottom:1pt; }";
  strNSS += "p.whs5 {margin-top:1pt;margin-bottom:1pt; }";
  strNSS += "p.whs6 {margin-top:1pt;margin-bottom:1pt; }";
  strNSS +="</style>";
  document.write(strNSS);
}
//-->
</script>
<script type="text/javascript" language="JavaScript" title="WebHelpInlineScript">
<!--
function reDo() {
  if (innerWidth != origWidth || innerHeight != origHeight)
     location.reload();
}
if ((parseInt(navigator.appVersion) == 4) && (navigator.appName == "Netscape")) {
	origWidth = innerWidth;
	origHeight = innerHeight;
	onresize = reDo;
}
onerror = null; 
//-->
</script>
<style type="text/css">
<!--
div.WebHelpPopupMenu { position:absolute; left:0px; top:0px; z-index:4; visibility:hidden; }
p.WebHelpNavBar { text-align:right; }
-->
</style><script type="text/javascript" language="javascript1.2" src="whmsg.js"></script>
<script type="text/javascript" language="javascript" src="whver.js"></script>
<script type="text/javascript" language="javascript1.2" src="whproxy.js"></script>
<script type="text/javascript" language="javascript1.2" src="whutils.js"></script>
<script type="text/javascript" language="javascript1.2" src="whtopic.js"></script>
<script type="text/javascript" language="javascript1.2">
<!--
if (window.gbWhTopic)
{
	if (window.setRelStartPage)
	{
	addTocInfo("MESH module\nTUI Scripts\nTransforming Meshes");
addButton("show",BTN_IMG,"Show","","","","",0,0,"whd_show0.gif","whd_show2.gif","whd_show1.gif");
addButton("hide",BTN_IMG,"Hide","","","","",0,0,"whd_hide0.gif","whd_hide2.gif","whd_hide1.gif");

	}


	if (window.setRelStartPage)
	{
	setRelStartPage("index.htm");

		autoSync(1);
		sendSyncInfo();
		sendAveInfoOut();
	}

}
else
	if (window.gbIE4)
		document.location.reload();
//-->
</script>
</head>
<body><script type="text/javascript" language="javascript1.2">
<!--
if (window.writeIntopicBar)
	writeIntopicBar(4);
//-->
</script>
<h1>Transforming Meshes</h1>

<h3 class="whs1">Transforming Meshes</h3>

<h4 class="whs2">&nbsp;</h4>

<h4 class="whs2"><a name=bookmark>Translation</a></h4>

<p class="whs3">&nbsp;</p>

<p class="whs4">import SMESH_mechanic</p>

<p class="whs4">&nbsp;</p>

<p class="whs4"><span style="font-family: 'Lucida Console', monospace;">smesh 
 = SMESH_mechanic.smesh </span></p>

<p class="whs4">mesh = SMESH_mechanic.mesh 
 </p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># define translation 
 vector</p>

<p class="whs4"><span style="font-family: 'Lucida Console', monospace;">point 
 = smesh.PointStruct(-150., -150., 0.)</span></p>

<p class="whs4">vector =smesh.DirStruct(point) 
 </p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># translate a mesh</p>

<p class="whs4">doCopy = 1</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">mesh.Translate([], 
 vector, doCopy) &nbsp;</p>

<p class="whs6">&nbsp;</p>

<h4 class="whs2"><a name=bookmark1>Rotation</a></h4>

<p class="whs3">&nbsp;</p>

<p class="whs3">import math</p>

<p class="whs3">import SMESH_mechanic</p>

<p class="whs3">&nbsp;</p>

<p class="whs3"><span style="font-family: 'Lucida Console', monospace;">smesh 
 = SMESH_mechanic.smesh</span></p>

<p class="whs3">mesh = SMESH_mechanic.mesh </p>

<p class="whs3">&nbsp;</p>

<p class="whs5"># define rotation axis 
 and angle</p>

<p class="whs3">axisXYZ = smesh.AxisStruct(0., 0., 0., 
 5., 5., 20.)</p>

<p class="whs3">angle270 = 1.5 * math.pi</p>

<p class="whs3">&nbsp;</p>

<p class="whs5"># rotate a mesh</p>

<p class="whs4">mesh.Rotate([], 
 axisXYZ, angle270, 1) &nbsp;</p>

<p class="whs6">&nbsp;</p>

<h4 class="whs2"><a name=bookmark2>Symmetry</a></h4>

<p class="whs3">&nbsp;</p>

<p class="whs3">import math</p>

<p class="whs3">&nbsp;</p>

<p class="whs3">import SMESH_mechanic</p>

<p class="whs3">&nbsp;</p>

<p class="whs3"><span style="font-family: 'Lucida Console', monospace;">smesh 
 = SMESH_mechanic.smesh</span></p>

<p class="whs3">mesh = SMESH_mechanic.mesh </p>

<p class="whs3">&nbsp;</p>

<p class="whs5"># create a symmetrical 
 copy of the mesh mirrored through a point</p>

<p class="whs3">axis = SMESH.AxisStruct(0, 0, 0, 0, 0, 
 0)</p>

<p class="whs3">&nbsp;</p>

<p class="whs3">mesh.Mirror([], axis, smesh.POINT, 1) 
 </p>

<p class="whs6">&nbsp;</p>

<h4 class="whs2"><a name=bookmark3>Merging 
 Nodes</a></h4>

<p class="whs3">&nbsp;</p>

<p class="whs4">import SMESH_mechanic</p>

<p class="whs4">mesh = SMESH_mechanic.mesh</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># merge nodes</p>

<p class="whs4">Tolerance = 25.0</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">GroupsOfNodes = 
 &nbsp;mesh.FindCoincidentNodes(Tolerance)</p>

<p class="whs4">mesh.MergeNodes(GroupsOfNodes) 
 &nbsp;</p>

<p class="whs6">&nbsp;</p>

<h4><a name=bookmark8>Merging Elements</a></h4>

<p class="whs4">import salome</p>

<p class="whs4">import geompy</p>

<p class="whs4">import smesh</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create a face to 
 be meshed</p>

<p class="whs4">px = geompy.MakeVertex(100., 
 0. &nbsp;, 0. 
 &nbsp;)</p>

<p class="whs4">py = geompy.MakeVertex(0. 
 &nbsp;, 100., 
 0. &nbsp;)</p>

<p class="whs4">pz = geompy.MakeVertex(0. 
 &nbsp;, 0. &nbsp;, 
 100.)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">vxy = geompy.MakeVector(px, 
 py)</p>

<p class="whs4">arc = geompy.MakeArc(py, 
 pz, px)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">wire = geompy.MakeWire([vxy, 
 arc])</p>

<p class="whs4">isPlanarFace = 1</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">face1 = geompy.MakeFace(wire, 
 isPlanarFace)</p>

<p class="whs4">id_face1 = geompy.addToStudy(face1, 
 &quot;Face1&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create a circle to 
 be an extrusion path</p>

<p class="whs4">px1 = geompy.MakeVertex( 
 100., &nbsp;100., 
 &nbsp;0.)</p>

<p class="whs4">py1 = geompy.MakeVertex(-100., 
 -100., &nbsp;0.)</p>

<p class="whs4">pz1 = geompy.MakeVertex( 
 &nbsp;&nbsp;0., 
 &nbsp;&nbsp;&nbsp;0., 
 50.)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">circle = geompy.MakeCircleThreePnt(py1, 
 pz1, px1)</p>

<p class="whs4">id_circle = geompy.addToStudy(circle, 
 &quot;Path&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create a 2D mesh 
 on the face</p>

<p class="whs4">trias = smesh.Mesh(face1, 
 &quot;Face : 2D mesh&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo1D = trias.Segment()</p>

<p class="whs4">algo1D.NumberOfSegments(6)</p>

<p class="whs4">algo2D = trias.Triangle()</p>

<p class="whs4">algo2D.LengthFromEdges()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">trias.Compute()</p>

<p class="whs5">&nbsp;</p>

<p class="whs5"># create a path mesh</p>

<p class="whs4">circlemesh = smesh.Mesh(circle, 
 &quot;Path mesh&quot;)</p>

<p class="whs4">algo = circlemesh.Segment()</p>

<p class="whs4">algo.NumberOfSegments(10)</p>

<p class="whs4">circlemesh.Compute()</p>

<p class="whs5">&nbsp;</p>

<p class="whs5"># extrusion of the 
 mesh</p>

<p class="whs4"><span style="font-family: 'Lucida Console', monospace;">trias.ExtrusionAlongPath([], 
 circlemesh, circle,</span></p>

<p class="whs4">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;1, 
 0, [], 0, smesh.PointStruct(0, 0, 0))</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># merge nodes</p>

<p class="whs4">print &quot;Number 
 of nodes before MergeNodes:&quot;, </p>

<p class="whs4">trias.NbNodes()</p>

<p class="whs4">tolerance = 0.001</p>

<p class="whs4">array_of_nodes_groups 
 = trias.FindCoincidentNodes(tolerance)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">trias.MergeNodes(array_of_nodes_groups)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">print &quot;Number 
 of nodes after MergeNodes:&quot;, trias.NbNodes()</p>

<p class="whs4">print &quot;&quot;</p>

<p class="whs4">print &quot;Number 
 of elements before MergeEqualElements:&quot;</p>

<p class="whs4">print &quot;Edges 
 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;: 
 &quot;, trias.NbEdges()</p>

<p class="whs4">print &quot;Triangles 
 &nbsp;: &quot;, 
 trias.NbTriangles()</p>

<p class="whs4">print &quot;Quadrangles: 
 &quot;, trias.NbQuadrangles()</p>

<p class="whs4">print &quot;Volumes 
 &nbsp;&nbsp;&nbsp;: 
 &quot;, trias.NbVolumes()</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># merge elements</p>

<p class="whs4">trias.MergeEqualElements()</p>

<p class="whs4">print &quot;Number 
 of elements after MergeEqualElements:&quot;</p>

<p class="whs4">print &quot;Edges 
 &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;: 
 &quot;, trias.NbEdges()</p>

<p class="whs4">print &quot;Triangles 
 &nbsp;: &quot;, 
 trias.NbTriangles()</p>

<p class="whs4">print &quot;Quadrangles: 
 &quot;, trias.NbQuadrangles()</p>

<p class="whs4">print &quot;Volumes 
 &nbsp;&nbsp;&nbsp;: 
 &quot;, trias.NbVolumes()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">salome.sg.updateObjBrowser(1) 
 </p>

<p class="whs4">&nbsp;</p>

<h3>Sewing Meshes</h3>

<h4><a name=bookmark4>Sew Meshes Border to Border</a></h4>

<p class="whs4">import geompy</p>

<p class="whs4">import smesh</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create two faces 
 of a box</p>

<p class="whs4">box1 = geompy.MakeBox(0., 
 0., -10., 30., 20., 25.)</p>

<p class="whs4">facesList1 = geompy.SubShapeAll(box1, 
 geompy.ShapeType[&quot;FACE&quot;])</p>

<p class="whs4">face1 = facesList1[2]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">box2 = geompy.MakeBox(0., 
 5., 0., 20., 20., 15.)</p>

<p class="whs4">facesList2 = geompy.SubShapeAll(box2, 
 geompy.ShapeType[&quot;FACE&quot;])</p>

<p class="whs4">face2 = facesList2[1]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">edgesList = geompy.SubShapeAll(face2, 
 geompy.ShapeType[&quot;EDGE&quot;])</p>

<p class="whs4">edge1 = edgesList[2]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">aComp = geompy.MakeCompound([face1, 
 face2])</p>

<p class="whs4">geompy.addToStudy(aComp, 
 &quot;Two faces&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create a mesh on 
 two faces</p>

<p class="whs4">mesh = smesh.Mesh(aComp, 
 &quot;Two faces : quadrangle mesh&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo1D = mesh.Segment()</p>

<p class="whs4">algo1D.NumberOfSegments(9)</p>

<p class="whs4">algo2D = mesh.Quadrangle()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo_local = mesh.Segment(edge1)</p>

<p class="whs4">algo_local.Arithmetic1D(1, 
 4)</p>

<p class="whs4">algo_local.Propagation()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">mesh.Compute()</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># sew border to side</p>

<p class="whs5"># FirstNodeIDOnFreeBorder, 
 SecondNodeIDOnFreeBorder, LastNodeIDOnFreeBorder,</p>

<p class="whs5"># FirstNodeIDOnSide, 
 LastNodeIDOnSide,</p>

<p class="whs5"># CreatePolygons, CreatePolyedrs</p>

<p class="whs4">mesh.SewBorderToSide(5, 
 45, 6, 113, 109, 0, 0) </p>

<h4><a name=bookmark5>Sew Conform Free Borders</a></h4>

<p class="whs4">import geompy</p>

<p class="whs4">import smesh</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create two faces 
 of the box</p>

<p class="whs4">box1 = geompy.MakeBox(0., 
 0., -10., 20., 20., 15.)</p>

<p class="whs4">facesList1 = geompy.SubShapeAll(box1, 
 geompy.ShapeType[&quot;FACE&quot;])</p>

<p class="whs4">face1 = facesList1[2]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">box2 = geompy.MakeBox(0., 
 5., 0., 20., 20., 15.)</p>

<p class="whs4">facesList2 = geompy.SubShapeAll(box2, 
 geompy.ShapeType[&quot;FACE&quot;])</p>

<p class="whs4">face2 = facesList2[1]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">edgesList = geompy.SubShapeAll(face2, 
 geompy.ShapeType[&quot;EDGE&quot;])</p>

<p class="whs4">edge1 = edgesList[2]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">aComp = geompy.MakeCompound([face1, 
 face2])</p>

<p class="whs4">geompy.addToStudy(aComp, 
 &quot;Two faces&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create a mesh on 
 two faces</p>

<p class="whs4">mesh = smesh.Mesh(aComp, 
 &quot;Two faces : quadrangle mesh&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo1D = mesh.Segment()</p>

<p class="whs4">algo1D.NumberOfSegments(9)</p>

<p class="whs4">algo2D = mesh.Quadrangle()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo_local = mesh.Segment(edge1)</p>

<p class="whs4">algo_local.Arithmetic1D(1, 
 4)</p>

<p class="whs4">algo_local.Propagation()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">mesh.Compute()</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># sew conform free 
 borders</p>

<p class="whs5"># FirstNodeID1, SecondNodeID1, 
 LastNodeID1, FirstNodeID2, SecondNodeID2</p>

<p class="whs4">mesh.SewConformFreeBorders(5, 
 45, 6, 3, 24) &nbsp;</p>

<h4><a name=bookmark6>Sew Free Borders</a></h4>

<p class="whs4">import geompy</p>

<p class="whs4">import smesh</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create two faces 
 of the box</p>

<p class="whs4">box1 = geompy.MakeBox(0., 
 0., 0., 20., 20., 15.)</p>

<p class="whs4">facesList1 = geompy.SubShapeAll(box1, 
 geompy.ShapeType[&quot;FACE&quot;])</p>

<p class="whs4">face1 = facesList1[2]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">box2 = geompy.MakeBox(0., 
 5., 0., 20., 20., 15.)</p>

<p class="whs4">facesList2 = geompy.SubShapeAll(box2, 
 geompy.ShapeType[&quot;FACE&quot;])</p>

<p class="whs4">face2 = facesList2[1]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">edgesList = geompy.SubShapeAll(face2, 
 geompy.ShapeType[&quot;EDGE&quot;])</p>

<p class="whs4">edge1 = edgesList[2]</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">aComp = geompy.MakeCompound([face1, 
 face2])</p>

<p class="whs4">geompy.addToStudy(aComp, 
 &quot;Two faces&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create a mesh on 
 two faces</p>

<p class="whs4">mesh = smesh.Mesh(aComp, 
 &quot;Two faces : quadrangle mesh&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo1D = mesh.Segment()</p>

<p class="whs4">algo1D.NumberOfSegments(4)</p>

<p class="whs4">algo2D = mesh.Quadrangle()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo_local = mesh.Segment(edge1)</p>

<p class="whs4">algo_local.Arithmetic1D(1, 
 4)</p>

<p class="whs4">algo_local.Propagation()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">mesh.Compute()</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># sew free borders</p>

<p class="whs5"># FirstNodeID1, SecondNodeID1, 
 LastNodeID1,</p>

<p class="whs5"># FirstNodeID2, SecondNodeID2, 
 LastNodeID2, CreatePolygons, CreatePolyedrs</p>

<p class="whs6">mesh.SewFreeBorders(6, 
 21, 5, 1, 12, 3, 0, 0) </p>

<h4><a name=bookmark7>Sew Side Elements</a></h4>

<p class="whs4">import geompy</p>

<p class="whs4">import smesh</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create two boxes</p>

<p class="whs4">box1 = geompy.MakeBox(0., 
 &nbsp;0., 0., 
 10., 10., 10.)</p>

<p class="whs4">box2 = geompy.MakeBox(0., 
 15., 0., 20., 25., 10.)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">EdgesList = geompy.SubShapeAll(box2, 
 geompy.ShapeType[&quot;EDGE&quot;])</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">aComp = geompy.MakeCompound([box1, 
 box2])</p>

<p class="whs4">geompy.addToStudy(aComp, 
 &quot;Two boxes&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># create a mesh on 
 two boxes</p>

<p class="whs4">mesh = smesh.Mesh(aComp, 
 &quot;Two faces : quadrangle mesh&quot;)</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo1D = mesh.Segment()</p>

<p class="whs4">algo1D.NumberOfSegments(2)</p>

<p class="whs4">algo2D = mesh.Quadrangle()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">algo_local = mesh.Segment(EdgesList[8])</p>

<p class="whs4">algo_local.NumberOfSegments(4)</p>

<p class="whs4">algo_local.Propagation()</p>

<p class="whs4">&nbsp;</p>

<p class="whs4">mesh.Compute()</p>

<p class="whs4">&nbsp;</p>

<p class="whs5"># sew side elements</p>

<p class="whs5"># IDsOfSide1Elements, 
 IDsOfSide2Elements,</p>

<p class="whs5"># NodeID1OfSide1ToMerge, 
 NodeID1OfSide2ToMerge, NodeID2OfSide1ToMerge, NodeID2OfSide2ToMerge</p>

<p class="whs4">mesh.SewSideElements([69, 
 70, 71, 72], [91, 92, 89, 90], 8, 38, 23, 58) </p>

<script type="text/javascript" language="javascript1.2">
<!--
if (window.writeIntopicBar)
	writeIntopicBar(0);
//-->
</script>
</body>
</html>