mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-13 02:00:34 +05:00
Merge V8_3_BR branch.
This commit is contained in:
commit
651e7566c8
@ -31,7 +31,7 @@ ENDIF(WIN32)
|
|||||||
STRING(TOUPPER ${PROJECT_NAME} PROJECT_NAME_UC)
|
STRING(TOUPPER ${PROJECT_NAME} PROJECT_NAME_UC)
|
||||||
|
|
||||||
SET(${PROJECT_NAME_UC}_MAJOR_VERSION 8)
|
SET(${PROJECT_NAME_UC}_MAJOR_VERSION 8)
|
||||||
SET(${PROJECT_NAME_UC}_MINOR_VERSION 2)
|
SET(${PROJECT_NAME_UC}_MINOR_VERSION 3)
|
||||||
SET(${PROJECT_NAME_UC}_PATCH_VERSION 0)
|
SET(${PROJECT_NAME_UC}_PATCH_VERSION 0)
|
||||||
SET(${PROJECT_NAME_UC}_VERSION
|
SET(${PROJECT_NAME_UC}_VERSION
|
||||||
${${PROJECT_NAME_UC}_MAJOR_VERSION}.${${PROJECT_NAME_UC}_MINOR_VERSION}.${${PROJECT_NAME_UC}_PATCH_VERSION})
|
${${PROJECT_NAME_UC}_MAJOR_VERSION}.${${PROJECT_NAME_UC}_MINOR_VERSION}.${${PROJECT_NAME_UC}_PATCH_VERSION})
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
<ul>
|
<ul>
|
||||||
$navpath
|
$navpath
|
||||||
<li class="footer">
|
<li class="footer">
|
||||||
Copyright © 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE<br>
|
Copyright © 2007-2017 CEA/DEN, EDF R&D, OPEN CASCADE<br>
|
||||||
Copyright © 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS<br>
|
Copyright © 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS<br>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -4,7 +4,7 @@
|
|||||||
<ul>
|
<ul>
|
||||||
$navpath
|
$navpath
|
||||||
<li class="footer">
|
<li class="footer">
|
||||||
Copyright © 2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE<br>
|
Copyright © 2007-2017 CEA/DEN, EDF R&D, OPEN CASCADE<br>
|
||||||
Copyright © 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS<br>
|
Copyright © 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS<br>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
@ -36,7 +36,7 @@ master_doc = 'index'
|
|||||||
|
|
||||||
# General substitutions.
|
# General substitutions.
|
||||||
project = 'MGCleaner Plug-in'
|
project = 'MGCleaner Plug-in'
|
||||||
copyright = '2013-2016, EDF R&D'
|
copyright = '2013-2017, EDF R&D'
|
||||||
|
|
||||||
# The default replacements for |version| and |release|, also used in various
|
# The default replacements for |version| and |release|, also used in various
|
||||||
# other places throughout the built documents.
|
# other places throughout the built documents.
|
||||||
|
@ -36,7 +36,7 @@ master_doc = 'index'
|
|||||||
|
|
||||||
# General substitutions.
|
# General substitutions.
|
||||||
project = 'Verima Plug-in'
|
project = 'Verima Plug-in'
|
||||||
copyright = '2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE'
|
copyright = '2007-2017 CEA/DEN, EDF R&D, OPEN CASCADE'
|
||||||
|
|
||||||
# The default replacements for |version| and |release|, also used in various
|
# The default replacements for |version| and |release|, also used in various
|
||||||
# other places throughout the built documents.
|
# other places throughout the built documents.
|
||||||
|
@ -36,7 +36,7 @@ master_doc = 'index'
|
|||||||
|
|
||||||
# General substitutions.
|
# General substitutions.
|
||||||
project = 'MeshGems-SurfOpt Plug-in'
|
project = 'MeshGems-SurfOpt Plug-in'
|
||||||
copyright = '2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE'
|
copyright = '2007-2017 CEA/DEN, EDF R&D, OPEN CASCADE'
|
||||||
|
|
||||||
# The default replacements for |version| and |release|, also used in various
|
# The default replacements for |version| and |release|, also used in various
|
||||||
# other places throughout the built documents.
|
# other places throughout the built documents.
|
||||||
|
@ -2,15 +2,14 @@ import sys, os, shutil, pickle, tempfile
|
|||||||
import main, genereCrack, Zset
|
import main, genereCrack, Zset
|
||||||
import utilityFunctions as uF
|
import utilityFunctions as uF
|
||||||
|
|
||||||
|
os.environ['QT_QPA_PLATFORM_PLUGIN_PATH']=os.path.join(os.environ['QTDIR'],'plugins','platforms')
|
||||||
|
|
||||||
#commande="/bin/bash -c ""source $HOME/zebulon/Z8.6.6_NEW/do_config_bash"""
|
#commande="/bin/bash -c ""source $HOME/zebulon/Z8.6.6_NEW/do_config_bash"""
|
||||||
#os.system(commande)
|
#os.system(commande)
|
||||||
|
|
||||||
def IHM():
|
def IHM():
|
||||||
|
|
||||||
try:
|
from PyQt5.QtWidgets import QApplication
|
||||||
from PyQt5.QtWidgets import QApplication
|
|
||||||
except:
|
|
||||||
from PyQt4.QtGui import QApplication
|
|
||||||
|
|
||||||
app = QApplication(sys.argv)
|
app = QApplication(sys.argv)
|
||||||
myapp = main.ShipHolderApplication()
|
myapp = main.ShipHolderApplication()
|
||||||
@ -31,8 +30,7 @@ def SCRIPT(dataFile=None, data=None, dim=3, names=None):
|
|||||||
|
|
||||||
print data
|
print data
|
||||||
|
|
||||||
tmpdir=tempfile.mkdtemp()
|
tmpdir=tempfile.mkdtemp(prefix='tmpZcracks')
|
||||||
uF.removeFromSessionPath('LD_LIBRARY_PATH', 'Meshgems-2111')
|
|
||||||
|
|
||||||
if names==None: names={'saneGeoName':'salome_sane', 'crackGeoName':'salome_crack', 'crackedGeoName':'salome_cracked'}
|
if names==None: names={'saneGeoName':'salome_sane', 'crackGeoName':'salome_crack', 'crackedGeoName':'salome_cracked'}
|
||||||
|
|
||||||
|
@ -18,13 +18,13 @@ import string
|
|||||||
|
|
||||||
#tmpdir = "/local00/home/B27118/projets/Zcracks/Zcracks/casTests/tmpdir"
|
#tmpdir = "/local00/home/B27118/projets/Zcracks/Zcracks/casTests/tmpdir"
|
||||||
#if not os.path.isdir(tmpdir): os.mkdir(tmpdir)
|
#if not os.path.isdir(tmpdir): os.mkdir(tmpdir)
|
||||||
tmpdir=tempfile.mktemp(prefix='tmpZcracks')
|
tmpdir=tempfile.mkdtemp(prefix='tmpZcracks')
|
||||||
print "tmpdir=", tmpdir
|
print "tmpdir=", tmpdir
|
||||||
|
|
||||||
meshgemsdir=os.environ('MESHGEMSHOME')
|
#meshgemsdir=os.environ('MESHGEMSHOME')
|
||||||
if len(meshgemsdir) > 0:
|
#if len(meshgemsdir) > 0:
|
||||||
meshgems=string.split(meshgemsdir,os.sep)[-1]
|
#meshgems=string.split(meshgemsdir,os.sep)[-1]
|
||||||
uF.removeFromSessionPath('LD_LIBRARY_PATH', meshgems)
|
#uF.removeFromSessionPath('LD_LIBRARY_PATH', meshgems)
|
||||||
|
|
||||||
def LAUNCH(listCas=[]):
|
def LAUNCH(listCas=[]):
|
||||||
if type(listCas)!=list: listCas=[listCas]
|
if type(listCas)!=list: listCas=[listCas]
|
||||||
|
@ -36,7 +36,7 @@ master_doc = 'index'
|
|||||||
|
|
||||||
# General substitutions.
|
# General substitutions.
|
||||||
project = 'ZCracks Plug-in'
|
project = 'ZCracks Plug-in'
|
||||||
copyright = '2007-2016 CEA/DEN, EDF R&D, OPEN CASCADE'
|
copyright = '2007-2017 CEA/DEN, EDF R&D, OPEN CASCADE'
|
||||||
|
|
||||||
# The default replacements for |version| and |release|, also used in various
|
# The default replacements for |version| and |release|, also used in various
|
||||||
# other places throughout the built documents.
|
# other places throughout the built documents.
|
||||||
|
@ -1,13 +1,9 @@
|
|||||||
import sys, pickle, tempfile, shutil
|
import sys, pickle, tempfile, shutil
|
||||||
from os import path, getpid, environ, remove, system
|
from os import path, getpid, environ, remove, system
|
||||||
|
|
||||||
try:
|
from PyQt5.QtCore import *
|
||||||
from PyQt5.QtCore import *
|
from PyQt5.QtGui import *
|
||||||
from PyQt5.QtGui import *
|
from PyQt5.QtWidgets import *
|
||||||
from PyQt5.QtWidgets import *
|
|
||||||
except:
|
|
||||||
from PyQt4.QtCore import *
|
|
||||||
from PyQt4.QtGui import *
|
|
||||||
|
|
||||||
import utilityFunctions as uF
|
import utilityFunctions as uF
|
||||||
import genereCrack, Zset, output, zcracks_ui
|
import genereCrack, Zset, output, zcracks_ui
|
||||||
@ -21,8 +17,6 @@ from zcracks_ui import Ui_Zui
|
|||||||
# ---------------------
|
# ---------------------
|
||||||
|
|
||||||
|
|
||||||
uF.removeFromSessionPath('LD_LIBRARY_PATH', 'Meshgems-2111')
|
|
||||||
|
|
||||||
def stringToFloat(string, typ=float):
|
def stringToFloat(string, typ=float):
|
||||||
if str(string).replace(' ','')=='':
|
if str(string).replace(' ','')=='':
|
||||||
out=[]
|
out=[]
|
||||||
@ -78,25 +72,6 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
|
|
||||||
self.verbose=1
|
self.verbose=1
|
||||||
|
|
||||||
#self.connect(self.ui.CBQuad, SIGNAL("toggled(bool)"),self.pressQuad)
|
|
||||||
#self.connect(self.ui.btReset, SIGNAL("clicked()"),self.pressReset)
|
|
||||||
#self.connect(self.ui.btCancel, SIGNAL("clicked()"),self.pressCancel)
|
|
||||||
#self.connect(self.ui.btApply, SIGNAL("clicked()"),self.pressApply)
|
|
||||||
#self.connect(self.ui.btApplyClose, SIGNAL("clicked()"),self.pressApplyClose)
|
|
||||||
#self.connect(self.ui.btLoad, SIGNAL("clicked()"),self.pressCharger)
|
|
||||||
#self.connect(self.ui.btSave, SIGNAL("clicked()"),self.pressSauver)
|
|
||||||
#self.connect(self.ui.btLoadCracked, SIGNAL("clicked()"),self.pressLoadCracked)
|
|
||||||
#self.connect(self.ui.btLoadSane, SIGNAL("clicked()"),self.pressLoadSane)
|
|
||||||
|
|
||||||
#self.connect(self.ui.btGrVol, SIGNAL("clicked()"),self.pressLoadGroupVOL)
|
|
||||||
#self.connect(self.ui.btGrFace, SIGNAL("clicked()"),self.pressLoadGroupFACE)
|
|
||||||
#self.connect(self.ui.btGrEdge, SIGNAL("clicked()"),self.pressLoadGroupEDGE)
|
|
||||||
#self.connect(self.ui.btGrNode, SIGNAL("clicked()"),self.pressLoadGroupNODE)
|
|
||||||
#self.connect(self.ui.btGrAll, SIGNAL("clicked()"),self.pressLoadGroupALL)
|
|
||||||
#self.connect(self.ui.btVisu, SIGNAL("clicked()"),self.pressVisu)
|
|
||||||
|
|
||||||
#self.connect(self.ui.CBAdvanced, SIGNAL("toggled(bool)"),self.pressAdvanced)
|
|
||||||
|
|
||||||
self.ui.CBQuad.toggled.connect(self.pressQuad)
|
self.ui.CBQuad.toggled.connect(self.pressQuad)
|
||||||
self.ui.btReset.clicked.connect(self.pressReset)
|
self.ui.btReset.clicked.connect(self.pressReset)
|
||||||
self.ui.btCancel.clicked.connect(self.pressCancel)
|
self.ui.btCancel.clicked.connect(self.pressCancel)
|
||||||
@ -144,9 +119,9 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
def pressQuad(self):
|
def pressQuad(self):
|
||||||
if self.ui.CBQuad.isChecked():
|
if self.ui.CBQuad.isChecked():
|
||||||
self.ui.CBBarsoum.setEnabled(True)
|
self.ui.CBBarsoum.setEnabled(True)
|
||||||
self.ui.valGradation.setText(QString('2.3'))
|
self.ui.valGradation.setText('2.3')
|
||||||
else:
|
else:
|
||||||
self.ui.valGradation.setText(QString('1.3'))
|
self.ui.valGradation.setText('1.3')
|
||||||
self.ui.CBBarsoum.setChecked(False)
|
self.ui.CBBarsoum.setChecked(False)
|
||||||
self.ui.CBBarsoum.setEnabled(False)
|
self.ui.CBBarsoum.setEnabled(False)
|
||||||
|
|
||||||
@ -162,10 +137,10 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
tab=onglet.findChildren(QTableWidget)[0]
|
tab=onglet.findChildren(QTableWidget)[0]
|
||||||
for irow in range(tab.rowCount()):
|
for irow in range(tab.rowCount()):
|
||||||
if tab.item(irow,0) != None:
|
if tab.item(irow,0) != None:
|
||||||
tab.item(irow,0).setText(QString(''))
|
tab.item(irow,0).setText('')
|
||||||
self.ui.valGradation.setText(QString('1.3'))
|
self.ui.valGradation.setText('1.3')
|
||||||
self.ui.valLayers.setText(QString('5'))
|
self.ui.valLayers.setText('6')
|
||||||
self.ui.valIterations.setText(QString('2'))
|
self.ui.valIterations.setText('2')
|
||||||
self.ui.CBIs2D.setChecked(False)
|
self.ui.CBIs2D.setChecked(False)
|
||||||
self.ui.CBRefine.setChecked(False)
|
self.ui.CBRefine.setChecked(False)
|
||||||
|
|
||||||
@ -257,7 +232,7 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
fileNames = fileDiag.selectedFiles()
|
fileNames = fileDiag.selectedFiles()
|
||||||
filedef = fileNames[0]
|
filedef = fileNames[0]
|
||||||
filedef = addExtension(str(filedef), 'med')
|
filedef = addExtension(str(filedef), 'med')
|
||||||
self.ui.valCrackedName.setText(QString(filedef))
|
self.ui.valCrackedName.setText(filedef)
|
||||||
|
|
||||||
|
|
||||||
def pressLoadSane(self):
|
def pressLoadSane(self):
|
||||||
@ -268,7 +243,7 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
if fileDiag.exec_() :
|
if fileDiag.exec_() :
|
||||||
fileNames = fileDiag.selectedFiles()
|
fileNames = fileDiag.selectedFiles()
|
||||||
filedef = fileNames[0]
|
filedef = fileNames[0]
|
||||||
self.ui.valSaneName.setText(QString(filedef))
|
self.ui.valSaneName.setText(filedef)
|
||||||
|
|
||||||
|
|
||||||
def pressCharger(self):
|
def pressCharger(self):
|
||||||
@ -287,23 +262,15 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
|
|
||||||
for cont, obj in enumerate(self.lineEditObjects):
|
for cont, obj in enumerate(self.lineEditObjects):
|
||||||
if self.lineEditTypes[cont] in [float, int]:
|
if self.lineEditTypes[cont] in [float, int]:
|
||||||
obj.setText(QString(self.data['TXT'+self.lineEditNames[cont]]))
|
obj.setText(self.data['TXT'+self.lineEditNames[cont]])
|
||||||
else:
|
else:
|
||||||
obj.setText(QString(self.data[self.lineEditNames[cont]]))
|
obj.setText(self.data[self.lineEditNames[cont]])
|
||||||
|
|
||||||
self.ui.CBQuad.setChecked(True if 'quad' in self.data.keys() and self.data['quad'] else False)
|
self.ui.CBQuad.setChecked(True if 'quad' in self.data.keys() and self.data['quad'] else False)
|
||||||
self.ui.CBBarsoum.setChecked(True if 'barsoum' in self.data.keys() and self.data['barsoum'] else False)
|
self.ui.CBBarsoum.setChecked(True if 'barsoum' in self.data.keys() and self.data['barsoum'] else False)
|
||||||
self.ui.CBIs2D.setChecked(True if 'is2D' in self.data.keys() and self.data['is2D'] else False)
|
self.ui.CBIs2D.setChecked(True if 'is2D' in self.data.keys() and self.data['is2D'] else False)
|
||||||
self.ui.CBRefine.setChecked(True if 'refine' in self.data.keys() and self.data['refine'] else False)
|
self.ui.CBRefine.setChecked(True if 'refine' in self.data.keys() and self.data['refine'] else False)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#if self.data['quad']: self.ui.CBQuad.setChecked(True)
|
|
||||||
#if self.data['barsoum']: self.ui.CBBarsoum.setChecked(True)
|
|
||||||
#if self.data['is2D']: self.ui.CBIs2D.setChecked(True)
|
|
||||||
#if self.data['refine']: self.ui.CBRefine.setChecked(True)
|
|
||||||
self.setTableParameters()
|
self.setTableParameters()
|
||||||
|
|
||||||
|
|
||||||
@ -451,7 +418,7 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
if tab.item(irow,0) == None:
|
if tab.item(irow,0) == None:
|
||||||
item = QTableWidgetItem()
|
item = QTableWidgetItem()
|
||||||
tab.setItem(irow, 0, item)
|
tab.setItem(irow, 0, item)
|
||||||
tab.item(irow,0).setText(QString(self.data['TXTcrack'][str(self.ui.tabWidget.tabText(iongl))][str(label)]))
|
tab.item(irow,0).setText(self.data['TXTcrack'][str(self.ui.tabWidget.tabText(iongl))][str(label)])
|
||||||
if str(self.ui.tabWidget.tabText(iongl)) == self.data['TXTcrack']['actif']:
|
if str(self.ui.tabWidget.tabText(iongl)) == self.data['TXTcrack']['actif']:
|
||||||
self.ui.tabWidget.setCurrentWidget(onglet)
|
self.ui.tabWidget.setCurrentWidget(onglet)
|
||||||
|
|
||||||
@ -475,19 +442,19 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
|
|
||||||
for group in objetSain.GetGroups():
|
for group in objetSain.GetGroups():
|
||||||
if (self.GroupToLoad in ['VOL','ALL']) and (group.GetType()==SMESH.VOLUME):
|
if (self.GroupToLoad in ['VOL','ALL']) and (group.GetType()==SMESH.VOLUME):
|
||||||
groupsVOL+=group.GetName().replace(' ','')+" "
|
groupsVOL+=self.cleanGroupName(group)
|
||||||
nGr+=1
|
nGr+=1
|
||||||
|
|
||||||
if (self.GroupToLoad in ['FACE','ALL']) and (group.GetType()==SMESH.FACE):
|
if (self.GroupToLoad in ['FACE','ALL']) and (group.GetType()==SMESH.FACE):
|
||||||
groupsFAC+=group.GetName().replace(' ','')+" "
|
groupsFAC+=self.cleanGroupName(group)
|
||||||
nGr+=1
|
nGr+=1
|
||||||
|
|
||||||
if (self.GroupToLoad in ['EDGE','ALL']) and (group.GetType()==SMESH.EDGE):
|
if (self.GroupToLoad in ['EDGE','ALL']) and (group.GetType()==SMESH.EDGE):
|
||||||
groupsEDG+=group.GetName().replace(' ','')+" "
|
groupsEDG+=self.cleanGroupName(group)
|
||||||
nGr+=1
|
nGr+=1
|
||||||
|
|
||||||
if (self.GroupToLoad in ['NODE','ALL']) and (group.GetType()==SMESH.NODE):
|
if (self.GroupToLoad in ['NODE','ALL']) and (group.GetType()==SMESH.NODE):
|
||||||
groupsNOD+=group.GetName().replace(' ','')+" "
|
groupsNOD+=self.cleanGroupName(group)
|
||||||
nGr+=1
|
nGr+=1
|
||||||
|
|
||||||
if groupsVOL!='': self.ui.valGrVol.setText(groupsVOL)
|
if groupsVOL!='': self.ui.valGrVol.setText(groupsVOL)
|
||||||
@ -503,6 +470,24 @@ class ShipHolderApplication(QGroupBox):
|
|||||||
remove(f)
|
remove(f)
|
||||||
except:
|
except:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
def cleanGroupName(self, group):
|
||||||
|
name=group.GetName()
|
||||||
|
while name.endswith(' '): name=name[:-1]
|
||||||
|
if ' ' in name:
|
||||||
|
message('A','%s group has a space in its name --> ignored' %name)
|
||||||
|
return('')
|
||||||
|
else:
|
||||||
|
return(name+" ")
|
||||||
|
|
||||||
|
def checkNamesSpaces(self, names):
|
||||||
|
if type(names) is str: names=[names]
|
||||||
|
ok=True
|
||||||
|
for n in names:
|
||||||
|
if ' ' in n:
|
||||||
|
message('E','%s has a space in its name, please remove it' %n, goOn=True)
|
||||||
|
ok=False
|
||||||
|
return(ok)
|
||||||
|
|
||||||
|
|
||||||
# ---------------------------------
|
# ---------------------------------
|
||||||
|
@ -22,9 +22,9 @@ class output():
|
|||||||
pass
|
pass
|
||||||
f = open(self.tmpFile,'w')
|
f = open(self.tmpFile,'w')
|
||||||
f.write('\n ------------------------------\n')
|
f.write('\n ------------------------------\n')
|
||||||
f.write(' | BIENVENU DANS L\'INTERFACE |\n')
|
f.write(' | BIENVENUE DANS L\'INTERFACE |\n')
|
||||||
f.write(' | ZCRACKS DE SALOME |\n')
|
f.write(' | ZCRACKS DE SALOME |\n')
|
||||||
f.write(' | VERSION ALPHA |\n')
|
f.write(' | VERSION BETA |\n')
|
||||||
f.write(' ------------------------------\n\n')
|
f.write(' ------------------------------\n\n')
|
||||||
f.close()
|
f.close()
|
||||||
|
|
||||||
|
@ -178,7 +178,13 @@ def extendElsets(meshFile, outFile=None):
|
|||||||
smesh = smeshBuilder.New(theStudy)
|
smesh = smeshBuilder.New(theStudy)
|
||||||
|
|
||||||
([mesh], status) = smesh.CreateMeshesFromMED(meshFile)
|
([mesh], status) = smesh.CreateMeshesFromMED(meshFile)
|
||||||
|
|
||||||
|
if mesh.NbVolumes()>0:
|
||||||
|
case2D=False
|
||||||
|
mesh.Reorient2DBy3D( [ mesh ], mesh, 1 )
|
||||||
|
else:
|
||||||
|
case2D=True
|
||||||
|
|
||||||
mesh=cleanGroups(mesh)
|
mesh=cleanGroups(mesh)
|
||||||
|
|
||||||
# Node color status
|
# Node color status
|
||||||
@ -339,91 +345,6 @@ def getMaxAspectRatio(tmpdir):
|
|||||||
return(float(maxAR))
|
return(float(maxAR))
|
||||||
|
|
||||||
|
|
||||||
#def extendElsets(meshFile):
|
|
||||||
#if not path.isfile(meshFile):
|
|
||||||
#message('E','Mesh med file is not valid')
|
|
||||||
#return(-1)
|
|
||||||
|
|
||||||
#import SMESH, salome
|
|
||||||
##salome.salome_init()
|
|
||||||
#theStudy = salome.myStudy
|
|
||||||
#from salome.smesh import smeshBuilder
|
|
||||||
#smesh = smeshBuilder.New(theStudy)
|
|
||||||
|
|
||||||
#([mesh], status) = smesh.CreateMeshesFromMED(meshFile)
|
|
||||||
|
|
||||||
## Node color status
|
|
||||||
#nodeList=mesh.GetNodesId()
|
|
||||||
#colorList=[0]*len(nodeList)
|
|
||||||
|
|
||||||
## Init using SIDE0 SIDE1
|
|
||||||
#for group in mesh.GetGroups():
|
|
||||||
#if group.GetType()==SMESH.FACE :
|
|
||||||
#color=0
|
|
||||||
#if group.GetName()[0:4]=='SIDE0' :
|
|
||||||
#color=1
|
|
||||||
#elif group.GetName()[0:4]=='SIDE1' :
|
|
||||||
#color=2
|
|
||||||
#else : continue
|
|
||||||
## Get faces
|
|
||||||
#faces=group.GetIDs()
|
|
||||||
## Set faces nodes to given color
|
|
||||||
#for face_id in faces :
|
|
||||||
#for face_node_id in mesh.GetElemNodes(face_id) :
|
|
||||||
#colorList[face_node_id-1]=color
|
|
||||||
|
|
||||||
## Propagates color using elem connectivity
|
|
||||||
## Always propagates max color
|
|
||||||
#volElemList=mesh.GetElementsByType(SMESH.VOLUME)
|
|
||||||
#ifChanged=True
|
|
||||||
#while ifChanged :
|
|
||||||
#ifChanged=False
|
|
||||||
#minColor=100
|
|
||||||
#maxColor=0
|
|
||||||
#for elemId in volElemList:
|
|
||||||
#for elemNodeId in mesh.GetElemNodes(elemId) :
|
|
||||||
#nodeColor=colorList[elemNodeId-1]
|
|
||||||
#if nodeColor<minColor : minColor=nodeColor
|
|
||||||
#if nodeColor>maxColor : maxColor=nodeColor
|
|
||||||
#if minColor!=maxColor :
|
|
||||||
#ifChanged = True
|
|
||||||
#for elemNodeId in mesh.GetElemNodes(elemId) :
|
|
||||||
#colorList[elemNodeId-1]=maxColor
|
|
||||||
|
|
||||||
#velem0 = []
|
|
||||||
#velem1 = []
|
|
||||||
#for elemId in volElemList:
|
|
||||||
#elemNodesId=mesh.GetElemNodes(elemId)
|
|
||||||
#elemColor=colorList[elemNodesId[0]-1]
|
|
||||||
#if(elemColor==1) : velem0.append(elemId)
|
|
||||||
#if(elemColor==2) : velem1.append(elemId)
|
|
||||||
|
|
||||||
#mesh.MakeGroupByIds('SIDE_co',SMESH.VOLUME,velem0)
|
|
||||||
#mesh.MakeGroupByIds('SIDE_ext',SMESH.VOLUME,velem1)
|
|
||||||
|
|
||||||
#surfElemList=mesh.GetElementsByType(SMESH.FACE)
|
|
||||||
#selem0 = []
|
|
||||||
#selem1 = []
|
|
||||||
#nbelem0=0
|
|
||||||
#nbelem1=0
|
|
||||||
|
|
||||||
#for elemId in surfElemList:
|
|
||||||
#elemNodesId=mesh.GetElemNodes(elemId)
|
|
||||||
#elemColor=colorList[elemNodesId[0]-1]
|
|
||||||
#if(elemColor==1) : selem0.append(elemId)
|
|
||||||
#if(elemColor==2) : selem1.append(elemId)
|
|
||||||
|
|
||||||
#mesh.MakeGroupByIds('SIDE_co',SMESH.FACE,selem0)
|
|
||||||
#mesh.MakeGroupByIds('SIDE_ext',SMESH.FACE,selem1)
|
|
||||||
|
|
||||||
#maxAR=0.
|
|
||||||
#for elem in volElemList:
|
|
||||||
#maxAR=max(mesh.GetAspectRatio(elem),maxAR)
|
|
||||||
#for elem in surfElemList:
|
|
||||||
#maxAR=max(mesh.GetAspectRatio(elem),maxAR)
|
|
||||||
|
|
||||||
#mesh.ExportMED(meshFile, 0, SMESH.MED_V2_2, 1, None ,1)
|
|
||||||
#return(maxAR)
|
|
||||||
|
|
||||||
|
|
||||||
def removeFromSessionPath(envVar, patern):
|
def removeFromSessionPath(envVar, patern):
|
||||||
|
@ -36,7 +36,7 @@ master_doc = 'index'
|
|||||||
|
|
||||||
# General substitutions.
|
# General substitutions.
|
||||||
project = 'Plug-in blocFissure'
|
project = 'Plug-in blocFissure'
|
||||||
copyright = '2010-2016 EDF R&D'
|
copyright = '2010-2017 EDF R&D'
|
||||||
|
|
||||||
# The default replacements for |version| and |release|, also used in various
|
# The default replacements for |version| and |release|, also used in various
|
||||||
# other places throughout the built documents.
|
# other places throughout the built documents.
|
||||||
|
@ -42,9 +42,9 @@ INPUTDATA_KEY_FILES="meshfiles"
|
|||||||
INPUTDATA_KEY_PARAM="parameters"
|
INPUTDATA_KEY_PARAM="parameters"
|
||||||
|
|
||||||
PARAM_KEY_NBITER = "NbIteration"
|
PARAM_KEY_NBITER = "NbIteration"
|
||||||
PARAM_KEY_RMINRMAX = "RminRmax"
|
PARAM_KEY_RMAXRMIN = "RmaxRmin"
|
||||||
PARAM_NBITER_DEFAULT_VALUE = 3
|
PARAM_NBITER_DEFAULT_VALUE = 10
|
||||||
PARAM_RMINRMAX_DEFAULT_VALUE = 1.5
|
PARAM_RMAXRMIN_DEFAULT_VALUE = 3
|
||||||
|
|
||||||
class InputDialog(GenericDialog):
|
class InputDialog(GenericDialog):
|
||||||
|
|
||||||
@ -125,7 +125,7 @@ class InputDialog(GenericDialog):
|
|||||||
|
|
||||||
# Setup default values for numerical parameters
|
# Setup default values for numerical parameters
|
||||||
self.__ui.txtParamNbIter.setValue(PARAM_NBITER_DEFAULT_VALUE)
|
self.__ui.txtParamNbIter.setValue(PARAM_NBITER_DEFAULT_VALUE)
|
||||||
self.__ui.txtParamRminRmax.setValue(PARAM_RMINRMAX_DEFAULT_VALUE)
|
self.__ui.txtParamRmaxRmin.setValue(PARAM_RMAXRMIN_DEFAULT_VALUE)
|
||||||
|
|
||||||
# Note that PADDER does not support group name longer than 8
|
# Note that PADDER does not support group name longer than 8
|
||||||
# characters. We apply then this limit in the gui field.
|
# characters. We apply then this limit in the gui field.
|
||||||
@ -317,8 +317,8 @@ class InputDialog(GenericDialog):
|
|||||||
dictInputParameters = dictInputData[INPUTDATA_KEY_PARAM]
|
dictInputParameters = dictInputData[INPUTDATA_KEY_PARAM]
|
||||||
if dictInputParameters.has_key(PARAM_KEY_NBITER):
|
if dictInputParameters.has_key(PARAM_KEY_NBITER):
|
||||||
self.__ui.txtParamNbIter.setValue(dictInputParameters[PARAM_KEY_NBITER])
|
self.__ui.txtParamNbIter.setValue(dictInputParameters[PARAM_KEY_NBITER])
|
||||||
if dictInputParameters.has_key(PARAM_KEY_RMINRMAX):
|
if dictInputParameters.has_key(PARAM_KEY_RMAXRMIN):
|
||||||
self.__ui.txtParamRminRmax.setValue(dictInputParameters[PARAM_KEY_RMINRMAX])
|
self.__ui.txtParamRmaxRmin.setValue(dictInputParameters[PARAM_KEY_RMAXRMIN])
|
||||||
|
|
||||||
def getData(self):
|
def getData(self):
|
||||||
"""
|
"""
|
||||||
@ -334,7 +334,7 @@ class InputDialog(GenericDialog):
|
|||||||
# Get the list of additionnal parameters
|
# Get the list of additionnal parameters
|
||||||
dictInputParameters = {}
|
dictInputParameters = {}
|
||||||
dictInputParameters[PARAM_KEY_NBITER] = self.__ui.txtParamNbIter.value()
|
dictInputParameters[PARAM_KEY_NBITER] = self.__ui.txtParamNbIter.value()
|
||||||
dictInputParameters[PARAM_KEY_RMINRMAX] = self.__ui.txtParamRminRmax.value()
|
dictInputParameters[PARAM_KEY_RMAXRMIN] = self.__ui.txtParamRmaxRmin.value()
|
||||||
dictInputData[INPUTDATA_KEY_PARAM] = dictInputParameters
|
dictInputData[INPUTDATA_KEY_PARAM] = dictInputParameters
|
||||||
return dictInputData
|
return dictInputData
|
||||||
|
|
||||||
|
@ -111,7 +111,7 @@
|
|||||||
</property>
|
</property>
|
||||||
<item>
|
<item>
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Béton</string>
|
<string>Beton</string>
|
||||||
</property>
|
</property>
|
||||||
<property name="icon">
|
<property name="icon">
|
||||||
<iconset>
|
<iconset>
|
||||||
@ -213,9 +213,9 @@
|
|||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QLabel" name="lblParamRminRmax">
|
<widget class="QLabel" name="lblParamRmaxRmin">
|
||||||
<property name="text">
|
<property name="text">
|
||||||
<string>Rmin / Rmax</string>
|
<string>Rmax / Rmin</string>
|
||||||
</property>
|
</property>
|
||||||
</widget>
|
</widget>
|
||||||
</item>
|
</item>
|
||||||
@ -227,7 +227,7 @@
|
|||||||
<widget class="QSpinBox" name="txtParamNbIter"/>
|
<widget class="QSpinBox" name="txtParamNbIter"/>
|
||||||
</item>
|
</item>
|
||||||
<item>
|
<item>
|
||||||
<widget class="QDoubleSpinBox" name="txtParamRminRmax"/>
|
<widget class="QDoubleSpinBox" name="txtParamRmaxRmin"/>
|
||||||
</item>
|
</item>
|
||||||
</layout>
|
</layout>
|
||||||
</item>
|
</item>
|
||||||
|
@ -24,7 +24,7 @@ from qtsalome import QDialog, QIcon, Qt
|
|||||||
|
|
||||||
from plugindialog_ui import Ui_PluginDialog
|
from plugindialog_ui import Ui_PluginDialog
|
||||||
from inputdialog import InputDialog, INPUTDATA_KEY_FILES, INPUTDATA_KEY_PARAM
|
from inputdialog import InputDialog, INPUTDATA_KEY_FILES, INPUTDATA_KEY_PARAM
|
||||||
from inputdialog import PARAM_KEY_NBITER, PARAM_KEY_RMINRMAX
|
from inputdialog import PARAM_KEY_NBITER, PARAM_KEY_RMAXRMIN
|
||||||
from inputdata import InputData
|
from inputdata import InputData
|
||||||
# __GBO__: uncomment this line and comment the previous one to use the
|
# __GBO__: uncomment this line and comment the previous one to use the
|
||||||
# demo input dialog instead of the real one.
|
# demo input dialog instead of the real one.
|
||||||
|
@ -83,7 +83,7 @@ PADDERTESTDIR = getPadderTestDir(defaultConfig)
|
|||||||
# padder.cfg).
|
# padder.cfg).
|
||||||
#
|
#
|
||||||
def test00_parameters():
|
def test00_parameters():
|
||||||
"""Test using a concrete mesh and a single steelbar mesh"""
|
"""Test using a concrete mesh and a single steelbar mesh"""
|
||||||
file_concrete=os.path.join(spadder.getTestDataDir(),"concrete.med")
|
file_concrete=os.path.join(spadder.getTestDataDir(),"concrete.med")
|
||||||
file_steelbar=os.path.join(spadder.getTestDataDir(),"ferraill.med")
|
file_steelbar=os.path.join(spadder.getTestDataDir(),"ferraill.med")
|
||||||
|
|
||||||
@ -109,7 +109,7 @@ def test01_parameters():
|
|||||||
file_type=MESHJOB.MED_CONCRETE,
|
file_type=MESHJOB.MED_CONCRETE,
|
||||||
group_name="concrete")
|
group_name="concrete")
|
||||||
meshJobFileList.append(param)
|
meshJobFileList.append(param)
|
||||||
|
|
||||||
medfile = os.path.join(datadir,"ferraill.med")
|
medfile = os.path.join(datadir,"ferraill.med")
|
||||||
param = MESHJOB.MeshJobFile(file_name=medfile,
|
param = MESHJOB.MeshJobFile(file_name=medfile,
|
||||||
file_type=MESHJOB.MED_STEELBAR,
|
file_type=MESHJOB.MED_STEELBAR,
|
||||||
@ -121,7 +121,7 @@ def test01_parameters():
|
|||||||
file_type=MESHJOB.MED_STEELBAR,
|
file_type=MESHJOB.MED_STEELBAR,
|
||||||
group_name="ferrtran")
|
group_name="ferrtran")
|
||||||
meshJobFileList.append(param)
|
meshJobFileList.append(param)
|
||||||
|
|
||||||
return meshJobFileList
|
return meshJobFileList
|
||||||
|
|
||||||
def test02_parameters():
|
def test02_parameters():
|
||||||
@ -161,7 +161,7 @@ def test03_parameters():
|
|||||||
meshJobFileList = test03_parameters()
|
meshJobFileList = test03_parameters()
|
||||||
|
|
||||||
meshJobParameterList = []
|
meshJobParameterList = []
|
||||||
param = MESHJOB.MeshJobParameter(name="RminRmax",value="1.5")
|
param = MESHJOB.MeshJobParameter(name="RmaxRmin",value="1.5")
|
||||||
meshJobParameterList.append(param)
|
meshJobParameterList.append(param)
|
||||||
param = MESHJOB.MeshJobParameter(name="NbIteration",value="3")
|
param = MESHJOB.MeshJobParameter(name="NbIteration",value="3")
|
||||||
meshJobParameterList.append(param)
|
meshJobParameterList.append(param)
|
||||||
@ -174,7 +174,7 @@ if jobid<0:
|
|||||||
msg = component.getLastErrorMessage()
|
msg = component.getLastErrorMessage()
|
||||||
print "ERR: %s"%msg
|
print "ERR: %s"%msg
|
||||||
sys.exit(1)
|
sys.exit(1)
|
||||||
|
|
||||||
created = False
|
created = False
|
||||||
nbiter = 0
|
nbiter = 0
|
||||||
while not created:
|
while not created:
|
||||||
@ -217,11 +217,11 @@ while not ended:
|
|||||||
ended=True
|
ended=True
|
||||||
time.sleep(0.5)
|
time.sleep(0.5)
|
||||||
nbiter+=1
|
nbiter+=1
|
||||||
|
|
||||||
if state not in end_states:
|
if state not in end_states:
|
||||||
print "ERR: jobid = "+str(jobid)+" ended abnormally with state="+str(state)
|
print "ERR: jobid = "+str(jobid)+" ended abnormally with state="+str(state)
|
||||||
msg = component.getLastErrorMessage()
|
msg = component.getLastErrorMessage()
|
||||||
print "ERR: %s"%msg
|
print "ERR: %s"%msg
|
||||||
else:
|
else:
|
||||||
print "OK: jobid = "+str(jobid)+" ended with state="+str(state)
|
print "OK: jobid = "+str(jobid)+" ended with state="+str(state)
|
||||||
meshJobResults = component.finalize(jobid)
|
meshJobResults = component.finalize(jobid)
|
||||||
|
Loading…
Reference in New Issue
Block a user