File: correctvel.f

package info (click to toggle)
calculix-ccx 2.11-1
  • links: PTS, VCS
  • area: main
  • in suites: buster, stretch
  • size: 10,188 kB
  • sloc: fortran: 115,312; ansic: 34,480; sh: 374; makefile: 35; perl: 15
file content (72 lines) | stat: -rw-r--r-- 2,086 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
!
!     CalculiX - A 3-dimensional finite element program
!              Copyright (C) 1998-2015 Guido Dhondt
!
!     This program is free software; you can redistribute it and/or
!     modify it under the terms of the GNU General Public License as
!     published by the Free Software Foundation(version 2);
!     
!
!     This program is distributed in the hope that it will be useful,
!     but WITHOUT ANY WARRANTY; without even the implied warranty of 
!     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 
!     GNU General Public License for more details.
!
!     You should have received a copy of the GNU General Public License
!     along with this program; if not, write to the Free Software
!     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
!
      subroutine correctvel(hel,adv,vfa,ipnei,area,bv,xxn,neifa,
     &  lakonf,nef,neq)
!
!     correction of the velocity at the element centers due to the
!     pressure change (balance of mass)
!
!     the solution is stored in field bv.
!
      implicit none
!
      character*8 lakonf(*)
!
      integer i,j,k,nef,jdof1,indexf,ipnei(*),neifa(*),ifa,
     &  neq,numfaces
!
      real*8 bv(neq,3),hel(3,*),adv(*),xxn(3,*),area(*),vfa(0:5,*)
!
c$omp parallel default(none)
c$omp& shared(nef,bv,ipnei,lakonf,neifa,vfa,area,xxn,hel,adv)
c$omp& private(i,jdof1,k,indexf,numfaces,j,ifa)
c$omp do
      do i=1,nef
!
         jdof1=i
         do k=1,3
            bv(jdof1,k)=0.d0
         enddo
         indexf=ipnei(i)
!
         if(lakonf(i)(4:4).eq.'8') then
            numfaces=6
         elseif(lakonf(i)(4:4).eq.'6') then
            numfaces=5
         else
            numfaces=4
         endif
         do j=1,numfaces
            indexf=indexf+1
            ifa=neifa(indexf)
            do k=1,3
               bv(jdof1,k)=bv(jdof1,k)
     &              +vfa(4,ifa)*area(ifa)*xxn(k,indexf)
            enddo
         enddo
!
         do k=1,3
            bv(jdof1,k)=(hel(k,jdof1)-bv(jdof1,k))/adv(jdof1)
         enddo
      enddo
c$omp end do
c$omp end parallel
!  
      return
      end