00001 subroutine symbolic(valsizeMax)
00002
00003 use global
00004
00005 use mf
00006
00007 use DFPORT
00008
00009 implicit none
00010
00011
00012
00013 integer indSize
00014 integer ptrSize
00015 integer valSize,valSizeMax
00016
00017 real(8), allocatable :: JacVal(:),luval(:)
00018 integer, allocatable :: JacColInd(:),JacRowPtr(:),iw(:),uptr(:)
00019
00020
00021 integer numberOfColors
00022
00023
00024
00025
00026
00027
00028 valsize=1
00029 indSize=valSize
00030 ptrSize=globalcurrentsetlength+1
00031
00032 valSizeMax=valsize
00033
00034 allocate(JacVal(valSizeMax),JacColInd(valSizeMax),JacRowPtr(ptrSize),uptr(globalcurrentsetlength))
00035
00036 call colorJacobianCRS(JacVal,JacColInd,JacRowPtr,globalcurrentsetlength,1,valSize,indSize,uptr,1,numberOfColors)
00037
00038
00039 deallocate(JacVal,JacColInd,JacRowPtr,uptr)
00040
00041
00042 valsize=globalcurrentsetlength*numberOfColors
00043 indSize=valSize
00044 ptrSize=globalcurrentsetlength+1
00045
00046 valSizeMax=valsize
00047
00048
00049 allocate(JacVal(valSizeMax),JacColInd(valSizeMax),JacRowPtr(ptrSize),uptr(globalcurrentsetlength))
00050
00051 jacVal=0.d0
00052 JacColInd=0
00053 JacRowPtr=0
00054 uptr=0
00055
00056 tempy=y
00057
00058
00059
00060 allocate(yBackup(size(y)))
00061 yBackup=0.d0
00062 yBackup=y
00063
00064
00065
00066 call random_seed()
00067 CALL RANDOM_NUMBER(y)
00068
00069 tempy=y
00070
00071
00072 myModel%physics(currentPhysics)%evalOrder=>jacDiscOrder
00073
00074 call colorJacobianCRS(JacVal,JacColInd,JacRowPtr,globalcurrentsetlength,1,valSize,indSize,uptr,0,numberOfColors)
00075
00076
00077
00078 myModel%physics(currentPhysics)%evalOrder=>myModel%physics(currentPhysics)%discOrder
00079
00080
00081 y=yBackup
00082 tempy=y
00083 deallocate(yBackup)
00084
00085
00086
00087 deallocate(JacVal,JacColInd,JacRowPtr,uptr)
00088
00089
00090
00091 indSize=valSize
00092 ptrSize=globalcurrentsetlength+1
00093
00094 valSizeMax=valsize
00095 valSizeMax=floor(valsize*jacSF)
00096
00097
00098
00099
00100
00101
00102 end subroutine symbolic