ADAMS用户子程序23.docx
《ADAMS用户子程序23.docx》由会员分享,可在线阅读,更多相关《ADAMS用户子程序23.docx(31页珍藏版)》请在冰点文库上搜索。
ADAMS用户子程序23
第9章ADAMS用户子程序
本章对ADAMS用户子程序做了简要介绍,着重介绍了CONSUB、GFOSUB和REQSUB的利用方式,和在用户子程序中两个最经常使用的功能子程序SYSARY和SYSFNC的利用情形。
通过本章的学习,读者将具有大体的开发用户子程序的能力。
ADAMS用户子程序简介
一样情形下,ADAMS的大部份功能能够通过函数表达式完成,函数表达式很容易操作,因为没必要编译或连接程序,而且ADAMS/Solver还会实时地提供函数表达式。
但函数表达式提供的只是有限的编程结构,因此有些复杂的情形,专门是涉及到一些逻辑表达,用函数表达式那么很难表达出来。
因此在需要采纳一些ADAMS没有提供的特殊函数时,能够采纳用户子程序。
用户子程序更具有通用性,能够利用编程语言来概念模型元素或特定的输出。
用户能够将函数表达式写成子程序的形式并将其与ADAMS/View连接,它具有函数表达式所没有的通用性和灵活性。
子程序利用通用程序设计语言(FORTRAN或C)的功能来概念ADAMS/View不能提供的函数,并使之依照需要而量身设计。
通过连接用户子程序,可不能失去ADAMS/View的任何功效,也可不能降低仿真速度。
当显现以下情形时,通常会利用到用户子程序:
(1)数学函数很难表达。
(2)需要概念多用户利用的函数。
(3)GSE和UCON声明时,需要用户子程序。
(4)需要操纵复杂仿真运行时,和需要作决策逻辑时。
利用用户子程序时要警惕,因为不正确的用户子程序会很难调试。
用户子程序的种类
依照用户子程序的功能,能够将它们分为三类:
(1)DriverSubroutine——驱动子程序
(2)EvaluationSubroutines——计算子程序
(3)Restartsubroutines——重启子程序
1.驱动子程序(DriverSubroutine)
驱动子程序(DriverSubroutine)--CONSUB--用来驱动ADAMS/Solver。
如此ADAMS/Solver在仿真时可更进一步地完成对模型的分析和修改的自动化工作。
CONSUB发出request(请求),regulate(调整),和varysimulations(改变仿真)的命令,并通过作出的交互式命令来修改数据,或进行不同的分析。
大多数运行ADAMS/Solver的情形都是交互式,或是以批处置的形式,一次只涉及到单个的分析。
利用CONSUB,能够完成对数据的动态分析,改变前提条件,并重复动态分析。
2.计算子程序(EvaluationSubroutines)
计算子程序(EvaluationSubroutines)为用户自概念。
ADAMS/Solver可写子程序来对某些非标准的或复杂的计算式计算其数值。
计算子程序(EvaluationSubroutine)的程序名和功能如表9-1所示。
表9-1计算子程序(EvaluationSubroutine)的程序名和功能
子程序
功能
COUSUB,CONXX,COUXX2
定义用户自定义的COUPLER
CURSUB
计算曲线坐标以及CURVE的导数
DIFSUB
计算DIFF的微分方程值
DMPSUB
计算FLEX_BODY的模型的阻尼比
FIESUB
对FIELD计算力和力矩以及它们的导数
GFOSUB
对GFORCE计算数值
GSE_DERIV
GSE_UPDATE
GSE_OUTPUT
GSE_SAMP
用GSE来计算当前状态和输出的偏导数值
MFOSUB
对MFORCE计算模型值
MOTSUB
对MOTION计算绞点位移,速度和加速度
REQSUB
对REQUEST计算输出值
SENSUB
对SENSOR计算感应值
SFOSUB
对SFORCE计算力的大小
TIRSUB
对于轮胎接触,定义三个力和三个力矩
UCOSUB
对UCON计算约束值和其导数
VARSUB
对VARIABLE计算其代数值
VFOSUB
对VFOSUB计算力的分量
VTOSUB
对VTORUE计算力矩的分量
3.重启子程序(RestartSubroutines)
重启子程序(Restartsubroutines)由一对子程序组成,SAVESUB和RELSUB。
它们能够保留和从头加载子程序运行进程中的某些状态变量,这些状态变量是那些相关的用户子程序在从头启动或进行某些变量初始化时所必需的数据。
若是在用户子程序之间彼此调历时,需要利用它们在子程序内部保留数据。
若是没有利用RELSUB和SAVSUB,在保留仿真文件时,内部数据就会丢失。
尽管SAVE命令可将模型和仿真数据保留到文件中去,而且能够通过利用RELOAD命令从头调入保留文件,并能够从该保留点从头启动仿真。
但SAVE和RELOAD不可能对用户子程序的内部数据进行特殊操作,在RELOAD命令以后,ADAMS/Solver会从仿真流程中断点继续挪用用户子程序,但用户子程序中某些感爱好的内部变量却没有取得保留。
例如,假设SFOSUB子程序中力的系数是一个内部状态变量,若是打算将第一次挪用SFOSUB子程序时所计算的力的系数保留以作尔后利用,假设用“SAVE”和“RELOAD”时会产生数据丢失。
可用SAVSUB将计算出来的系数保留在文件中并用RELSUB从头调入它们,或力仅仅用RELSUB来从头计算系数。
重启子程序(RestartSubroutine)的程序名和功能如表9-2所示。
表9-2重启子程序(RestartSubroutine)的程序名和功能
子程序
功能
RELSUB
加载能使用户子程序重新启动的信息
SAVSUB
保存以后能重新启动用户子程序的信息
子程序的利用
相关于ADAMS/View来讲,用户概念子程序有两个任务:
输入和输出。
输入确实是在相应的命令或状态,或在说明当前系统状态的计算结果中,提供给ADAMS/View的相关信息。
输出确实是从ADAMS/View中取得的相关信息。
1.声明浮点变量
为了保证数值在子程序之间或ADAMS/Solver和子程序之间能够正确地传递,需要声明浮点变量,就像在ADAMS/Solver中作的声明一样。
在UNIX和Windows机械上,ADAMS/Solver利用双精度浮点变量。
因为未声明的浮点变量通常都是单精度的(如REAL),因此应当明确声明所有的浮点变量都是双精度的。
2.参数的利用
ADAMS/View会从FUNCTION=USER()的表达式中提供给用户子程序参数值。
例如,若是你利用FUNTION=,,,ADAMS/View通过一个包括,,的PAR数组参数,和通过一个值为3的NPAR参数传递这些数值。
通过利用这些功能使得用户子程序加倍灵活。
例如,若是计算需要marker101和marker102的距离,能够将这些标志符直接写进用户子程序。
3.幸免不持续
在运行表达式中,当利用子程序来概念运动,传感器,力,或模型中的状态平稳方程时,应当保证这些函数是持续的。
不持续的函数很难处置,因为大多数数学理论都是假定系统方程是持续的。
若是违背了该规那么,ADAMS/Solver就会得出出人意料的结果。
当利用IF声明,将分段函数连接起来时,常常会产生不持续函数。
为了保证函数是持续的,在利用该类型的函数时,必然要警惕。
4.创建用户子程序
为了创建自己的用户子程序,ADAMS提供了子程序模板并将它们放在安装目录install_dir/adams/solver/usersubs中。
子程序不能以C语言为模板。
若是需要一个C语言的子程序,必需通过修改FORTRAN文件来创建它,或利用FORTRAN模板作为向导,创建自己的C语言格式子程序。
创建用户子程序的步骤:
(1)决定需要创建什么样的用户子程序。
例如,若是有GFORCE的声明,能够创建GFOSUB的用户子程序。
(2)决定要计算什么,需要什么输入参数。
(3)将适合的用户子程序模板从安装目录拷贝到当前目录。
模板目录中包括了要利用的所有子程序模板。
(4)利用文字编辑器来观察用户子程序模板。
(5)按需要修改用户子程序。
从用户子程序中挪用功能子程序,或其他FORTRAN或C语言子程序。
(6)保留用户子程序。
因为可能对不同的模型会利用相同的子程序,因此最好给文件起一个容易区分的名字。
5.挪用用户子程序
能够通过利用声明或命令来挪用用户子程序。
通过利用前面概念的用户子程序的名字来让ADAMS/Solver明白挪用哪个子程序。
也能够利用子程序来概念一些模型元素。
能挪用用户子程序的声明或命令如表9-3所示。
表9-3挪用用户子程序的声明或命令
要调用的子程序
使用的声明/命令
CONSUB
CONTROL
COUSUB,COUXX,COUXX2
COUPLER
CURSUB
CURVE
DIFSUB
DIFF
FIESUB
FIELD
GFOSUB
GFORCE
GSE_DERIV,GSE_UPDATE,
GSE_OUTPUT,GSE_SAMP
GSE
MOTSUB
MOTION
RELSUB
RELOAD
REQSUB
REQUEST
SAVSUB
SAVE
SENSUB
SENSOR
SFOSUB
SFORCE
TIRSUB
TIRE
UCOSUB
UCON
VARSUB
VARIABLE
VFOSUB
VFORCE
VTOSUB
VTORQUE
能够从用户子程序中挪用功能子程序。
这些子程序的功能就像是在用户的数据和用户利用的用户子程序的接口一样。
例如,在driveruser——writtensubroutine(驱动用户子程序)中,能够利用control,access功能子程序。
从evaluationuser——writtensubroutines(计算用户子程序)中,也能够挪用access,function,和某些情形下setup函数。
换句话说,能够从上面任何一个用户子程序中挪用access和function函数,但用户只能从driversubroutine中挪用control函数,从某个evaluationsubroutines中挪用setup函数。
6.编译,连接和运行库
在写完定制的子程序后,必需要将它们编译并连接到ADAMS以创建到ADAMS/Solver的用户库文件中去。
然后,能够连同该库与ADAMS/Solver一同运行。
必需有一个FORTRAN编译器,因为ADAMS本身不提供编译器,由用户子程序生成动态连接库的详细进程参见节后半部份的介绍。
9.2经常使用ADAMS用户子程序简介
利用GFOSUB用户子程序实例
为了使读者对用户子程序有一个直观印象,本节第一给作声明和挪用GFOSUB子程序的例子,通过与GFORCE函数表达式的对照,说明利用用户子程序的必要性。
有关GFOSUB用户子程序的更详细内容,将在末节进行介绍。
另外,在节的结尾部份提供了GFOSUB用户子程序的具体工程应用实例。
现假定有如下一个GFORCE函数表达式的声明,其函数表达式概念了小球和斜面之间的某种彼此作使劲关系(此处彼此作使劲不必然有确切的物理含义,仅为了说明GFORCE的概念进程),包括力矢量和力矩矢量。
如以下图所示,为了在GFORCE中描述这种彼此作使劲关系,在小球球心上概念了标架Mark_I(ID为2001),在斜面上概念了标架Mark_R(ID为2003),同时为了确信小球对斜面的反作使劲点的位置,生成与标架Mark_I时刻重叠的标架Mark_J(ID为2002),Mark_J隶属于斜面。
于是能够利用GFORCE函数表达式的声明,如下面所示(该GFORCE自身的ID为100):
GFORCE/,100I=2001,JFLOAT=2002,RM=2003,
FX=-*VX(2001,2003,2003)
FY=-*VY(2001,2003,2003)
FZ=-*VZ(2001,2003,2003)
TX=-*WX(2001,2003,2003)
TY=-*WY(2001,2003,2003)
TZ=-*WZ(2001,2003,2003)
若是力和力矩的表达比较冗长,那么能够利用GFOSUB用户子程序来代替GFORCE声明。
和,用下面语句挪用已创建好的GFOSUB子程序,并向其传递参数。
GFORCE/,100I=2001,JFLOAT=2002,RM=2003,
FUNCTION=USER,,2001,2003,2003)
GFOSUB用户子程序的程序体创建如下:
SUBROUTINEGFOSUB(ID,TIME,PAR,NPAR,DFLAG,
&IFLAG,RESULT)
=======================概念与声明===================
—————————————外部变量概念——————————
INTEGERID
DOUBLEPRECISIONTIME
DOUBLEPRECISIONPAR(*)
INTEGERNPAR
LOGICALDFLAG
LOGICALIFLAG
DOUBLEPRECISIONRESULT(6)
ID标志号,在内部程序中挪用
TIME仿真时刻
PAR不定维的数组,用以向程序传递参数,本例中维数为5,别离为:
PAR
(1)=
PAR
(2)=
PAR(3)=2001
PAR(4)=2002
PAR(5)=2003
NPARPAR数组的维数,本例中NPAR=5
DFLAG积分标志位,
IFLAG初始标志位
RESULT返回的程序值,每一次挪用能够返回六个值,本例中:
RESULT
(1)为FX的值
RESULT
(2)为FY的值
RESULT(3)为FZ的值
RESULT(4)为TX的值
RESULT(5)为TY的值
RESULT(6)为TZ的值
———————————本地变量和参数概念—————————
DOUBLEPRECISIONFCT,TCR,VEL(6)
INTEGERIPAR(3),IM,JM,RM,NSTATES
LOGICALERRFLG
========================可执行代码=====================
FCT=PAR
(1)
TCR=PAR
(2)
IM=PAR(3)
JM=PAR(4)
RM=PAR(5)
……
挪用SYSARY子程序取得计算信息:
若是变量IFLAG的值为true,那么将子程序初始化。
.
……
———————将标架的移动和转动速度值赋给VEL数组————————
IPAR
(1)=IM
IPAR
(2)=JM
IPAR(3)=RM
CALLSYSARY(’VEL’,IPAR,3,VEL,NSTATES,ERRFLG)
————————通过ERRMES检查SYSARY挪用成效————————
……
CALLERRMES(ERRFLG,’ErrorcallingSYSARYforVEL’,ID,’STOP’)
——————————返回GFORCE的计算结果———————————
RESULT
(1)=-FCT*VEL
(1)
RESULT
(2)=-FCT*VEL
(2)
RESULT(3)=-FCT*VEL(3)
RESULT(4)=-TCR*VEL(4)
RESULT(5)=-TCR*VEL(5)
RESULT(6)=-TCR*VEL(6)
RETURN
END
经常使用用户概念子程序简介
下面给出了几个经常使用用户概念子程序的简介。
对每一个子程序,都提供了概念、例子、相关说明等等。
1.CONSUB用户子程序
概念:
CONSUB驱动子程序用于驱动ADAMS/Solver。
只能通过交互式命令CONTROL激活CONSUB,而别的用户子程序那么不能挪用CONSUB。
挪用:
相应的挪用命令为:
CONTROL/[FUNCTION=USER(r1[,…,r30])[\]]
[[]]中的内容表示是可选的。
输入参数组成:
CONSUB用户子程序的输入参数组成为:
SUBROUTINECONSUB(par,npar)
输入参数说明:
npar——整型变量,其值为par数组的维数。
par——双精度常数数组,按顺序匹配CONTROL命令中的USER括号内的参数值。
要紧功能:
ADAMS/Solver将CONTROL中的常数以实数数组的形式传递给FUNCTION=USER()。
从CONSUB中,会挪用一些功能子程序,如SYSARY,SYSFNC或AKISPL等,可实现以下要紧功能:
(1)MODIFY功能子程序以交互式的方式挪用,用来改变ADAMS/Solver的声明。
(2)挪用ANALYS功能子程序的目的确实是激活某一个ADAMS/Solver的分析子程序。
(3)挪用DATOUT功能子程序的目的确实是处置从ADAMS/Solver仿真的输出。
当CONSUB停止执行时,ADAMS/Solver会提示你利用其他命令。
若是程序的操纵权交给了CONSUB,那么输出的自动生成会停止,若是想处置输出,那么要挪用DATOUT功能子程序。
CONSUB子程序的结构:
下面给出CONSUB子程序的结构,从而能够看出该子程序是如何工作的。
SUBROUTINECONSUB(PAR,NPAR)
=======================概念与声明===================
—————————————外部变量概念——————————
INTEGERNPAR
DOUBLEPRECISIONPAR(*)
———————————本地变量和参数概念—————————
……
========================可执行代码=====================
————————————用户自己的程序代码—————————
……
RETURN
END
CONSUB子程序例如:
下面给出一个CONSUB子程序应用的例子,在该例中,第一对模型进行了一次静力学仿真(StaticSimulation),然后改变Part1的质量后,进行一次动力学仿真(DynamicSimulation),并输出每次仿真的结果。
第一,用交互式的命令激活CONSUB:
CONTROL/FUNCTION=USER(r1[,...,r30])
相应的CONSUB用户子程序为:
SUBROUTINECONSUB(PAR,NPAR)
=======================概念与声明===================
—————————————外部变量概念——————————
INTEGERNPAR
DOUBLEPRECISIONPAR(*)
———————————本地变量和参数概念—————————
CHARACTER*10ATYPE
CHARACTER*20TITLE
LOGICALERRFLG,INIFLG
CHARACTER*80COMMND,MESSGE
INTEGERSTATUS
DOUBLEPRECISIONDPZERO
PARAMETER(DPZERO=
========================可执行代码=====================
——————————第一进行一次静力学分析—————————
指明分析类型和这次分析的名称
ATYPE=’STATIC’
TITLE=’STATIC_2003’
INIFLG=.TRUE.
挪用功能子程序ANALYS进行静力学分析
CALLANALYS(ATYPE,TITLE,DPZERO,DPZERO,INIFLG,
&STATUS)
若是仿真中显现错误,那么挪用ERRMES功能子程序返回错误信息并终止仿真
ERRFLG=STATUS.NE.0
MESSGE=’ErrorcallingANALYSforSTATIC_1.’
CALLERRMES(ERRFLG,MESSGE,STATUS,’STOP’)
挪用DATOUT功能子程序输出分析数据
CALLDATOUT(STATUS)
挪用MODIFY功能子程序改变PART/1的质量
COMMND=’PART/1,MASS=100’
CALLMODIFY(COMMND,STATUS)
指明分析类型和分析的名称进行动力学分析
ATYPE=’DYNAMIC’
TITLE=’DYNAMIC_2003’
INIFLG=.TURE.
CALLANALYS(ATYPE,TITLE,DPZERO,DPZERO,INIFLG,
&STATUS)
ERRFLG=STATUS.NE.0
MESSGE=’ErrorcallingANALYSforSTATIC_2.’
CALLERRMES(ERRFLG,MESSGE,STATUS,’STOP’)
CALLDATOUT(STATUS)
RETURN
END
2.GFOSUB用户子程序
概念:
GFOSUB计算子程序用于计算GFORCE声明中的变量值。
在GFORCE的函数表达式太复杂或计算流程需要作特殊操纵时能够利用GFOSUB用户子程序。
挪用:
相应的挪用命令为
GFOCE/id,I=id,JFLOAT=id,RM=id
FUNCTION=USER(r1[,…,r30])
([])中的内容表示是可选的。
输入参数组成:
GFOSUB用户子程序的输入参数组成为:
SUBROUTINEGFOSUB(id,time,par,npar,dflag,iflag,result)
输入参数说明:
dflag——逻辑型变量;当ADAMS/Solver挪用GFOSUB子程序求解某些特定的偏微分方程时其值为ture,不然设为false。
Id——整数变量;用于提供给GFORCE声明其自身的标志符。
当需要GFOSUB的信息时,ADAMS/Solver可自动识别相应的函数声明中的其他信息(如par参数等)。
Iflag——逻辑型变量;当需要从GFOSUB中取得函数相关信息时,ADAMS/Solver将其设置为true;当iflag值为false时,那么计算用户概念的表达式的值。
Npar——整型变量;用于指明在USER括号中利用的实参数量,也确实是GFOSUB子程序中数组par的维数。
Par——双精度的常数数组;按顺序寄存USER括号中实参的数值。
Time——双精度变量;传递给ADAMS/Solver当前的仿真时刻。
子程序的返回结果:
双精度数组,返回GFORCE组成的六个值。
GFOSUB子程序的结构:
SUBROUTINE