Go to the documentation of this file.00001 INTEGER FUNCTION ignlgi()
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 INTEGER numg
00020 PARAMETER (numg=32)
00021
00022
00023 INTEGER a1,a1vw,a1w,a2,a2vw,a2w,m1,m2
00024
00025
00026 INTEGER cg1(numg),cg2(numg),ig1(numg),ig2(numg),lg1(numg),
00027 + lg2(numg)
00028 LOGICAL qanti(numg)
00029
00030
00031 INTEGER curntg,k,s1,s2,z
00032 LOGICAL qqssd
00033
00034
00035 LOGICAL qrgnin
00036 EXTERNAL qrgnin
00037
00038
00039 EXTERNAL getcgn,inrgcm,rgnqsd,setall
00040
00041
00042 COMMON /globe/m1,m2,a1,a2,a1w,a2w,a1vw,a2vw,ig1,ig2,lg1,lg2,cg1,
00043 + cg2,qanti
00044
00045
00046 SAVE /globe/
00047
00048
00049
00050
00051
00052
00053
00054 IF (.NOT. (qrgnin())) CALL inrgcm()
00055 CALL rgnqsd(qqssd)
00056 IF (.NOT. (qqssd)) CALL setall(1234567890,123456789)
00057
00058
00059
00060 CALL getcgn(curntg)
00061 s1 = cg1(curntg)
00062 s2 = cg2(curntg)
00063 k = s1/53668
00064 s1 = a1* (s1-k*53668) - k*12211
00065 IF (s1.LT.0) s1 = s1 + m1
00066 k = s2/52774
00067 s2 = a2* (s2-k*52774) - k*3791
00068 IF (s2.LT.0) s2 = s2 + m2
00069 cg1(curntg) = s1
00070 cg2(curntg) = s2
00071 z = s1 - s2
00072 IF (z.LT.1) z = z + m1 - 1
00073 IF (qanti(curntg)) z = m1 - z
00074 ignlgi = z
00075 RETURN
00076
00077 END