59 TYPE(t_region
) :: region
63 INTEGER ::
i,
j,
k, n1, n2
66 INTEGER :: ilev, lbound, bctype, distrib, flowmodel, gasmodel, indcp, indmol
67 INTEGER ::
ibeg,
iend,
jbeg,
jend,
kbeg, kend,
idir,
jdir,
kdir, i2d, noff
68 INTEGER :: icoff, ijcoff, ijkcd, ijkcd1, ijkcd2, ijkcb0, ijkcb1, ijknb
69 INTEGER :: inoff, ijnoff,
inode,
jnode, knode, indsvel, spaceorder
70 INTEGER :: aerocoeff, j2d
72 REAL(RFREAL) :: sgn, rhoa, rhoua, rhova, rhowa, rhoea, rhovrel(3), pa, &
73 mrate, tburn, rgas, ds, sv, limfac, limfac3, rvolref, &
74 eps2n, uinj, vinj, winj, vcont, rhl, rhr, qsl, qsr, vola, &
75 gam, ggm1, rl, rr, ul, ur, vl, vr, wl, wr, pl, pr, &
76 hl, hr, qsrl, qsrr, eps2(3), dvar(5), dvarm(5), dvarp(5), &
77 deltl(5), deltr(5), sf(3)
78 REAL(RFREAL) :: pref, rref, vref, rcpref
79 REAL(RFREAL),
POINTER :: cv(:,:), dv(:,:), gv(:,:),
rhs(:,:), vol(:)
80 REAL(RFREAL),
POINTER :: sface(:,:), svel(:), vals(:,:)
83 REAL(RFREAL) :: muscl3, af, bf, eps
88 muscl3(af,bf,eps) = (bf*(2._rfreal*af*af+eps)+af*(bf*bf+2._rfreal*eps))/ &
89 (2._rfreal*af*af+2._rfreal*bf*bf-af*bf+ &
90 3._rfreal*eps+1.e-30_rfreal)
93 'RFLO_RoeFluxPatch.F90' )
97 ilev = region%currLevel
105 bctype =
patch%bcType
107 distrib =
patch%mixt%distrib
108 flowmodel = region%mixtInput%flowModel
109 gasmodel = region%mixtInput%gasModel
110 spaceorder = region%mixtInput%spaceOrder
111 indcp = region%levels(ilev)%mixt%indCp
112 indmol = region%levels(ilev)%mixt%indMol
113 indsvel = region%levels(ilev)%grid%indSvel
114 limfac = region%mixtInput%limFac
116 cv => region%levels(ilev)%mixt%cv
117 dv => region%levels(ilev)%mixt%dv
118 gv => region%levels(ilev)%mixt%gv
119 vol => region%levels(ilev)%grid%vol
120 rhs => region%levels(ilev)%mixt%rhs
121 vals =>
patch%mixt%vals
123 aerocoeff = region%global%aeroCoeffs
124 pref = region%global%refPressure
125 rref = region%global%refDensity
126 vref = region%global%refVelocity
128 rcpref = 2.0_rfreal/(rref*vref*vref)
136 IF (lbound==2 .OR. lbound==4 .OR. lbound==6)
THEN
145 IF (lbound==1 .OR. lbound==2)
THEN
146 sface => region%levels(ilev)%grid%si
147 svel => region%levels(ilev)%grid%siVel
148 ELSE IF (lbound==3 .OR. lbound==4)
THEN
149 sface => region%levels(ilev)%grid%sj
150 svel => region%levels(ilev)%grid%sjVel
151 ELSE IF (lbound==5 .OR. lbound==6)
THEN
152 sface => region%levels(ilev)%grid%sk
153 svel => region%levels(ilev)%grid%skVel
158 limfac3 = limfac*limfac*limfac
159 rvolref = 1._rfreal/region%global%limVolRef**1.5_rfreal
160 eps2(1) = limfac3*region%global%limRef(1)*region%global%limRef(1)*rvolref
161 eps2(2) = limfac3*region%global%limRef(2)*region%global%limRef(2)*rvolref
162 eps2(3) = limfac3*region%global%limRef(3)*region%global%limRef(3)*rvolref
167 IF (bctype>=bc_slipwall .AND. bctype<=bc_slipwall+bc_range)
THEN
172 ijkcb0 = indijk(
i ,
j ,
k ,icoff,ijcoff)
175 pa = 0.5_rfreal*(3._rfreal*dv(dv_mixt_pres,ijkcb0)- &
176 dv(dv_mixt_pres,ijkcb1))
177 sf(1) = sgn*sface(xcoord,ijknb)
178 sf(2) = sgn*sface(ycoord,ijknb)
179 sf(3) = sgn*sface(zcoord,ijknb)
180 sv = sgn*svel(ijknb*indsvel)
182 rhs(cv_mixt_xmom,ijkcb0) =
rhs(cv_mixt_xmom,ijkcb0) + pa*sf(1)
183 rhs(cv_mixt_ymom,ijkcb0) =
rhs(cv_mixt_ymom,ijkcb0) + pa*sf(2)
184 rhs(cv_mixt_zmom,ijkcb0) =
rhs(cv_mixt_zmom,ijkcb0) + pa*sf(3)
185 rhs(cv_mixt_ener,ijkcb0) =
rhs(cv_mixt_ener,ijkcb0) + pa*sv
187 IF (lbound==1 .OR. lbound==2)
THEN
190 ELSE IF (lbound==3 .OR. lbound==4)
THEN
193 ELSE IF (lbound==5 .OR. lbound==6)
THEN
197 j2d = aerocoeff * indij(n1,n2,noff)
198 patch%cp(j2d) = rcpref*(pa - pref)
206 ELSE IF (bctype>=bc_noslipwall .AND. bctype<=bc_noslipwall+bc_range)
THEN
211 ijkcb0 = indijk(
i ,
j ,
k ,icoff,ijcoff)
213 pa = dv(dv_mixt_pres,ijkcb0)
214 sf(1) = sgn*sface(xcoord,ijknb)
215 sf(2) = sgn*sface(ycoord,ijknb)
216 sf(3) = sgn*sface(zcoord,ijknb)
217 sv = sgn*svel(ijknb*indsvel)
219 rhs(cv_mixt_xmom,ijkcb0) =
rhs(cv_mixt_xmom,ijkcb0) + pa*sf(1)
220 rhs(cv_mixt_ymom,ijkcb0) =
rhs(cv_mixt_ymom,ijkcb0) + pa*sf(2)
221 rhs(cv_mixt_zmom,ijkcb0) =
rhs(cv_mixt_zmom,ijkcb0) + pa*sf(3)
222 rhs(cv_mixt_ener,ijkcb0) =
rhs(cv_mixt_ener,ijkcb0) + pa*sv
224 IF (lbound==1 .OR. lbound==2)
THEN
227 ELSE IF (lbound==3 .OR. lbound==4)
THEN
230 ELSE IF (lbound==5 .OR. lbound==6)
THEN
234 j2d = aerocoeff * indij(n1,n2,noff)
235 patch%cp(j2d) = rcpref*(pa - pref)
243 ELSE IF (bctype>=bc_symmetry .AND. bctype<=bc_symmetry+bc_range)
THEN
248 ijkcb0 = indijk(
i ,
j ,
k ,icoff,ijcoff)
251 pa = 0.5_rfreal*(dv(dv_mixt_pres,ijkcb0)+dv(dv_mixt_pres,ijkcd))
252 sf(1) = sgn*sface(xcoord,ijknb)
253 sf(2) = sgn*sface(ycoord,ijknb)
254 sf(3) = sgn*sface(zcoord,ijknb)
255 sv = sgn*svel(ijknb*indsvel)
257 rhs(cv_mixt_xmom,ijkcb0) =
rhs(cv_mixt_xmom,ijkcb0) + pa*sf(1)
258 rhs(cv_mixt_ymom,ijkcb0) =
rhs(cv_mixt_ymom,ijkcb0) + pa*sf(2)
259 rhs(cv_mixt_zmom,ijkcb0) =
rhs(cv_mixt_zmom,ijkcb0) + pa*sf(3)
260 rhs(cv_mixt_ener,ijkcb0) =
rhs(cv_mixt_ener,ijkcb0) + pa*sv
262 IF (lbound==1 .OR. lbound==2)
THEN
265 ELSE IF (lbound==3 .OR. lbound==4)
THEN
268 ELSE IF (lbound==5 .OR. lbound==6)
THEN
272 j2d = aerocoeff * indij(n1,n2,noff)
273 patch%cp(j2d) = rcpref*(pa - pref)
281 ELSE IF (bctype>=bc_injection .AND. bctype<=bc_injection+bc_range)
THEN
286 ijkcb0 = indijk(
i ,
j ,
k ,icoff,ijcoff)
289 sf(1) = sgn*sface(xcoord,ijknb)
290 sf(2) = sgn*sface(ycoord,ijknb)
291 sf(3) = sgn*sface(zcoord,ijknb)
292 sv = sgn*svel(ijknb*indsvel)
294 IF (lbound==1 .OR. lbound==2)
THEN
297 ELSE IF (lbound==3 .OR. lbound==4)
THEN
300 ELSE IF (lbound==5 .OR. lbound==6)
THEN
304 i2d = distrib * indij(n1,n2,noff)
305 mrate = vals(bcdat_inject_mfrate,i2d)
306 tburn = vals(bcdat_inject_temp ,i2d)
307 rhovrel(1) = vals(bcdat_inject_rfvfu ,i2d)
308 rhovrel(2) = vals(bcdat_inject_rfvfv ,i2d)
309 rhovrel(3) = vals(bcdat_inject_rfvfw ,i2d)
311 IF (mrate > 0._rfreal)
THEN
312 ds =
sqrt(sf(1)*sf(1)+sf(2)*sf(2)+sf(3)*sf(3))
313 IF (gasmodel == gas_model_tcperf)
THEN
315 sf(1)/ds,sf(2)/ds,sf(3)/ds, &
316 gv(gv_mixt_cp ,ijkcb0*indcp ), &
317 gv(gv_mixt_mol ,ijkcb0*indmol), &
318 dv(dv_mixt_pres,ijkcb0 ), &
319 rhoa,rhoua,rhova,rhowa,rhoea,pa, &
322 CALL
errorstop( region%global,err_unknown_bc,__line__ )
324 vcont = uinj*sf(1) + vinj*sf(2) + winj*sf(3)
333 IF (flowmodel == flow_euler)
THEN
334 pa = 0.5_rfreal*(3._rfreal*dv(dv_mixt_pres,ijkcb0)- &
335 dv(dv_mixt_pres,ijkcb1))
337 pa = dv(dv_mixt_pres,ijkcb0)
341 rhs(cv_mixt_dens,ijkcb0) =
rhs(cv_mixt_dens,ijkcb0) + vcont*rhoa
342 rhs(cv_mixt_xmom,ijkcb0) =
rhs(cv_mixt_xmom,ijkcb0) + vcont*rhoua + &
344 rhs(cv_mixt_ymom,ijkcb0) =
rhs(cv_mixt_ymom,ijkcb0) + vcont*rhova + &
346 rhs(cv_mixt_zmom,ijkcb0) =
rhs(cv_mixt_zmom,ijkcb0) + vcont*rhowa + &
348 rhs(cv_mixt_ener,ijkcb0) =
rhs(cv_mixt_ener,ijkcb0) + &
349 vcont*(rhoea+pa) + pa*sv
351 j2d = aerocoeff * indij(n1,n2,noff)
352 patch%cp(j2d) = rcpref*(pa - pref)
360 ELSE IF (bctype>=bc_regionint .AND. bctype<=bc_regionint +bc_range)
THEN
362 ELSE IF (bctype>=bc_regnonconf .AND. bctype<=bc_regnonconf+bc_range)
THEN
368 IF (spaceorder == discr_order_1)
THEN
372 ijkcb0 = indijk(
i ,
j ,
k ,icoff,ijcoff)
375 sf(1) = sgn*sface(xcoord,ijknb)
376 sf(2) = sgn*sface(ycoord,ijknb)
377 sf(3) = sgn*sface(zcoord,ijknb)
378 sv = sgn*svel(ijknb*indsvel)
379 rhl = dv(dv_mixt_pres,ijkcd) + cv(cv_mixt_ener,ijkcd)
380 qsl = dv(dv_mixt_uvel,ijkcd)*sf(1) + &
381 dv(dv_mixt_vvel,ijkcd)*sf(2) + &
382 dv(dv_mixt_wvel,ijkcd)*sf(3) - sv
383 rhr = dv(dv_mixt_pres,ijkcb0) + cv(cv_mixt_ener,ijkcb0)
384 qsr = dv(dv_mixt_uvel,ijkcb0)*sf(1) + &
385 dv(dv_mixt_vvel,ijkcb0)*sf(2) + &
386 dv(dv_mixt_wvel,ijkcb0)*sf(3) - sv
387 pa = 0.5_rfreal*(dv(dv_mixt_pres,ijkcb0)+dv(dv_mixt_pres,ijkcd))
388 rhs(cv_mixt_dens,ijkcb0) =
rhs(cv_mixt_dens,ijkcb0) + &
389 0.5_rfreal*(qsl*cv(cv_mixt_dens,ijkcd)+ &
390 qsr*cv(cv_mixt_dens,ijkcb0))
391 rhs(cv_mixt_xmom,ijkcb0) =
rhs(cv_mixt_xmom,ijkcb0) + pa*sf(1) + &
392 0.5_rfreal*(qsl*cv(cv_mixt_xmom,ijkcd)+ &
393 qsr*cv(cv_mixt_xmom,ijkcb0))
394 rhs(cv_mixt_ymom,ijkcb0) =
rhs(cv_mixt_ymom,ijkcb0) + pa*sf(2) + &
395 0.5_rfreal*(qsl*cv(cv_mixt_ymom,ijkcd)+ &
396 qsr*cv(cv_mixt_ymom,ijkcb0))
397 rhs(cv_mixt_zmom,ijkcb0) =
rhs(cv_mixt_zmom,ijkcb0) + pa*sf(3) + &
398 0.5_rfreal*(qsl*cv(cv_mixt_zmom,ijkcd)+ &
399 qsr*cv(cv_mixt_zmom,ijkcb0))
400 rhs(cv_mixt_ener,ijkcb0) =
rhs(cv_mixt_ener,ijkcb0) + &
401 0.5_rfreal*(qsl*rhl+qsr*rhr) + sv*pa
403 IF (lbound==1 .OR. lbound==2)
THEN
406 ELSE IF (lbound==3 .OR. lbound==4)
THEN
409 ELSE IF (lbound==5 .OR. lbound==6)
THEN
413 j2d = aerocoeff * indij(n1,n2,noff)
414 patch%cp(j2d) = rcpref*(pa - pref)
419 ELSE IF (spaceorder == discr_order_2)
THEN
423 ijkcb0 = indijk(
i ,
j ,
k ,icoff,ijcoff)
428 sf(1) = sgn*sface(xcoord,ijknb)
429 sf(2) = sgn*sface(ycoord,ijknb)
430 sf(3) = sgn*sface(zcoord,ijknb)
431 sv = sgn*svel(ijknb*indsvel)
432 vola = (0.5_rfreal*(vol(ijkcb0)+vol(ijkcd1)))**1.5_rfreal
434 dvar(1) = cv(cv_mixt_dens,ijkcb0) - cv(cv_mixt_dens,ijkcd1)
435 dvar(2) = dv(dv_mixt_uvel,ijkcb0) - dv(dv_mixt_uvel,ijkcd1)
436 dvar(3) = dv(dv_mixt_vvel,ijkcb0) - dv(dv_mixt_vvel,ijkcd1)
437 dvar(4) = dv(dv_mixt_wvel,ijkcb0) - dv(dv_mixt_wvel,ijkcd1)
438 dvar(5) = dv(dv_mixt_pres,ijkcb0) - dv(dv_mixt_pres,ijkcd1)
440 dvarm(1) = cv(cv_mixt_dens,ijkcd1) - cv(cv_mixt_dens,ijkcd2)
441 dvarm(2) = dv(dv_mixt_uvel,ijkcd1) - dv(dv_mixt_uvel,ijkcd2)
442 dvarm(3) = dv(dv_mixt_vvel,ijkcd1) - dv(dv_mixt_vvel,ijkcd2)
443 dvarm(4) = dv(dv_mixt_wvel,ijkcd1) - dv(dv_mixt_wvel,ijkcd2)
444 dvarm(5) = dv(dv_mixt_pres,ijkcd1) - dv(dv_mixt_pres,ijkcd2)
446 dvarp(1) = cv(cv_mixt_dens,ijkcb1) - cv(cv_mixt_dens,ijkcb0)
447 dvarp(2) = dv(dv_mixt_uvel,ijkcb1) - dv(dv_mixt_uvel,ijkcb0)
448 dvarp(3) = dv(dv_mixt_vvel,ijkcb1) - dv(dv_mixt_vvel,ijkcb0)
449 dvarp(4) = dv(dv_mixt_wvel,ijkcb1) - dv(dv_mixt_wvel,ijkcb0)
450 dvarp(5) = dv(dv_mixt_pres,ijkcb1) - dv(dv_mixt_pres,ijkcb0)
453 deltl(1) = 0.5_rfreal*muscl3(dvar(1) ,dvarm(1),eps2n)
454 deltr(1) = 0.5_rfreal*muscl3(dvarp(1),dvar(1) ,eps2n)
456 deltl(2) = 0.5_rfreal*muscl3(dvar(2) ,dvarm(2),eps2n)
457 deltr(2) = 0.5_rfreal*muscl3(dvarp(2),dvar(2) ,eps2n)
458 deltl(3) = 0.5_rfreal*muscl3(dvar(3) ,dvarm(3),eps2n)
459 deltr(3) = 0.5_rfreal*muscl3(dvarp(3),dvar(3) ,eps2n)
460 deltl(4) = 0.5_rfreal*muscl3(dvar(4) ,dvarm(4),eps2n)
461 deltr(4) = 0.5_rfreal*muscl3(dvarp(4),dvar(4) ,eps2n)
463 deltl(5) = 0.5_rfreal*muscl3(dvar(5) ,dvarm(5),eps2n)
464 deltr(5) = 0.5_rfreal*muscl3(dvarp(5),dvar(5) ,eps2n)
466 rgas = 8314.3_rfreal/gv(gv_mixt_mol,ijkcd1*indmol)
467 gam = gv(gv_mixt_cp,ijkcd1*indcp)/(gv(gv_mixt_cp,ijkcd1*indcp)-rgas)
468 ggm1 = gam/(gam-1._rfreal)
469 rl = cv(cv_mixt_dens,ijkcd1) + deltl(1)
470 ul = dv(dv_mixt_uvel,ijkcd1) + deltl(2)
471 vl = dv(dv_mixt_vvel,ijkcd1) + deltl(3)
472 wl = dv(dv_mixt_wvel,ijkcd1) + deltl(4)
473 pl = dv(dv_mixt_pres,ijkcd1) + deltl(5)
474 hl = ggm1*pl/rl + 0.5_rfreal*(ul*ul+vl*vl+wl*wl)
475 qsrl = (ul*sf(1)+vl*sf(2)+ wl*sf(3)-sv)*rl
477 rgas = 8314.3_rfreal/gv(gv_mixt_mol,ijkcb0*indmol)
478 gam = gv(gv_mixt_cp,ijkcb0*indcp)/(gv(gv_mixt_cp,ijkcb0*indcp)-rgas)
479 ggm1 = gam/(gam-1._rfreal)
480 rr = cv(cv_mixt_dens,ijkcb0) - deltr(1)
481 ur = dv(dv_mixt_uvel,ijkcb0) - deltr(2)
482 vr = dv(dv_mixt_vvel,ijkcb0) - deltr(3)
483 wr = dv(dv_mixt_wvel,ijkcb0) - deltr(4)
484 pr = dv(dv_mixt_pres,ijkcb0) - deltr(5)
485 hr = ggm1*pr/rr + 0.5_rfreal*(ur*ur+vr*vr+wr*wr)
486 qsrr = (ur*sf(1)+vr*sf(2)+wr*sf(3)-sv)*rr
487 pa = 0.5_rfreal*(pl+pr)
489 rhs(cv_mixt_dens,ijkcb0) =
rhs(cv_mixt_dens,ijkcb0) + &
490 0.5_rfreal*(qsrl +qsrr )
491 rhs(cv_mixt_xmom,ijkcb0) =
rhs(cv_mixt_xmom,ijkcb0) + pa*sf(1) + &
492 0.5_rfreal*(qsrl*ul+qsrr*ur)
493 rhs(cv_mixt_ymom,ijkcb0) =
rhs(cv_mixt_ymom,ijkcb0) + pa*sf(2) + &
494 0.5_rfreal*(qsrl*vl+qsrr*vr)
495 rhs(cv_mixt_zmom,ijkcb0) =
rhs(cv_mixt_zmom,ijkcb0) + pa*sf(3) + &
496 0.5_rfreal*(qsrl*wl+qsrr*wr)
497 rhs(cv_mixt_ener,ijkcb0) =
rhs(cv_mixt_ener,ijkcb0) + &
498 0.5_rfreal*(qsrl*hl+qsrr*hr) + sv*pa
500 IF (lbound==1 .OR. lbound==2)
THEN
503 ELSE IF (lbound==3 .OR. lbound==4)
THEN
506 ELSE IF (lbound==5 .OR. lbound==6)
THEN
510 j2d = aerocoeff * indij(n1,n2,noff)
511 patch%cp(j2d) = rcpref*(pa - pref)
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE ibeg
subroutine rflo_getpatchdirection(patch, idir, jdir, kdir)
subroutine bcondinjectionperf(distrib, minj, tinj, rhoVrel, sxn, syn, szn, cpgas, mm, p, rhob, rhoub, rhovb, rhowb, rhoeb, pb, uinj, vinj, winj)
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE inode
subroutine registerfunction(global, funName, fileName)
subroutine rflo_getpatchindices(region, patch, iLev, ibeg, iend, jbeg, jend, kbeg, kend)
subroutine rflo_getnodeoffset(region, iLev, iNodeOffset, ijNodeOffset)
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE jdir
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE knode iend
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE idir
subroutine rflo_getcelloffset(region, iLev, iCellOffset, ijCellOffset)
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE knode jend
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE kdir
subroutine errorstop(global, errorCode, errorLine, addMessage)
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE knode jbeg
subroutine rflo_roefluxpatch(region, patch)
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE knode kbeg
subroutine deregisterfunction(global)
**********************************************************************Rocstar Simulation Suite Illinois Rocstar LLC All rights reserved ****Illinois Rocstar LLC IL **www illinoisrocstar com **sales illinoisrocstar com WITHOUT WARRANTY OF ANY **EXPRESS OR INCLUDING BUT NOT LIMITED TO THE WARRANTIES **OF FITNESS FOR A PARTICULAR PURPOSE AND **NONINFRINGEMENT IN NO EVENT SHALL THE CONTRIBUTORS OR **COPYRIGHT HOLDERS BE LIABLE FOR ANY DAMAGES OR OTHER WHETHER IN AN ACTION OF TORT OR **Arising OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE **USE OR OTHER DEALINGS WITH THE SOFTWARE **********************************************************************INTERFACE SUBROUTINE jnode