added handling of ijetto=2 case in jintrac branch

This commit is contained in:
Lorenzo Figini 2014-06-12 23:13:32 +00:00
parent b02c254a35
commit f9facdc28e
6 changed files with 220 additions and 118 deletions

View File

@ -9,7 +9,6 @@
# P. Strand, elfps@chalmers.se
# G. Corrigan, gcor@jet.uk
# D. Harting, d.harting@fz-juelich.de
# Set the environment from the top-level Makefile of JETTO
# --------------------------------------------------------
include ../include.mk
@ -27,7 +26,6 @@ FOBJ=$(FOBJ0:.f90=.o)
########################################
# Set up compiler specific environment #
########################################
# set default compiler
# --------------------
FC=$(F90)
@ -99,14 +97,14 @@ clean:
# Dependencies
# ------------
gray_main.o: gray-externals.o itm_types.o
gray-externals.o: green_func_p.o reflections.o
gray-externals.o: green_func_p.o reflections.o scatterspl.o
green_func_p.o: const_and_precisions.o
const_and_precisions.o: itm_types.o itm_constants.o
itm_constants.o: itm_types.o
scatterspl.o: itm_types.o
# Special rule to preprocess source file and include svn revision
# ---------------------------------------------------------------
DIRECTIVES = -DREVISION="'$(shell svnversion)'"
gray-externals.o:gray-externals.f
$(FC) -c -Mpreprocess $(DIRECTIVES) $(FFLAGS) $(INC) $<

View File

@ -3,8 +3,8 @@ EXE=gray
LIBFILE=lib$(EXE).a
# Objects list
OBJ=gray_main.o gray-externals.o grayl.o reflections.o green_func_p.o \
const_and_precisions.o itm_constants.o itm_types.o
OBJ=gray_main.o gray-externals.o grayl.o reflections.o scatterspl.o \
green_func_p.o const_and_precisions.o itm_constants.o itm_types.o
# Alternative search paths
vpath %.f90 src
@ -30,10 +30,11 @@ $(LIBFILE): $(OBJ)
# Dependencies on modules
main.o: gray_main.o
gray_main.o: gray-externals.o itm_types.o
gray-externals.o: green_func_p.o reflections.o
gray-externals.o: green_func_p.o reflections.o scatterspl.o
green_func_p.o: const_and_precisions.o
const_and_precisions.o: itm_types.o itm_constants.o
itm_constants.o: itm_types.o
scatterspl.o: itm_types.o
# General object compilation command
%.o: %.f90

View File

@ -1023,6 +1023,7 @@ c
subroutine equidata(ijetto,mr,mz,r,z,psin2d,psiaxis,psiedge,
. rax,zax,nbnd,rbnd,zbnd,mrho,psijet,fpjet,qjet)
use itm_constants, only : pi=>itm_pi
use reflections, only : inside
implicit real*8 (a-h,o-z)
integer ijetto,mr,mz,nbnd,mrho
real*8 r(mr),z(mz),psin2d(mr,mz)
@ -1042,6 +1043,7 @@ c
dimension tr(nrest),tz(nzest),wrk(lwrk),iwrk(liwrk)
parameter(lwrkbsp=4*(nnw+nnh),liwrkbsp=nnw+nnh)
dimension wrkbsp(lwrkbsp),iwrkbsp(liwrkbsp)
dimension rv1d(nnw*nnh),zv1d(nnw*nnh),wpsi(nnw*nnh)
parameter(lw10=nnw*3+nnh*4+nnw*nnh,lw01=nnw*4+nnh*3+nnw*nnh)
parameter(lw20=nnw*2+nnh*4+nnw*nnh,lw02=nnw*4+nnh*2+nnw*nnh)
parameter(lw11=nnw*3+nnh*3+nnw*nnh,ldiwrk=nnw+nnh)
@ -1129,21 +1131,22 @@ c psi function
c
c do j=1,nz
c do i=1,nr
c write(620,2021) rv(i),zv(j),psi(i,j)
c write(620,2021) rv(i),zv(j),psin(i,j)
c enddo
c write(620,*) ' '
c enddo
c
c spline fitting/interpolation of psin(i,j) and derivatives
c
if (ijetto.eq.1) then
c valid data on the whole grid
do j=1,nz
do i=1,nr
psi(i,j)=psin(i,j)*psia
c psi(i,j)=psin(i,j)*psia
ij=nz*(i-1)+j
fvpsi(ij)=psin(i,j)
enddo
enddo
c
c spline fitting/interpolation of psin(i,j) and derivatives
c
iopt=0
call regrid(iopt,nr,rv,nz,zv,fvpsi,rmnm,rmxm,zmnm,zmxm,
. kspl,kspl,sspl,nrest,nzest,nsr,tr,nsz,tz,cc,fp,
@ -1157,21 +1160,66 @@ c if ier=-1 data are fitted using sspl=0
end if
nsrt=nsr
nszt=nsz
if (sspl.gt.0.0d0) then
call bispev(tr,nsr,tz,nsz,cc,kspl,kspl,rv,nr,zv,nz,ffvpsi,
. wrkbsp,lwrkbsp,iwrkbsp,liwrkbsp,ier)
c
else
c valid data only inside boundary
ij=0
do j=1,nz
do i=1,nr
ij=nz*(i-1)+j
psin(i,j)=ffvpsi(ij)
psi(i,j)=psin(i,j)*psia
c write(619,2021) rv(i),zv(j),psin(i,j)
if (.not.inside(rbnd,zbnd,nbnd,rv(i),zv(j))) cycle
ij=ij+1
rv1d(ij)=rv(i)
zv1d(ij)=zv(j)
fvpsi(ij)=psin(i,j)
wpsi(ij)=1.0d0
end do
c write(619,*) ' '
end do
c add boundary to the fit
if (ij+nbnd.le.nnw*nnh) then
do i=1,nbnd
ij=ij+1
rv1d(ij)=rbnd(i)
zv1d(ij)=zbnd(i)
fvpsi(ij)=1.0d0
wpsi(ij)=1.0d0
end do
end if
2021 format(5(1x,e16.9))
nrz=ij
c
c fit as a scattered set of points
c
nsr=nr+4
nsz=nz+4
call scatterspl(rv1d,zv1d,fvpsi,wpsi,nrz,kspl,sspl,
. rmnm,rmxm,zmnm,zmxm,tr,nsr,tz,nsz,coeff,ier)
!!!!!!!!!!!! Sistemare anche dipendenze Makefile scatterspl:...
c if ier=-1 data are fitted using sspl=0
if(ier.eq.-1) then
sspl=0.0d0
nsr=nr+4
nsz=nz+4
call scatterspl(rv1d,zv1d,fvpsi,wpsi,nrz,kspl,sspl,
. rmnm,rmxm,zmnm,zmxm,tr,nsr,tz,nsz,coeff,ier)
end if
nsrt=nsr
nszt=nsz
end if
c
c re-evaluate psi on the grid using the spline (only for debug)
c
c call bispev(tr,nsr,tz,nsz,cc,kspl,kspl,rv,nr,zv,nz,ffvpsi,
c . wrkbsp,lwrkbsp,iwrkbsp,liwrkbsp,ier)
c
c do j=1,nz
c do i=1,nr
c ij=nz*(i-1)+j
c psin(i,j)=ffvpsi(ij)
cc psi(i,j)=psin(i,j)*psia
c write(619,2021) rv(i),zv(j),psin(i,j)
c enddo
c write(619,*) ' '
c enddo
c
c2021 format(5(1x,e16.9))
c
nur=1
nuz=0

View File

@ -18,7 +18,7 @@ c input arguments
c
c ijetto Equilibrium source (1 EFIT, 2 ESCO)
c If IJETTO=2, then PSIN values are valid only inside
c plasma boudary (PSIN=0 outside)
c plasma boudary (PSIN=1 outside)
c mr Size of flux map grid in R direction
c mz Size of flux map grid in Z direction
c r R coordinates of flux map grid points [m]

View File

@ -188,12 +188,17 @@ function inside(xc,yc,n,x,y)
integer, dimension(n) :: jint
real(r8), dimension(n) :: xint
real(r8), dimension(n+1) :: xclosed,yclosed
integer :: i,nj
integer :: i,np,nj
xclosed(1:n)=xc(1:n)
yclosed(1:n)=yc(1:n)
xclosed(n+1)=xc(1)
yclosed(n+1)=yc(1)
call locate_unord(yclosed,n+1,y,jint,n,nj)
if (xc(1)==xc(n) .and. yc(1)==yc(n)) then
np=n
else
np=n+1
xclosed(np)=xc(1)
yclosed(np)=yc(1)
end if
call locate_unord(yclosed(1:np),np,y,jint,n,nj)
inside=.false.
if (nj==0) return
do i=1,nj

50
src/scatterspl.f90 Normal file
View File

@ -0,0 +1,50 @@
subroutine scatterspl(x,y,z,w,n,kspl,sspl,xmin,xmax,ymin,ymax, &
tx,nknt_x,ty,nknt_y,coeff,ierr)
use itm_types, only : r8
implicit none
integer :: n
real(r8), dimension(n) :: x, y, z
real(r8), dimension(n) :: w
integer :: kspl
real(r8) :: sspl
real(r8) :: xmin, xmax, ymin, ymax
real(r8), dimension(nknt_x) :: tx
real(r8), dimension(nknt_y) :: ty
integer :: nknt_x, nknt_y
real(r8), dimension(nknt_x*nknt_y) :: coeff
integer :: ierr
integer :: iopt
real(r8), parameter :: eps_r8=epsilon(1._r8)
real(r8) :: resid
integer :: u,v,km,ne,b1,b2,lwrk1,lwrk2,kwrk,nxest,nyest
real(r8), dimension(:), allocatable :: tx_tmp,ty_tmp
real(r8), dimension(:), allocatable :: wrk1, wrk2
integer, dimension(:), allocatable :: iwrk
nxest=nknt_x
nyest=nknt_y
ne = max(nxest,nyest)
allocate(tx_tmp(ne),ty_tmp(ne))
km = kspl+1
u = nxest-km
v = nyest-km
b1 = kspl*min(u,v)+kspl+1
b2 = (kspl+1)*min(u,v)+1
lwrk1 = u*v*(2+b1+b2)+2*(u+v+km*(n+ne)+ne-2*kspl)+b2+1
lwrk2 = u*v*(b2+1)+b2
kwrk = n+(nknt_x-2*kspl-1)*(nknt_y-2*kspl-1)
allocate(wrk1(lwrk1),wrk2(lwrk2),iwrk(kwrk))
iopt=0
call surfit(iopt,n,x,y,z,w,xmin,xmax,ymin,ymax,kspl,kspl,sspl, &
nxest,nyest,ne,eps_r8,nknt_x,tx_tmp,nknt_y,ty_tmp, &
coeff,resid,wrk1,lwrk1,wrk2,lwrk2,iwrk,kwrk,ierr)
tx(1:nknt_x)=tx_tmp(1:nknt_x)
ty(1:nknt_y)=ty_tmp(1:nknt_y)
deallocate(wrk1,wrk2,iwrk)
deallocate(tx_tmp,ty_tmp)
end subroutine scatterspl