Abaqus Python 脚本和真正简单的 GUI 界面语法问题

问题描述 投票:0回答:1

我已经在 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
python user-interface abaqus
1个回答
0
投票

根据我的经验,为了使脚本正常工作,您缺少以下模块导入:

from abaqus import *
from abaqusConstants import *
© www.soinside.com 2019 - 2024. All rights reserved.