File indexing completed on 2018-03-02 18:45:03 UTC
view on githubraw file Latest commit 8702af1f on 2012-09-20 23:12:48 UTC
8702af1f36 Patr*0001 #include "CPP_EEOPTIONS.h"
0002 subroutine template()
0003 use OAD_tape
0004 use OAD_rev
0005
0006
0007
0008 type(modeType) :: our_orig_mode
0009
0010
0011 INTEGER , PARAMETER :: nArgsHelper=9
0012 INTEGER argsHelper(nArgsHelper)
0013 _RL array_p( 1-myOLw:sNx+myOLe,
0014 & 1-myOLs:sNy+myOLn,
0015 & myNz, nSx, nSy )
0016
0017 #ifdef OAD_DEBUG_SPLIT1
0018 character*(80):: indentation='
0019 + '
0020 our_indent=our_indent+1
0021
0022 write(standardmessageunit, '(A,A,A)', ADVANCE='NO')
0023 +'OAD:',indentation(1:our_indent), 'enter __SRNAME__:'
0024 call oad_dump_revmod(); call oad_dump_tapestats()
0025 write(standardmessageunit,*)
0026 #endif
0027
0028 if (our_rev_mode%plain) then
0029 #ifdef OAD_DEBUG_SPLIT1
0030 write(standardmessageunit,'(A,A,A)')
0031 +'OAD:',indentation(1:our_indent),
0032 +' __SRNAME__: entering plain'
0033 #endif
0034
0035 array_p = array%v
0036
0037 our_orig_mode=our_rev_mode
0038
0039 call OAD_revPlain()
0040
0041 call EXCH1_RL(
0042 U array_p,
0043 I myOLw, myOLe, myOLs, myOLn, myNz,
0044 I exchWidthX, exchWidthY,
0045 I cornerMode, myThid )
0046
0047 our_rev_mode=our_orig_mode
0048
0049 array%v = array_p
0050 end if
0051 if (our_rev_mode%tape) then
0052 #ifdef OAD_DEBUG_SPLIT1
0053 write(standardmessageunit,'(A,A,A)')
0054 +'OAD:',indentation(1:our_indent),
0055 +' __SRNAME__: entering tape'
0056 #endif
0057
0058 array_p = array%v
0059
0060 argsHelper=(/myOLw, myOLe, myOLs, myOLn, myNz,exchWidthX,
0061 +exchWidthY,cornerMode, myThid/)
0062
0063 our_orig_mode=our_rev_mode
0064
0065 call OAD_revPlain()
0066
0067 call EXCH1_RL(
0068 U array_p,
0069 I myOLw, myOLe, myOLs, myOLn, myNz,
0070 I exchWidthX, exchWidthY,
0071 I cornerMode, myThid )
0072
0073 our_rev_mode=our_orig_mode
0074
0075 array%v = array_p
0076
0077 if(oad_it_sz.lt. oad_it_ptr+nArgsHelper) call oad_it_grow()
0078 oad_it(oad_it_ptr:oad_it_ptr+nArgsHelper-1)=argsHelper
0079 oad_it_ptr=oad_it_ptr+nArgsHelper
0080 end if
0081 if (our_rev_mode%adjoint) then
0082
0083 oad_it_ptr=oad_it_ptr-nArgsHelper
0084 argsHelper=oad_it(oad_it_ptr:oad_it_ptr+nArgsHelper-1)
0085 #ifdef OAD_DEBUG_SPLIT1
0086 write(standardmessageunit,'(A,A,A)')
0087 +'OAD:',indentation(1:our_indent),
0088 +' __SRNAME__: entering adjoint'
0089 #endif
0090
0091 array_p = array%d
0092
0093 our_orig_mode=our_rev_mode
0094
0095 call OAD_revPlain()
0096
0097 call EXCH1_RL_AD(
0098 U array_p,
0099 I argsHelper(1),argsHelper(2),argsHelper(3),
0100 I argsHelper(4),argsHelper(5),argsHelper(6),
0101 I argsHelper(7),argsHelper(8),argsHelper(9) )
0102
0103 our_rev_mode=our_orig_mode
0104
0105 array%d = array_p
0106 end if
0107
0108 #ifdef OAD_DEBUG_SPLIT1
0109 write(standardmessageunit,'(A,A,A)', ADVANCE='NO')
0110 +'OAD:',indentation(1:our_indent), 'leave __SRNAME__:'
0111 call oad_dump_revmod(); call oad_dump_tapestats()
0112 write(standardmessageunit,*)
0113
0114 our_indent=our_indent-1
0115 #endif
0116
0117 end subroutine template