From 286336ddd1ea884f9c397729511853e9f6fd276a Mon Sep 17 00:00:00 2001 From: hollyhan Date: Tue, 2 Jan 2024 15:02:20 -0700 Subject: [PATCH] Write TPW variables into a new file every timestep --- sl_model_mod.f90 | 55 ++++++++++++++++++++---------------------------- 1 file changed, 23 insertions(+), 32 deletions(-) diff --git a/sl_model_mod.f90 b/sl_model_mod.f90 index 5da4cfb..7ae91fa 100644 --- a/sl_model_mod.f90 +++ b/sl_model_mod.f90 @@ -591,7 +591,7 @@ subroutine sl_solver_init(itersl, starttime, mali_iceload, mali_bedrock, mali_ma lambda(:,:) = 0.0 ! write the values (0.0) for the first timestep - open(unit = 201, file = trim(outputfolder)//'TPW', form = 'formatted', access = 'sequential', & + open(unit = 201, file = trim(outputfolder)//'TPW'//trim(numstr), form = 'formatted', access = 'sequential', & & status = 'replace') write(201,'(9ES19.8E2/,3ES19.8E2/,18ES19.8E2)') il(:,:), mm(:), lambda(:,:) ! write(unit_num,'(9ES19.8E2/,3ES19.8E2/,18ES19.8E2)') dil(:,:,1), dm(:,1), dlambda(:,:,1) @@ -761,28 +761,19 @@ subroutine sl_solver(itersl, iter, dtime, starttime, mali_iceload, mali_mask, sl call read_sl(beta0(:,:), 'beta', outputfolder, suffix=numstr) if (tpw) then - ! read in variables for the rotation signal - open(unit = 201, file = trim(outputfolder)//'TPW', form = 'formatted', access = 'sequential', & - & status = 'old') - + ! initialize empty arrays oldlambda(:,:) = (0.0,0.0) oldil(:,:) = 0.0 oldm(:) = 0.0 do n = 1, nfiles-1 - ! find the number of lines to skip to read in appropriate TPW components - if (n == 1) then - j = TIMEWINDOW(n) - else - j = TIMEWINDOW(n) - TIMEWINDOW(n-1) - 1 - endif - !skip lines to read in the rotational components corresponding to timesteps within the TW - do m = 1, j - read(201,*) !skip line for il - read(201,*) !skip reading in mm - read(201,*) !skip reading in lambda - enddo + j = TIMEWINDOW(n) + write(numstr,'(I4)') j + numstr = trim(adjustl(numstr)) + ! read in variables for the rotation signal + open(unit = 201, file = trim(outputfolder)//'TPW'//trim(numstr), & + & form = 'formatted', access = 'sequential', status = 'old') !read in TPW components - total rotational change from the beginning of simulation read(201,'(9ES19.8E2)') ((il(i,j), i = 1,3), j = 1, 3) @@ -802,8 +793,8 @@ subroutine sl_solver(itersl, iter, dtime, starttime, mali_iceload, mali_mask, sl if (n == nfiles-1) then deltalambda(:,:,nfiles-1) = lambda(:,:) endif + close(201) enddo - close(201) endif !endif (TPW) ! find index of the previous timestep @@ -1226,20 +1217,6 @@ subroutine sl_solver(itersl, iter, dtime, starttime, mali_iceload, mali_mask, sl !----------------------------------------------------------- write(unit_num,'(A,I4,A)') ' ', ninner, ' inner-loop iterations' - !HH: print out the number of iteration it takes for the inner convergence - open(unit = 201, file = trim(outputfolder)//'numiter', form = 'formatted', access ='sequential', & - & status = 'old', position='append') - write(201,'(I5)') ninner - close(201) - - ! Write out the converged rotation-related quantities - if (tpw) then - open(unit = 201, file = trim(outputfolder)//'TPW', form = 'formatted', access = 'sequential', & - & status = 'old', position='append') - write(201,'(9ES19.8E2/,3ES19.8E2/,18ES19.8E2)') il(:,:), mm(:), lambda(:,:) - close(201) - endif - if (calcRG) then ! For R calculations if (nmelt == 0) then rrlm(:,:) = (0.0,0.0)! No change on first timestep @@ -1296,6 +1273,20 @@ subroutine sl_solver(itersl, iter, dtime, starttime, mali_iceload, mali_mask, sl write(201,'(I4)') nmelt close(201) + ! number of iteration it takes for the inner convergence + open(unit = 201, file = trim(outputfolder)//'numiter', form = 'formatted', access ='sequential', & + & status = 'old', position='append') + write(201,'(I5)') ninner + close(201) + + ! converged rotation-related quantities + if (tpw) then + open(unit = 201, file = trim(outputfolder)//'TPW'//trim(numstr), form = 'formatted', & + & access = 'sequential', status = 'replace') + write(201,'(9ES19.8E2/,3ES19.8E2/,18ES19.8E2)') il(:,:), mm(:), lambda(:,:) + close(201) + endif + ! topography at the current timestep call write_sl(topoxy, 'tgrid', outputfolder, suffix=numstr)