OpenRadioss 2025.1.11
OpenRadioss project
Loading...
Searching...
No Matches
nlocal_vel.F
Go to the documentation of this file.
1Copyright> OpenRadioss
2Copyright> Copyright (C) 1986-2025 Altair Engineering Inc.
3Copyright>
4Copyright> This program is free software: you can redistribute it and/or modify
5Copyright> it under the terms of the GNU Affero General Public License as published by
6Copyright> the Free Software Foundation, either version 3 of the License, or
7Copyright> (at your option) any later version.
8Copyright>
9Copyright> This program is distributed in the hope that it will be useful,
10Copyright> but WITHOUT ANY WARRANTY; without even the implied warranty of
11Copyright> MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12Copyright> GNU Affero General Public License for more details.
13Copyright>
14Copyright> You should have received a copy of the GNU Affero General Public License
15Copyright> along with this program. If not, see <https://www.gnu.org/licenses/>.
16Copyright>
17Copyright>
18Copyright> Commercial Alternative: Altair Radioss Software
19Copyright>
20Copyright> As an alternative to this open-source version, Altair also offers Altair Radioss
21Copyright> software under a commercial license. Contact Altair to discuss further if the
22Copyright> commercial version may interest you: https://www.altair.com/radioss/.
23!||====================================================================
24!|| nlocal_vel ../engine/source/assembly/nlocal_vel.F
25!||--- called by ------------------------------------------------------
26!|| resol ../engine/source/engine/resol.F
27!||--- uses -----------------------------------------------------
28!|| nlocal_reg_mod ../common_source/modules/nlocal_reg_mod.F
29!||====================================================================
30 SUBROUTINE nlocal_vel(NLOC_DMG, NODFT ,NODLT)
31C-----------------------------------------------
32C M o d u l e s
33C-----------------------------------------------
35C-----------------------------------------------------------------------
36C I m p l i c i t T y p e s
37C-----------------------------------------------
38#include "implicit_f.inc"
39C-----------------------------------------------
40C C o m m o n B l o c k s
41C-----------------------------------------------
42#include "com08_c.inc"
43C-----------------------------------------------
44C D u m m y A r g u m e n t s
45C-----------------------------------------------
46 INTEGER NODFT, NODLT
47 TYPE(nlocal_str_), TARGET :: NLOC_DMG
48C-----------------------------------------------
49C L o c a l V a r i a b l e s
50C-----------------------------------------------
51 INTEGER N,NPOS,NDDL
52 my_real, POINTER, DIMENSION(:) ::
53 . vel,vel0,fnl
54C-----------------------------------------------
55c calcul vitesse de la variable non locale
56c=======================================================================c=======================================================================
57 ! Recovering velocities and forces
58 vel => nloc_dmg%VNL(1:nloc_dmg%L_NLOC)
59 vel0 => nloc_dmg%VNL_OLD(1:nloc_dmg%L_NLOC)
60 fnl => nloc_dmg%FNL(1:nloc_dmg%L_NLOC,1)
61#include "vectorize.inc"
62 ! Loop over current nodes
63 DO n = nodft,nodlt
64 ! Position of the first additional dof
65 npos = nloc_dmg%POSI(n)
66 ! number of additional degrees of freedom
67 nddl = nloc_dmg%POSI(n+1) - npos
68 ! Save old values of velocities
69 vel0(npos:npos+nddl-1) = vel(npos:npos+nddl-1)
70 ! Updating velocities and forces
71 vel(npos:npos+nddl-1) = vel(npos:npos+nddl-1) + dt12*fnl(npos:npos+nddl-1)
72 ! Setting the forces to zero
73 fnl(npos:npos+nddl-1) = zero
74 ENDDO
75c-----------
76 RETURN
77 END
78
#define my_real
Definition cppsort.cpp:32
subroutine nlocal_vel(nloc_dmg, nodft, nodlt)
Definition nlocal_vel.F:31