我已经在 Abaqus 中成功运行 Python 脚本有一段时间了。
所以我很高兴找到真正简单的 GUI 构建器(RSGB),或者直到我尝试使用它为止!
我使用的内核脚本是一段成熟的代码,因此我认为它将是在 RSGB 中进行测试的主要候选者。
真正需要做的(或者我是这么认为的)是将小部件输入与内核函数中的变量相匹配。
但是由于一些无法解释的原因,Abaqus 声明我的函数声明行上有语法错误,看看你是否能发现它?
def setUp( modName, target, radMax, radMin, Vx, Vy, Vz, hght, wdth, zLen, numSphere ):
错误,
syntaxError:('无效语法',('.\RigidPyticle.py',22,86,'def setUp( modName, target, radMax, radMin, Vx, Vy, Vz, hght, wdth, zLen, numSphere ) '))
我应该补充一点,我已经检查了所有缩进,并且 GUI 发送的变量与内核函数中的变量相匹配。内核函数本身与使用 Abaqus CLI 运行时在 RSGB 框架之外运行良好的同一段代码
我错过了一些非常明显的东西吗?
(或者,正如我怀疑的那样,Abaqus 已经为我准备好了?)
部分内核代码列表,因为我无权透露全部:
# -*- coding: mbcs -*-
from part import *
from material import *
from section import *
from assembly import *
from step import *
from interaction import *
from load import *
from mesh import *
from optimization import *
from job import *
from sketch import *
from visualization import *
from connectorBehavior import *
import numpy as np
def setUp( modName, target, radMax, radMin, Vx, Vy, Vz, hght, wdth, zLen, numSphere ):
# Import target
mdb.openAuxMdb(target)
mdb.copyAuxMdbModel(fromName='Model-1', toName='Model-1')
mdb.copyAuxMdbModel(fromName='Model-1', toName='Model-1')
mdb.closeAuxMdb()
# Set up sphere material
mdb.models['Model-1'].Material(name='Silicon')
mdb.models['Model-1'].materials['Silicon'].Density(table=((2.33e-09, ), ))
mdb.models['Model-1'].materials['Silicon'].Elastic(table=((150000.0, 0.17), ))
mdb.models['Model-1'].HomogeneousSolidSection(material='Silicon', name='SphereSection', thickness=None)
# Set up spheres
for sph in range(1, numSphere):
sphName = 'Sphere-' + str(sph)
setName = 'SphereSet-' + str(sph)
rad = radMin + np.random.randint(radMax) * 0.1
cent = rad / 2.0
mdb.models['Model-1'].ConstrainedSketch(name='__profile__', sheetSize=5.0)
mdb.models['Model-1'].sketches['__profile__'].ConstructionLine(point1=(0.0, -2.5), point2=(0.0, 2.5))
mdb.models['Model-1'].sketches['__profile__'].FixedConstraint(entity=mdb.models['Model-1'].sketches['__profile__'].geometry[2])
mdb.models['Model-1'].sketches['__profile__'].ArcByCenterEnds(center=(0.0, 0.0), direction=COUNTERCLOCKWISE, point1=(0.0, -cent), point2=(0.0, cent))
mdb.models['Model-1'].Part(dimensionality=THREE_D, name=sphName, type=DISCRETE_RIGID_SURFACE)
mdb.models['Model-1'].parts[sphName].BaseShellRevolve(angle=360.0, flipRevolveDirection=OFF, sketch=mdb.models['Model-1'].sketches['__profile__'])
del mdb.models['Model-1'].sketches['__profile__']
# Mesh spheres
mdb.models['Model-1'].parts[sphName].setMeshControls(elemShape=QUAD, regions=mdb.models['Model-1'].parts[sphName].faces.getSequenceFromMask(('[#1 ]', ), ))
mdb.models['Model-1'].parts[sphName].seedPart(deviationFactor=0.1, minSizeFactor=0.1, size=0.33)
mdb.models['Model-1'].parts[sphName].generateMesh()
# Create set
mdb.models['Model-1'].parts[sphName].Set(faces=mdb.models['Model-1'].parts[sphName].faces.getSequenceFromMask(('[#1 ]', ), ), name=setName)
# Reference points & inertia
intName = 'Inertia-' + str(sph)
refPointName = 'RP-' + str(sph)
mdb.models['Model-1'].parts[sphName].ReferencePoint(point=(0.0, 0.0, 0.0))
mdb.models['Model-1'].parts[sphName].Set(name=refPointName, referencePoints=(mdb.models['Model-1'].parts[sphName].referencePoints[5], ))
mdb.models['Model-1'].parts[sphName].engineeringFeatures.PointMassInertia(alpha=0.0, composite=0.0, i11=6.59e-10, i22=6.59e-10, i33=6.59e-10, mass=9.8888e-10, name=intName, region=mdb.models['Model-1'].parts[sphName].sets[refPointName])
# Place spheres in assembly
# Sphere placement routine would be here
# Predefined velocity, rigid constraints
for vel in range(1, numSphere):
sphName = 'Sphere-' + str(vel)
setName = sphName + '.SphereSet-' + str(vel)
conName = 'Constraint-' + str(vel)
velName = 'RP-' + str(vel)
preFieldName = 'Predefined Field-' + str(vel)
mdb.models['Model-1'].RigidBody(bodyRegion=mdb.models['Model-1'].rootAssembly.sets[setName], name=conName, refPointRegion=Region(referencePoints=(mdb.models['Model-1'].rootAssembly.instances[sphName].referencePoints[5], )))
mdb.models['Model-1'].Velocity(distributionType=MAGNITUDE, field='', name=preFieldName, omega=0.0, region=mdb.models['Model-1'].rootAssembly.instances[sphName].sets[velName], velocity1=Vx, velocity2=Vy, velocity3=Vz)
# General contact algorithm
mdb.models['Model-1'].ContactProperty('IntProp-1')
mdb.models['Model-1'].interactionProperties['IntProp-1'].TangentialBehavior(formulation=FRICTIONLESS)
mdb.models['Model-1'].interactionProperties['IntProp-1'].NormalBehavior(allowSeparation=ON, constraintEnforcementMethod=DEFAULT, pressureOverclosure=HARD)
mdb.models['Model-1'].ContactExp(createStepName='Initial', name='Int-1')
mdb.models['Model-1'].interactions['Int-1'].contactPropertyAssignments.appendInStep(assignments=((GLOBAL, SELF, 'IntProp-1'), ), stepName='Initial')
# Explicit time step
mdb.models['Model-1'].ExplicitDynamicsStep(name='Step-1', previous='Initial', timePeriod=0.005)
mdb.models['Model-1'].interactions['Int-1'].includedPairs.setValuesInStep(stepName='Initial', useAllstar=ON)
return
根据我的经验,为了使脚本正常工作,您缺少以下模块导入:
from abaqus import *
from abaqusConstants import *