Welcome, Guest
Username: Password: Remember me

TOPIC: Porosity - Not working

Porosity - Not working 2 years 1 month ago #41182

  • ssiddi7
  • ssiddi7's Avatar
  • OFFLINE
  • Senior Boarder
  • Posts: 66
Hi Pham,

I am trying to understand the Fortran file of both porosity and drag force. In the file, which value is indication the porosity here below? Is it 0.2 value indication the porosity?
CALL OS( 'X=C ' , POROS , POROS , POROS , 1.D0 )
!
!
!
DO IELEM = 1 , NELEM
!
XX1 = ( X(IKLE%I(IELEM) )+
& X(IKLE%I(IELEM+NELMAX) )+
& X(IKLE%I(IELEM+2*NELMAX) ))/3.D0
YY1 = ( Y(IKLE%I(IELEM) )+
& Y(IKLE%I(IELEM+NELMAX) )+
& Y(IKLE%I(IELEM+2*NELMAX) ))/3.D0
!
IF(INPOLY(XX1,YY1,XSOM1,YSOM1,NSOM1)
& .OR. INPOLY(XX1,YY1,XSOM2,YSOM2,NSOM2)) THEN
POROS%R(IELEM) = 0.2D0 * ( 1.D0 + ABS(XX1/50.D0) )
ENDIF
!
ENDDO
!
The administrator has disabled public write access.

Porosity - Not working 2 years 1 month ago #41183

  • ssiddi7
  • ssiddi7's Avatar
  • OFFLINE
  • Senior Boarder
  • Posts: 66
Again, in the drag force fortran file, I am not getting the drag force and porosity value here. If you look at below, what is Por= 19.D0/20.D0 means? if it is porosity then where is drag force value here? Is it 19/20= 0.95 porosity?

POR=19.D0/20.D0
!
DO IELEM = 1 , NELEM
!
XX1 = ( X(IKLE%I(IELEM) )+
& X(IKLE%I(IELEM+NELMAX) )+
& X(IKLE%I(IELEM+2*NELMAX) ))/3.D0
YY1 = ( Y(IKLE%I(IELEM) )+
& Y(IKLE%I(IELEM+NELMAX) )+
& Y(IKLE%I(IELEM+2*NELMAX) ))/3.D0
!
IF(INPOLY(XX1,YY1,XSOM1,YSOM1,NSOM1)
& .OR. INPOLY(XX1,YY1,XSOM2,YSOM2,NSOM2)) THEN
IF(XX1.GE.-10.D0.AND.XX1.LE.10.D0) THEN
POROS%R(IELEM) = POR
ELSEIF(XX1.LT.-10.D0) THEN
POROS%R(IELEM) = POR - (1.D0-POR) * (XX1+10.D0) / 10.D0
ELSEIF(XX1.GT.10.D0) THEN
POROS%R(IELEM) = POR + (1.D0-POR) * (XX1-10.D0) / 10.D0
ENDIF
ENDIF
!
ENDDO ! IELEM
The administrator has disabled public write access.

Porosity - Not working 2 years 1 month ago #41191

  • pham
  • pham's Avatar
  • OFFLINE
  • Administrator
  • Posts: 1549
  • Thank you received: 598
Hello,

I have not understood your question "which value is indication the porosity here below?".

Anyway, if you want to modify Fortran files, I strongly recommend you to learn Fortran and read the developer guide available here after:
wiki.opentelemac.org/doku.php?id=documentation_latest
Not too much time to explain line by line what is implemented in simple Fortan files.

Porosity field is stored in local variable POROS (argument of this subroutine). It is defined here depending on the abscissa of the element (here to be accurate, the center of gravity of the triangle):
- 19/20+1/20*(x-10)/10 or 19/20+1/20*(x+10)/10 or 19/20 and if inside a polygon, POR is a local variable of the subroutine.
- 0.2*(1+abs(x/50)) or 1 and if inside a polygon.

The drag force is not defined in the Fortran file dedicated to porosity (user_corpor) but in user_dragfo, stored in FUDRAG and FVDRAG that will be used for the source terms of equations.

Chi-Tuan
The administrator has disabled public write access.

Porosity - Not working 2 years 4 weeks ago #41210

  • ssiddi7
  • ssiddi7's Avatar
  • OFFLINE
  • Senior Boarder
  • Posts: 66
Thanks you for your reply. I am using the fortran subroutine for dragforce and I am using just one polygon point in the fortran file.
Each time I am getting the same error: "GRAGFO: Area of zone equal to zero"
Any idea why it can give this error? I am not sure where to work to fix this issue.

ITERATION 0 TIME: 0.0000 S
TELEMAC2D INITIALIZED
USING STREAMLINE VERSION 7.3 FOR CHARACTERISTICS
DRAGFO: AREA OF ZONE EQUAL TO ZERO
STOP 1

PLANTE: PROGRAM STOPPED AFTER AN ERROR
RETURNING EXIT CODE: 2
The administrator has disabled public write access.

Porosity - Not working 2 years 4 weeks ago #41211

  • c.coulet
  • c.coulet's Avatar
  • OFFLINE
  • Moderator
  • Posts: 3722
  • Thank you received: 1031
are you sure there is at least one element of your mesh fully inside the polygon?
Christophe
The administrator has disabled public write access.

Porosity - Not working 2 years 4 weeks ago #41212

  • ssiddi7
  • ssiddi7's Avatar
  • OFFLINE
  • Senior Boarder
  • Posts: 66
I am sure
The administrator has disabled public write access.

Porosity - Not working 2 years 4 weeks ago #41213

  • c.coulet
  • c.coulet's Avatar
  • OFFLINE
  • Moderator
  • Posts: 3722
  • Thank you received: 1031
could you post a screenshot or give the files?
Christophe
The administrator has disabled public write access.

Porosity - Not working 2 years 4 weeks ago #41214

  • ssiddi7
  • ssiddi7's Avatar
  • OFFLINE
  • Senior Boarder
  • Posts: 66
Hi, I added the fortran file here.

File Attachment:

File Name: user_corpor_2022-10-03.f
File Size: 5 KB
The administrator has disabled public write access.

Porosity - Not working 2 years 4 weeks ago #41215

  • c.coulet
  • c.coulet's Avatar
  • OFFLINE
  • Moderator
  • Posts: 3722
  • Thank you received: 1031
Ok

You define a new polygon but the old condition remains in the poros modification...
Christophe
The administrator has disabled public write access.

Porosity - Not working 2 years 4 weeks ago #41219

  • ssiddi7
  • ssiddi7's Avatar
  • OFFLINE
  • Senior Boarder
  • Posts: 66
Here I attached the BOTTOM. Let me know if you need any other files
The administrator has disabled public write access.
Moderators: pham

The open TELEMAC-MASCARET template for Joomla!2.5, the HTML 4 version.