OpenRadioss 2025.1.11
OpenRadioss project
Loading...
Searching...
No Matches
spmd_h3d_quad_off.F File Reference
#include "implicit_f.inc"
#include "com01_c.inc"
#include "com04_c.inc"
#include "param_c.inc"
#include "scr17_c.inc"

Go to the source code of this file.

Functions/Subroutines

subroutine h3d_quad_off (elbuf_tab, iparg, ixq, quad_scalar, id_elem, ipart, ipartq)

Function/Subroutine Documentation

◆ h3d_quad_off()

subroutine h3d_quad_off ( type (elbuf_struct_), dimension(ngroup), intent(in), target elbuf_tab,
integer, dimension(nparg,ngroup), intent(in) iparg,
integer, dimension(nixq,numelq), intent(in) ixq,
dimension(numelq), intent(inout) quad_scalar,
integer, dimension(numelq), intent(inout) id_elem,
integer, dimension(lipart1,npart+nthpart), intent(in) ipart,
integer, dimension(numelq), intent(in) ipartq )

Definition at line 31 of file spmd_h3d_quad_off.F.

33C----------------------------------------------
34C M o d u l e s
35C-----------------------------------------------
36 USE elbufdef_mod
37 use element_mod , only : nixq
38C-----------------------------------------------
39C I m p l i c i t T y p e s
40C-----------------------------------------------
41#include "implicit_f.inc"
42C-----------------------------------------------
43C C o m m o n B l o c k s
44C-----------------------------------------------
45#include "com01_c.inc"
46#include "com04_c.inc"
47#include "param_c.inc"
48#include "scr17_c.inc"
49C-----------------------------------------------
50C D u m m y A r g u m e n t s
51C-----------------------------------------------
52 TYPE (ELBUF_STRUCT_), TARGET, DIMENSION(NGROUP), INTENT(IN) :: ELBUF_TAB
53 INTEGER, INTENT(IN) :: IPARG(NPARG,NGROUP),IXQ(NIXQ,NUMELQ),IPART(LIPART1,NPART+NTHPART)
54 INTEGER, INTENT(IN) :: IPARTQ(NUMELQ)
55 INTEGER, INTENT(INOUT) :: ID_ELEM(NUMELQ)
56 my_real, INTENT(INOUT) :: quad_scalar(numelq)
57
58C-----------------------------------------------
59C L O C A L V A R I A B L E S
60C-----------------------------------------------
61 INTEGER ITY,MLW,NEL,NFT,NG,I
62C-----------------------------------------------
63c
64 DO ng=1,ngroup
65 mlw =iparg(1,ng)
66 nel =iparg(2,ng)
67 ity =iparg(5,ng)
68 nft =iparg(3,ng)
69c
70 IF(ity == 2)THEN
71 DO i=1,nel
72 id_elem(nft+i) = ixq(nixq,nft+i)
73 ENDDO
74 ENDIF
75c
76 IF(ity == 2 )THEN
77 IF(mlw == 0 .OR. mlw == 13)THEN
78 DO i=1,nel
79 quad_scalar(nft+i) = one
80 ENDDO
81 ELSE
82 DO i=1,nel
83 IF(ipart(10,ipartq(nft+i)) /=0 .AND. nint(min(elbuf_tab(ng)%GBUF%OFF(i),one)) /= one) THEN
84 quad_scalar(nft+i) = zero
85 ELSE
86 quad_scalar(nft+i) = nint(min(elbuf_tab(ng)%GBUF%OFF(i),one))
87 ENDIF
88 ENDDO
89 ENDIF
90 ENDIF
91 ENDDO
92 RETURN
#define my_real
Definition cppsort.cpp:32
#define min(a, b)
Definition macros.h:20