基于ABAQUS的VDLOAD子程序实现四轮小车移动

ABAQUS因其具有强大的子程序二次开发功能而倍受研究人员欢迎。VDLOAD子程序可以定义随时间和空间变化的载荷分布,可用于模拟汽车移动和激光冲击过程。

其子程序模板如下:

      subroutine vdload (
C Read only (unmodifiable)variables -
     1 nBlock, ndim, stepTime, totalTime,
     2 amplitude, curCoords, velocity, dirCos, jltyp, sname,
C Write only (modifiable) variable -
     1 value )
C
      include 'vaba_param.inc'
C
      dimension curCoords(nBlock,ndim), velocity(nBlock,ndim),
     1  dirCos(nBlock,ndim,ndim), value(nBlock)
      character*80 sname
C


      do 100 km = 1, nBlock
        user coding to define value


  100 continue


      return
      end

value(nblock)是用户自定义的载荷大小,是程序中最重要的参数。

ndim:坐标的方向数,1、2、和3分别表示三维空间中、全局坐标下的X、Y和Z三个坐标分量。

steptime:表示当前分析步时间值,若有多个分析步存在,则其变化为0—>step1time—>0—>step2time—>…….—>0—>stepntime

totaltime:表示当前时间值,从0开始逐渐增大。

curCoords(nblock, ndim):当前节点坐标。

以上是用户常用的参数及其含义。

本贴就以VDLOAD子程序实现生活中常见的四轮小车移动,程序相对简单,主要难点在于车轮的坐标控制,代码开源。

对于四轮小车而言,假设车轮与地面的接触区域为正方形,示意图如下。

基于ABAQUS的VDLOAD子程序实现四轮小车移动的图1

其中前后车轮间距为L1,并排车轮距离为L2。蓝色区域为加载区,加载区长度为a*a。在ABAQUS中建模时,路面为XY平面,坐标原点位于路面模型的顶点。本模型默认整车位于路面的正中央,路面的长和宽分别为30mm和10mm,路面长的方向为X方向,宽为Y方向。初始时刻车轮距路面边缘的距离分别为xm和ym。

先定义车身参数和运动参数。

!车身参数
L1 = 6
L2 = 3
a = 0.5
!运动参数
speed = 10000
t = steptime
distance = speed*steptime
!初始时刻车身距路面的距离
xm = 3
ym = 3

每个车轮对路面的压强为:

pressure = 2000

主程序:


do k=1, nblock
  !节点坐标
  x = curCoords(k,1)
  y = curCoords(k,2)
  !上面一排车轮施加载荷
  if (y >= ym .and. y <= ym+a)then
    !第一个轮子
    if (x >= xm+distance .and. x <= xm+distance+a) then
      value(k) = pressure
    !第二个轮子
    else if (x >= xm+distance+a+L1 .and. x <= xm+distance+a*2+L1) then
      value(k) = pressure
    else
      value(k) = 0.0
    end if
  !下面一排车轮
  elif (y >= ym+a+L2 .and. y <= ym+a*2+L2) then
    !第一个轮子
    if (x >= xm+distance .and. x <= xm+distance+a) then
      value(k) = pressure
    !第二个轮子
    else if (x >= xm+distance+a+L1 .and. x <= xm+distance+a*2+L1) then
      value(k) = pressure
    else
      value(k) = 0.0
    end if
  else
    value(k) = 0.0
  end if
end do

程序编写完毕,接下来就是在ABAQUS软件建模,模型相对简单,就是一个板材。构建的模型如下。

基于ABAQUS的VDLOAD子程序实现四轮小车移动的图2

完整的代码如下

      subroutine vdload (
C Read only (unmodifiable)variables -
     1 nBlock, ndim, stepTime, totalTime,
     2 amplitude, curCoords, velocity, dirCos, jltyp, sname,
C Write only (modifiable) variable -
     1 value )
C
      include 'vaba_param.inc'
C
      dimension curCoords(nBlock,ndim), velocity(nBlock,ndim),
     1  dirCos(nBlock,ndim,ndim), value(nBlock)
      character*80 sname
C


      !车身参数
      L1 = 6
      L2 = 3
      a = 0.5
      !运动参数
      speed = 10000
      t = steptime
      distance = speed*steptime
      !初始时刻车身距路面的距离
      xm = 3
      ym = 3
      pressure = 3000
      
      do k=1, nblock
      !节点坐标
      x = curCoords(k,1)
      y = curCoords(k,2)
      !上面一排车轮施加载荷
      if (y >= ym .and. y <= ym+a)then
        !第一个轮子
        if (x >= xm+distance .and. x <= xm+distance+a) then
          value(k) = pressure
        !第二个轮子
        else if (x >= xm+distance+a+L1 .and. x <= xm+distance+a*2+L1) then
          value(k) = pressure
        else
          value(k) = 0.0
        end if
      !下面一排车轮
      else if (y >= ym+a+L2 .and. y <= ym+a*2+L2) then
        !第一个轮子
        if (x >= xm+distance .and. x <= xm+distance+a) then
          value(k) = pressure
        !第二个轮子
        else if (x >= xm+distance+a+L1 .and. x <= xm+distance+a*2+L1) then
          value(k) = pressure
        else
          value(k) = 0.0
        end if
      else
        value(k) = 0.0
      end if
      
      end do


      return
      end

为了能够观察到塑性应变,对载荷进行更改为3000MPa。

下面是运行一段时间的结果。

基于ABAQUS的VDLOAD子程序实现四轮小车移动的图3

默认 最新
当前暂无评论,小编等你评论哦!
点赞 1 评论 收藏 3
关注