Source Code
These source-code files are part of a reconstructed copy of Luminary 98, a
development version of the Apollo 11 Lunar Module (LM) Apollo Guidance Computer
(AGC) software.
The reconstruction began with source code of Luminary 99 revision 1 previously transcribed from a digitized copy of that program. The code was then updated by undoing changes described in original Luminary memo 85, using asterisks indicating changed lines in the listing as a guide. While no listing of this version is known to exist, nor are the memory-bank checksums available, the reconstruction is believed to be correct because it was an an intermediate step in reconstructing Luminary 97 whose reconstruction was verified by matching memory-bank checksums to those listed in drawing 2021152G. Note that page numbers in the reconstructed code match those on the Luminary 099 revision 001 printout, although the added code would likely have changed page numbers for a real Luminary 98 listing. Comments from the original source code are prefixed with a single '#' symbol, whereas comments added later are prefixed by "##" or "###". Report any errors noted by creating an issue report at the Virtual AGC project's GitHub repository. |
050202,000002: ## Copyright: Public domain.
050203,000003: ## Filename: INTEGRATION_INITIALIZATION.agc
050204,000004: ## Purpose: A section of Luminary revision 98.
050205,000005: ## It is part of the reconstructed source code for the a
050206,000006: ## development version of the flight software for the Lunar
050207,000007: ## Module's (LM) Apollo Guidance Computer (AGC) for Apollo 11.
050208,000008: ## The code has been recreated from a copy of Luminary 99
050209,000009: ## revision 001, using asterisks indicating changed lines in
050210,000010: ## the listing and Luminary Memo #85, which lists changes between
050211,000011: ## Luminary 98 and 99.
050212,000012: ## Reference: pp. 1205-1226
050213,000013: ## Assembler: yaYUL
050214,000014: ## Contact: Ron Burkey <info@sandroid.org>.
050215,000015: ## Website: www.ibiblio.org/apollo/index.html
050216,000016: ## Mod history: 2019-07-28 MAS Created from Luminary 99.
050217,000017:
Page 1205 |
050219,000019: # 1.0 INTRODUCTION
050220,000020: # ----------------
050221,000021:
050222,000022: # FROM A USERS POINT OF VIEW, ORBITAL INTEGRATION IS ESSENTIALLY THE SAME AS THE 278 INTEGRATION
050223,000023: # PROGRAM. THE SAME ENTRANCES TO THE PROGRAM WILL BE MAINTAINED, THE SAME STALLING ROUTINE WILL BE USED AND
050224,000024: # OUTPUT WILL STILL BE VIA THE PUSHLIST. THE PRIMARY DIFFERENCES TO A USER INVOLVE THE ADDED CAPABILITY OF
050225,000025: # TERMINATING INTEGRATION AT A SPECIFIC FINAL RADIUS AND THE DIFFERENCE IN STATE VECTOR SCALING INSIDE AND OUT-
050226,000026: # SIDE THE LUNAR SPHERE OF INFLUENCE.
050227,000027:
050228,000028: # IN ORDER TO MAKE THE CSM(LEM)PREC AND CSM(LEM)CONIC ENTRANCES SIMILAR TO FLIGHT 278, THE INTEGRATION PROGRAM
050229,000029: # WILL ITSELF SET THE FINAL RADIUS (RFINAL) TO 0 SO THAT REACHING THE DESIRED TIME ONLY WILL TERMINATE
050230,000030: # INTEGRATION. THE DP REGISTER RFINAL MUST BE SET BY USERS OF INTEGRVS AND INTEGRV, AND MUST BE DONE AFTER THE
050231,000031: # CALL TC INTSTALL.
050232,000032:
050233,000033: # WHEN THE LM IS ON THE LUNAR SURFACE (INDICATED BY LUNAR SURFACE FLAG SET) CALLS TO LEMCONIC, LEMPREC, AND
050234,000034: # INTEGRV WITH VINFLAG = 0 WILL RESULT IN THE USE OF THE PLANETARY INERTIAL ORIENTATION SUBROUTINES TO PROVIDE
050235,000035: # BOTH THE LMS POSITION AND VELOCITY IN THE REFERENCE COORDINATE SYSTEM.
050236,000036: # THE PROGRAM WILL PROVIDE OUTPUT AS IF INTEGRATION WAS USED. THAT IS, THE PUSHLIST WILL BE SET AS NOTED BELOW AND
050237,000037: # THE PERMANENT STATE VECTOR UPDATED WHEN SPECIFIED BY AN INTEGRV CALL.
050238,000038:
050239,000039: # USERS OF INTEGRVS DESIRING INTEGRATION (INTYPFLG = 0) SHOULD NOTE THAT THE OBLATENESS PERTURBATION COMPUTATION
050240,000040: # IN LUNAR ORBIT IS TIME DEPENDENT. THEREFORE, THE USER SHOULD SUPPLY AN INITIAL STATE VECTOR VALID AT SOME REAL
050241,000041: # TIME AND THE DESIRED TIME (TDEC1) ALSO AT SOME REAL TIME. FOR CONIC ,,INTEGRATION,, THE USER MAY STILL USE ZERO
050242,000042: # AS THE INITIAL TIME AND DELTA TIME AS THE DESIRED TIME.
050243,000043:
050244,000044: # 2.0 GENERAL DESCRIPTION
050245,000045: # -----------------------
050246,000046:
050247,000047: # THE INTEGRATION PROGRAM OPERATES AS A CLOSED INTERPRETIVE SUBROUTINE AND PERFORMS THESE FUNCTIONS ---
050248,000048: # 1) INTEGRATES (PRECISION OR CONIC) EITHER CSM OR LM STATE VECTOR
050249,000049: # 2) INTEGRATES THE W-MATRIX
050250,000050: # 3) PERMANENT OR TEMPORARY UPDATE OF THE STATE VECTOR
050251,000051:
050252,000052: # THERE ARE SIX ENTRANCES TO THE INTEGRATION PROGRAM. FOUR OF THESE (CSMPREC, LEMPREC, CSMCONIC, LEMCONIC) SET
050253,000053: # ALL THE FLAGS REQUIRED IN THE INTEGRATION PROGRAM ITSELF TO CAUSE THE PRECISION OR CONIC INTEGRATION (KEPLER) OF
050254,000054: # THE LM OR CSM STATE VECTOR, AS THE NAMES SUGGEST. ONE ENTRANCE (INTEGRVS) PERMITS THE CALLING PROGRAM TO
050255,000055: # PROVIDE A STATE VECTOR TO BE INTEGRATED. THE CALLING PROGRAM MUST SET THE FLAGS INDICATING (1) PRECISION OR
050256,000056: # CONIC INTEGRATION, (2) IN OR OUT OF LUNAR SPHERE, (3) MIDCOURSE OR NOT, AND THE INTEGRATION PROGRAM COMPLETES
050257,000057: # THE FLAG SETTING TO BYPASS W-MATRIX INTEGRATION. THE LAST ENTRANCE (INTEGRV, USED IN GENERAL BY THE
050258,000058: # NAVIGATION PROGRAMS) PERMITS THE CALLER TO SET FIVE FLAGS (NOT MOONFLAG OR MIDFLAG) BUT NOT TO INPUT A STATE
050259,000059: # VECTOR. ANY PROGRAM WHICH CALLS INTEGRVS OR INTEGRV MUST CALL INTSTALL BEFORE IT SETS THE INTEGRATION FLAGS
050260,000060: # AND/OR STATE VECTOR.
050261,000061:
050262,000062: # THREE SETS OF 42 REGISTERS AND 2 FLAGS ARE USED FOR THE STATE VECTORS. TWO SETS, WHICH MAY NOT BE OVERLAYED, ARE
050263,000063: # USED FOR THE PERMANENT STATE VECTORS FOR THE CSM AND LM. THE THIRD SET, WHICH MAY BE OVERLAYED WHEN INTEGRATION
050264,000064: # IS NOT BEING DONE, IS USED IN THE COMPUTATIONS.
050265,000065:
050266,000066: # THE PERMANENT STATE VECTORS WILL BE PERIODICALLY UPDATED SO THAT THE VECTORS WILL NOT BE OLDER THAN 4 TIMESTEPS.
050267,000067: # THE PERMANENT STATE VECTORS WILL ALSO BE UPDATED WHENEVER THE W-MATRIX IS INTEGRATED OR WHEN A CALLER OF INTEGRV
050268,000068: # SETS STATEFLG (THE NAVIGATION PROGRAMS P20, P22.)
050269,000069:
Page 1206 |
050271,000071: # APPENDIX B OF THE USERS GUIDE LISTS THE STATE VECTOR QUANTITIES.
050272,000072:
050273,000073: # 2.1 RESTARTS
050274,000074:
050275,000075: # PHASE CHANGES WILL BE MADE IN THE INTEGRATION PROGRAM ONLY FOR THE INTEGRV ENTRANCE (I.E., WHEN THE W-MATRIX IS
050276,000076: # INTEGRATED OR PERMANENT STATE VECTOR IS UPDATED.) THE GROUP NUMBER USED WILL BE THAT FOR THE P20-25 PROGRAMS
050277,000077: # (I.E., GROUP2) SINCE THE INTEGRV ENTRANCE WILL ONLY BE USED BY THESE PROGRAMS. IF A RESTART OCCURS DURING AN
050278,000078: # INTEGRATION OF THE STATE VECTOR ONLY, THE RECOVERY WILL BE TO THE LAST PHASE IN THE CALLING PROGRAM. CALLING
050279,000079: # PROGRAMS WHICH USE THE INTEGRV OR INTEGRVS ENTRANCE OF INTEGRATION SHOULD ENSURE THAT IF PHASE CHANGING IS DONE
050280,000080: # THAT IT IS PRIOR TO SETTING THE INTEGRATION INPUTS IN THE PUSHLIST.
050281,000081: # THIS IS BECAUSE THE PUSHLIST IS LOST DURING A RESTART.
050282,000082:
050283,000083: # 2.2 SCALING
050284,000084:
050285,000085: # THE INTEGRATION ROUTINE WILL MAINTAIN THE PERMANENT MEMORY STATE VECTORS IN THE SCALING AND UNITS DEFINED IN
050286,000086: # APPENDIX B OF THE USERS GUIDE. THE SCALING OF THE OUTPUT POSITION VECTOR DEPENDS ON THE ORIGIN OF THE COORDINATE
050287,000087: # SYSTEM AT THE DESIRED INTEGRATION TIME. THE COORDINATE SYSTEM TRANSFORMATION WILL BE DONE AUTOMATICALLY ON
050288,000088: # MULTIPLE TIMESTEP ENCKE INTEGRATION ONLY. THUS IT IS POSSIBLE TO HAVE OUTPUT FROM SUCCESSIVE INTEGRATIONS IN
050289,000089: # DIFFERENT SCALING.
050290,000090: # HOWEVER, RATT, VATT WILL ALWAYS BE SCALED THE SAME.
050291,000091:
050292,000092: # 3.0 INPUT/OUTPUT
050293,000093: # ----------------
050294,000094:
050295,000095: # PROGRAM INPUTS ARE THE FLAGS DESCRIBED IN APPENDIX A AND THE PERMANENT STATE VECTOR QUANTITIES DESCRIBED IN AP-
050296,000096: # PENDIX B OF THE USERS GUIDE, PLUS THE DESIRED TIME TO INTEGRATE TO IN TDEC1 (A PUSH LIST LOCATION).
050297,000097: # FOR INTEGRVS, THE RCV,VCV,TET OF THE TEMPORARY STATE VECTOR MUST BE SET, PLUS MOONFLAG AND MIDFLAG
050298,000098:
050299,000099: # FOR SIMULATION THE FOLLOWING QUANTITIES MUST BE PRESET ---
050300,000100: # EARTH MOON
050301,000101: # 29 27
050302,000102: # RRECTCSM(LEM) - RECTIFIED POSITION VECTOR METERS 2 2
050303,000103:
050304,000104: # 7 5
050305,000105: # VRECTCSM(LEM) - RECTIFIED VELOCITY VECTOR M/CSEC 2 2
050306,000106:
050307,000107: # 28 28
050308,000108: # TETCSM(LEM) - TIME STATE VECTOR IS VALID CSEC 2 2
050309,000109: # CUSTOMARILY 0, BUT NOTE LUNAR
050310,000110: # ORBIT DEPENDENCE ON REAL TIME.
050311,000111:
050312,000112: # 22 18
050313,000113: # DELTAVCSM(LEM) - POSITION DEVIATION METERS 2 2
050314,000114: # 0 IF TCCSM(LEM) = 0
050315,000115:
050316,000116: # 3 -1
050317,000117: # NUVCSM(LEM) - VELOCITY DEVIATION M/CSEC 2 2
050318,000118: # 0 IF TCCSM(LEM) = 0
Page 1207 |
050320,000120: # 29 27
050321,000121: # RCVCSM(LEM) - CONIC POSITION METERS 2 2
050322,000122: # EQUALS RRECTCSM(LEM) IF
050323,000123: # TCCSM(LEM) = 0
050324,000124:
050325,000125: # 7 5
050326,000126: # VCVCSM(LEM) - CONIC VELOCITY M/CSEC 2 2
050327,000127: # EQUALS VRECTCSM(LEM) IF
050328,000128: # TCCSM(LEM) = 0
050329,000129:
050330,000130: # 28 28
050331,000131: # TCCSM(LEM) - TIME SINCE RECTIFICATION CSECS 2 2
050332,000132: # CUSTOMARILY 0
050333,000133:
050334,000134: # 1/2 17 16
050335,000135: # XKEPCSM(LEM) - ROOT OF KEPLERS EQUATION M 2 2
050336,000136: # 0 IF TCCSM(LEM) = 0
050337,000137:
050338,000138: # CMOONFLG - PERMANENT FLAGS CORRESPONDING 0 0
050339,000139: # CMIDFLAG TO MOONFLAG AND MIDFLAG 0,1 0,1
050340,000140: # LMOONFLG C = CSM, L = LM 0 0
050341,000141: # LMIDFLG 0,1 0,1
050342,000142:
050343,000143: # SURFFLAG - LUNAR SURFACE FLAG 0,1 0,1
050344,000144:
050345,000145: # IN ADDITION, IF (L)CMIDFLAG IS SET, THE INITIAL INPUT VALUES FOR LUNAR
050346,000146: # SOLAR EPHEMERIDES SUBROUTINE AND PLANETARY INERTIAL ORIENTATION SUB-
050347,000147: # ROUTINE MUST BE PRESET.
050348,000148:
050349,000149: # OUTPUT
050350,000150: # AFTER EVERY CALL TO INTEGRATION
050351,000151: # EARTH MOON
050352,000152: # 29 29
050353,000153: # 0D RATT POSITION METERS 2 2
050354,000154:
050355,000155: # 7 7
050356,000156: # 6D VATT VELOCITY M/CSEC 2 2
050357,000157:
050358,000158: # 28 28
050359,000159: # 12D TAT TIME 2 2
050360,000160:
050361,000161: # 29 27
050362,000162: # 14D RATT1 POSITION METERS 2 2
050363,000163:
050364,000164: # 7 5
050365,000165: # 20D VATT1 VELOCITY M/CSEC 2 2
050366,000166:
050367,000167: # 3 2 36 30
050368,000168: # 26D MU(P) MU M /CS 2 2
050369,000169:
050370,000170: # X1 MUTABLE ENTRY -2 -10D
050371,000171:
050372,000172: # X2 COORDINT
050373,000173: # X2 COORDINATE SYSTEM ORIGEN 0 2
050374,000174: # (THIS, NOT MOONFLAG, SHOULD BE
Page 1208 |
050376,000176: # USED TO DETERMINE ORIGIN.)
050377,000177:
050378,000178: # IN ADDITION TO THE ABOVE, THE PERMANENT STATE VECTOR IS UPDATED WHENEVER
050379,000179: # STATEFLG WAS SET AND WHENEVER A W-MATRIX IS TO BE INTEGRATED. THE PUSH
050380,000180: # COUNTER IS SET TO 0 AND OVERFLOW IS CLEARED BEFORE RETURNING TO THE
050381,000181: # CALLING PROGRAM.
050382,000182:
050383,000183: # 4.0 CALLING SEQUENCES AND SAMPLE CODE
050384,000184: # -------------------------------------
050385,000185:
050386,000186: # A) PRECISION ORBITAL INTEGRATION. CSMPREC, LEMPREC ENTRANCES
050387,000187: # L-X STORE TIME TO 95T5791T5 T 95 PUS L9ST (T4531)
050388,000188: # L CALL
050389,000189: # L+1 CSMPREC (OR LEMPREC)
050390,000190: # L+2 RETURN
050391,000191: # INPUT 28
050392,000192: # TDEC1 (PD 32D) TIME TO INTEGRATE TO...CENTISECONDS SCALED 2
050393,000193: # OUTPUT
050394,000194: # THE DATA LISTED IN SECTION 3.0 PLUS
050395,000195: # RQVV POSITION VECTOR OF VEHICLE WITH RESPECT TO SECONDARY
050396,000196: # BODY... METERS B-29 ONLY IF MIDFLAG = DIMOFLAG = 1
050397,000197: # B) CONIC INTEGRATION. CSMCONIC, LEMCONIC ENTRANCES
050398,000198: # L-X STORE TIME IN PUSH LIST (TDEC1)
050399,000199: # L CALL
050400,000200: # L+1 CSMCONIC (OR LEMCONIC)
050401,000201: # INPUT/OUTPUT
050402,000202: # SAME AS PRECISION INTEGRATION, EXCEPT RQVV NOT SET
050403,000203: # C) INTEGRATE GIVEN STATE VECTOR. INTEGRVS ENTRANCE
050404,000204: # CALL
050405,000205: # INTSTALL
050406,000206: # VLOAD
050407,000207: # POSITION VECTOR
050408,000208: # STOVL RCV
050409,000209: # VELOCITY VECTOR
050410,000210: # STODL VCV
050411,000211: # TIME STATE VECTOR VALID
050412,000212: # STODL TET
050413,000213: # FINAL RADIUS
050414,000214: # STORE RFINAL
050415,000215: # SET(CLEAR) SET(CLEAR)
050416,000216: # INTYPFLAG
050417,000217: # MOONFLAG
050418,000218: # SET(CLEAR) DLOAD
050419,000219: # DESIRED TIME
050420,000220: # STCALL TDEC1
050421,000221: # INTEGRVS
050422,000222: # INPUT
050423,000223: # RCV POSITION VECTOR METERS
050424,000224: # VCV VELOCITY VECTOR M/CSEC
050425,000225: # TET TIME OF STATE VECTOR (MAY = 0) CSEC B-28
Page 1209 |
050427,000227: # TDEC1 TIME TO INTEGRATE TO CSEC B-28 (PD 32D)
050428,000228: # (MAY BE INCREMENT IF TET=0)
050429,000229: # OUTPUT
050430,000230: # SAME AS FOR PRECISION OR CONIC INTEGRATION,
050431,000231: # DEPENDING ON INTYPFLG.
050432,000232: # D) INTEGRATE STATE VECTOR. INTGRV ENTRANCE
050433,000233: # L-X STORE TIME IN PUSH LIST (TDEC1) (MAY BE DONE AFTER CALL TO INTSTALL)
050434,000234: # L-8 CALL
050435,000235: # L-7
050436,000236: # L-6 SET(CLEAR) SET(CLEAR)
050437,000237: # L-5 VINTFLAG 1=CSM, 0=LM
050438,000238: # L-4 INTYPFLAG 1=CONIC, 0=PRECISION
050439,000239: # L-3 SET(CLEAR) SET(CLEAR)
050440,000240: # L-2 DIMOFLAG 1=W-MATRIX, 0=NO W-MATRIX
050441,000241: # L-1 D6OR9FLG 1=9X9, 0=6X6
050442,000242: # L SET DLOAD
050443,000243: # L+1 STATEFLG DESIRE PERMANENT UPDATE
050444,000244: # L+2 FINAL RAD. OF STATE VECTOR
050445,000245: # L+3 STCALL RFINAL
050446,000246: # L+4 INTEGRV
050447,000247: # L CALL NORMAL USE -- WILL UPDATE STATE
050448,000248: # L+1 INTEGRV VECTOR IF DIMOFLAG=1. (STATEFLG IS
050449,000249: # L+2 RETURN ALWAYS RESET IN INTEGRATION AFTER
050450,000250: # IT IS USED.)
050451,000251: # INPUT
050452,000252: # TDEC1 (PD 32D) TIME TO INTEGRATE TO CSEC B-28
050453,000253: # OUTPUT
050454,000254: # SAME AS FOR PRECISION OR CONIC INTEGRATION
050455,000255: # THE PROGRAM WILL SET MOONFLAG, MIDFLAG DEPENDING ON
050456,000256: # THE PERMANENT STATE VECTOR REPRESENTATION.
050457,000257:
050458,000258: 11,2376 BANK 11
050459,000259: 13,2000 SETLOC INTINIT
050460,000260: 13,2000 BANK
050461,000261: 13,2604 E3,1554 EBANK= RRECTCSM
050462,000262: 13,2604 COUNT* $$/INTIN
050463,000263: 13,2604 05353 STATEINT TC PHASCHNG
050464,000264: 13,2605 00052 OCT 00052
050465,000265: 13,2606 35017 CAF PRIO5
050466,000266: 13,2607 05105 TC FINDVAC
050467,000267: 13,2610 E3,1554 EBANK= RRECTCSM
050468,000268: 13,2610 02613 26063 2CADR STATINT1
050469,000269:
050470,000270: 13,2612 05261 TC TASKOVER
050471,000271: 13,2613 06037 STATINT1 TC INTPRET
050472,000272: 13,2614 47014 BON RTB
050473,000273: 13,2615 04712 QUITFLAG # KILL INTEGRATION UNTIL NEXT POO.
050474,000274: 13,2616 26653 NOINT
050475,000275: 13,2617 21573 LOADTIME
050476,000276: 13,2620 00041 STORE TDEC1
Page 1210 |
050478,000278: 13,2621 77624 CALL
050479,000279: 13,2622 27414 INTSTALL
050480,000280: 13,2623 45014 SET CALL
050481,000281: 13,2624 01076 NODOFLAG
050482,000282: 13,2625 26644 SETIFLGS
050483,000283: 13,2626 77650 GOTO
050484,000284: 13,2627 26026 STATEUP
050485,000285: 13,2630 00003 25140 600SECS 2DEC 60000 B-28
050486,000286:
050487,000287: 13,2632 77414 ENDINT CLEAR EXIT
050488,000288: 13,2633 01672 STATEFLG
050489,000289: 13,2634 05353 TC PHASCHNG
050490,000290: 13,2635 20032 OCT 20032
050491,000291: 13,2636 00006 EXTEND
050492,000292: 13,2637 32631 DCA 600SECS
050493,000293: 13,2640 05277 TC LONGCALL
050494,000294: 13,2641 E3,1626 EBANK= RRECTHIS
050495,000295: 13,2641 02604 26063 2CADR STATEINT
050496,000296:
050497,000297: 13,2643 05155 TC ENDOFJOB
050498,000298: 13,2644 43014 SETIFLGS SET CLEAR
050499,000299: 13,2645 01472 STATEFLG
050500,000300: 13,2646 01673 INTYPFLG
050501,000301: 13,2647 43014 CLEAR CLEAR
050502,000302: 13,2650 01676 DIM0FLAG
050503,000303: 13,2651 01675 D6OR9FLG
050504,000304: 13,2652 77616 RVQ
050505,000305: 13,2653 77776 NOINT EXIT
050506,000306: 13,2654 05353 TC PHASCHNG
050507,000307: 13,2655 00002 OCT 00002
050508,000308:
050509,000309: 13,2656 05516 TC DOWNFLAG
050510,000310: 13,2657 00221 ADRES QUITFLAG
050511,000311: 13,2660 05155 TC ENDOFJOB
050512,000312:
050513,000313: # ATOPCSM TRANSFERS RRECT TO RRECT +41 TO RRECTCSM TO RRECTCSM +41
050514,000314:
050515,000315: # CALLING SEQUENCE
050516,000316: # L CALL
050517,000317: # L+1 ATOPCSM
050518,000318:
050519,000319: # NORMAL EXIT AT L+2
050520,000320:
050521,000321: 13,2661 47020 ATOPCSM STQ RTB
050522,000322: 13,2662 00051 S2
050523,000323: 13,2663 26674 MOVEACSM
050524,000324: 13,2664 45014 SET CALL
050525,000325: 13,2665 04063 CMOONFLG
050526,000326: 13,2666 26114 SVDWN1
050527,000327: 13,2667 43014 BON CLRGO
Page 1211 |
050529,000329: 13,2670 00303 MOONFLAG
050530,000330: 13,2671 00051 S2
050531,000331: 13,2672 04223 CMOONFLG
050532,000332: 13,2673 00051 S2
050533,000333: 13,2674 03036 MOVEACSM TC SETBANK
050534,000334: 13,2675 55500 TS DIFEQCNT # INITIALIZE INDEX
050535,000335: 13,2676 51500 INDEX DIFEQCNT
050536,000336: 13,2677 31502 CA RRECT
050537,000337: 13,2700 51500 INDEX DIFEQCNT
050538,000338: 13,2701 55554 TS RRECTCSM
050539,000339: 13,2702 11500 CCS DIFEQCNT # IS TRANSFER COMPLETE
050540,000340: 13,2703 12675 TCF MOVEACSM +1 # NO-LOOP
050541,000341: 13,2704 06061 TC DANZIG # COMPLETE - RETURN
050542,000342:
050543,000343: # PTOACSM TRANSFERS RRECTCSM TO RRECTCSM +41 TO RRECT TO RRECT +41
050544,000344:
050545,000345: # CALLING SEQUENCE
050546,000346: # L CALL
050547,000347: # PTOACSM
050548,000348:
050549,000349: # NORMAL EXIT AT L+2
050550,000350:
050551,000351: 13,2705 43034 PTOACSM RTB BON
050552,000352: 13,2706 26723 MOVEPCSM
050553,000353: 13,2707 04303 CMOONFLG
050554,000354: 13,2710 26716 SETMOON
050555,000355: 13,2711 66214 CLRMOON CLEAR SSP
050556,000356: 13,2712 00263 MOONFLAG
050557,000357: 13,2713 02031 PBODY
050558,000358: 13,2714 00000 0
050559,000359: 13,2715 77616 RVQ
050560,000360: 13,2716 66214 SETMOON SET SSP
050561,000361: 13,2717 00063 MOONFLAG
050562,000362: 13,2720 02031 PBODY
050563,000363: 13,2721 00002 2
050564,000364: 13,2722 77616 RVQ
050565,000365: 13,2723 03036 MOVEPCSM TC SETBANK
050566,000366: 13,2724 55500 TS DIFEQCNT
050567,000367: 13,2725 51500 INDEX DIFEQCNT
050568,000368: 13,2726 31554 CA RRECTCSM
050569,000369: 13,2727 51500 INDEX DIFEQCNT
050570,000370: 13,2730 55502 TS RRECT
050571,000371: 13,2731 11500 CCS DIFEQCNT
050572,000372: 13,2732 12724 TCF MOVEPCSM +1
050573,000373: 13,2733 06061 TC DANZIG
050574,000374:
050575,000375: # ATOPLEM TRANSFERS RRECT TO RRECT +41 TO RRECTLEM TO RRECTLEM +41
050576,000376: 13,2734 47020 ATOPLEM STQ RTB
Page 1212 |
050578,000378: 13,2735 00051 S2
050579,000379: 13,2736 26747 MOVEALEM
050580,000380: 13,2737 45014 SET CALL
050581,000381: 13,2740 04064 LMOONFLG
050582,000382: 13,2741 26070 SVDWN2
050583,000383: 13,2742 43014 BON CLRGO
050584,000384: 13,2743 00303 MOONFLAG
050585,000385: 13,2744 00051 S2
050586,000386: 13,2745 04224 LMOONFLG
050587,000387: 13,2746 00051 S2
050588,000388: 13,2747 03036 MOVEALEM TC SETBANK
050589,000389: 13,2750 55500 TS DIFEQCNT
050590,000390: 13,2751 51500 INDEX DIFEQCNT
050591,000391: 13,2752 31502 CA RRECT
050592,000392: 13,2753 51500 INDEX DIFEQCNT
050593,000393: 13,2754 55626 TS RRECTLEM
050594,000394: 13,2755 11500 CCS DIFEQCNT
050595,000395: 13,2756 12750 TCF MOVEALEM +1
050596,000396: 13,2757 06061 TC DANZIG
050597,000397:
050598,000398: # PTOALEM TRANSFERS RRECTLEM TO RRECTLEM +41 TO RRECT TO RRECT +41
050599,000399:
050600,000400: 13,2760 47014 PTOALEM BON RTB
050601,000401: 13,2761 04307 SURFFLAG
050602,000402: 13,2762 27001 USEPIOS
050603,000403: 13,2763 26770 MOVEPLEM
050604,000404: 13,2764 52014 BON GOTO
050605,000405: 13,2765 04304 LMOONFLG
050606,000406: 13,2766 26716 SETMOON
050607,000407: 13,2767 26711 CLRMOON
050608,000408: 13,2770 03036 MOVEPLEM TC SETBANK
050609,000409: 13,2771 55500 TS DIFEQCNT
050610,000410: 13,2772 51500 INDEX DIFEQCNT
050611,000411: 13,2773 31626 CA RRECTLEM
050612,000412: 13,2774 51500 INDEX DIFEQCNT
050613,000413: 13,2775 55502 TS RRECT
050614,000414: 13,2776 11500 CCS DIFEQCNT
050615,000415: 13,2777 12771 TCF MOVEPLEM +1
050616,000416: 13,3000 06061 TC DANZIG
050617,000417:
050618,000418: 13,3001 77201 USEPIOS SETPD VLOAD
050619,000419: 13,3002 00001 0
050620,000420: 13,3003 02023 RLS
050621,000421: 13,3004 41525 PDDL PUSH
050622,000422: 13,3005 00041 TDEC1
050623,000423: 13,3006 15517 STODL TET
050624,000424: 13,3007 27712 5/8
050625,000425: 13,3010 77624 CALL
Page 1213 |
050627,000427: 13,3011 55716 RP-TO-R
050628,000428: 13,3012 25535 STOVL RCV
050629,000429: 13,3013 24001 ZUNIT
050630,000430: 13,3014 14001 STODL 0D
050631,000431: 13,3015 01517 TET
050632,000432: 13,3016 14007 STODL 6D
050633,000433: 13,3017 27712 5/8
050634,000434: 13,3020 45014 SET CALL # NEEDED FOR SETTING X1 ON EXIT
050635,000435: 13,3021 00063 MOONFLAG
050636,000436: 13,3022 55716 RP-TO-R
050637,000437: 13,3023 74235 VXV VXSC
050638,000438: 13,3024 01535 RCV
050639,000439: 13,3025 26001 OMEGMOON
050640,000440: 13,3026 25543 STOVL VCV
050641,000441: 13,3027 24007 ZEROVEC
050642,000442: 13,3030 01521 STORE TDELTAV
050643,000443: 13,3031 67174 AXT,2 SXA,2
050644,000444: 13,3032 00002 2
050645,000445: 13,3033 02030 PBODY
050646,000446: 13,3034 35527 STCALL TNUV
050647,000447: 13,3035 27157 A-PCHK
050648,000448: 13,3036 33042 SETBANK CAF INTBANK
050649,000449: 13,3037 54006 TS BBANK
050650,000450: 13,3040 33452 CAF FORTYONE
050651,000451: 13,3041 00002 TC Q
050652,000452: 13,3042 E3,1554 EBANK= RRECTCSM
050653,000453: 13,3042 26063 INTBANK BBCON INTEGRV
050654,000454:
050655,000455: # SPECIAL PURPOSE ENTRIES TO ORBITAL INTEGRATION. THESE ROUTINES PROVIDE ENTRANCES TO INTEGRATION WITH
050656,000456: # APPROPRIATE SWITCHES SET OR CLEARED FOR THE DESIRED INTEGRATION.
050657,000457:
050658,000458: # CSMPREC AND LEMPREC PERFORM ORBIT INTEGRATION BY THE ENCKE METHOD TO THE TIME INDICATED IN TDEC1
050659,000459: # ACCELERATIONS DUE TO OBLATENESS ARE INCLUDED. NO W-MATRIX INT. IS DONE.
050660,000460: # THE PERMANENT STATE VECTOR IS NOT UPDATED.
050661,000461:
050662,000462: # CSMCONIC AND LEMCONIC PERFORM ORBIT INTEG. BY KEPLERS METHOD TO THE TIME INDICATED IN TDEC1
050663,000463: # NO DISTURBING ACCELERATIONS ARE INCLUDED. IN THE PROGRAM FLOW THE GIVEN
050664,000464: # STATE VECTOR IS RECTIFIED BEFORE SOLUTION OF KEPLERS EQUATION
050665,000465:
050666,000466: # THE ROUTINES ASSUME THAT THE CSM (LEM) STATE VECTOR IN P-MEM IS VALID.
050667,000467: # SWITCHES SET PRIOR TO ENTRY TO THE MAIN INTEG. PROG ARE AS FOLLOWS
050668,000468: # CSMPREC CSMCONIC LEMPREC LEMCONIC
050669,000469: # VINTFLAG SET SET CLEAR CLEAR
050670,000470: # INTYPFLG CLEAR SET CLEAR SET
050671,000471: # DIM0FLAG CLEAR CLEAR CLEAR CLEAR
050672,000472:
050673,000473: # CALLING SEQUENCE
050674,000474: # L-X STORE TDEC1
050675,000475: # L CALL (STCALL TDEC1)
Page 1214 |
050677,000477: # L+1 CSMPREC (CSMCONIC, LEMPREC, LEMCONIC)
050678,000478:
050679,000479: # NORMAL EXIT TO L+2
050680,000480:
050681,000481: # SUBROUTINES CALLED
050682,000482: # INTEGRV1
050683,000483: # PRECOUT FOR CSMPREC AND LEMPREC
050684,000484: # CONICOUT FOR CSMCONIC AND LEMCONIC
050685,000485:
050686,000486: # OUTPUT - SEE PAGE 2 OF THIS LOG SECTION
050687,000487:
050688,000488: # INPUT
050689,000489: # TDEC1 TIME TO INTEGRATE TO. CSECS B-28
050690,000490:
050691,000491: 13,3043 45020 CSMPREC STQ CALL
050692,000492: 13,3044 00046 X1
050693,000493: 13,3045 27414 INTSTALL
050694,000494: 13,3046 43130 SXA,1 SET
050695,000495: 13,3047 02102 IRETURN
050696,000496: 13,3050 01474 VINTFLAG
050697,000497:
050698,000498: 13,3051 43014 IFLAGP SET CLEAR
050699,000499: 13,3052 01467 PRECIFLG
050700,000500: 13,3053 01676 DIM0FLAG
050701,000501: 13,3054 77614 CLRGO
050702,000502: 13,3055 01633 INTYPFLG
050703,000503: 13,3056 27136 INTEGRV1
050704,000504: 13,3057 45020 LEMPREC STQ CALL
050705,000505: 13,3060 00046 X1
050706,000506: 13,3061 27414 INTSTALL
050707,000507: 13,3062 43130 SXA,1 CLRGO
050708,000508: 13,3063 02102 IRETURN
050709,000509: 13,3064 01634 VINTFLAG
050710,000510: 13,3065 27051 IFLAGP
050711,000511:
050712,000512: 13,3066 45020 CSMCONIC STQ CALL
050713,000513: 13,3067 00046 X1
050714,000514: 13,3070 27414 INTSTALL
050715,000515: 13,3071 43130 SXA,1 SET
050716,000516: 13,3072 02102 IRETURN
050717,000517: 13,3073 01474 VINTFLAG
050718,000518: 13,3074 43014 IFLAGC CLEAR SETGO
050719,000519: 13,3075 01676 DIM0FLAG
050720,000520: 13,3076 01433 INTYPFLG
050721,000521: 13,3077 27136 INTEGRV1
050722,000522: 13,3100 45020 LEMCONIC STQ CALL
050723,000523: 13,3101 00046 X1
050724,000524: 13,3102 27414 INTSTALL
050725,000525: 13,3103 43130 SXA,1 CLRGO
050726,000526: 13,3104 02102 IRETURN
Page 1215 |
050728,000528: 13,3105 01634 VINTFLAG
050729,000529: 13,3106 27074 IFLAGC
050730,000530:
050731,000531: 13,3107 66214 INTEGRVS SET SSP
050732,000532: 13,3110 01467 PRECIFLG
050733,000533: 13,3111 02031 PBODY
050734,000534: 13,3112 00000 0
050735,000535: 13,3113 66214 BOF SSP
050736,000536: 13,3114 00343 MOONFLAG
050737,000537: 13,3115 27120 +3
050738,000538: 13,3116 02031 PBODY
050739,000539: 13,3117 00002 2
050740,000540: 13,3120 77220 STQ VLOAD
050741,000541: 13,3121 02102 IRETURN
050742,000542: 13,3122 24007 ZEROVEC
050743,000543: 13,3123 01521 STORE TDELTAV
050744,000544: 13,3124 35527 STCALL TNUV
050745,000545: 13,3125 23441 RECTIFY
050746,000546: 13,3126 43014 CLEAR SET
050747,000547: 13,3127 01676 DIM0FLAG
050748,000548: 13,3130 04062 NEWIFLG
050749,000549: 13,3131 77614 SETGO
050750,000550: 13,3132 04020 RPQFLAG
050751,000551: 13,3133 27150 ALOADED
050752,000552:
050753,000553: # INTEGRV IS AN ENTRY TO ORBIT INTEGRATION WHICH PERMITS THE CALLER,
050754,000554: # NORMALLY THE NAVIGATION PROGRAM, TO SET THE INTEG. FLAGS. THE ROUTINE
050755,000555: # IS ENTERED AT INTEGRV1 BY CSMPREC ET. AL. AND AT ALOADED BY INTEGRVS.
050756,000556: # THE ROUTINE SETS UP A-MEMORY IF ENTERED AT INTEGRV,1 AND SETS THE INTEG.
050757,000557: # PROGRAM FOR PRECISION OR CONIC
050758,000558:
050759,000559: # THE CALLER MUST FIRST CALL INTSTALL TO CHECK IF INTEG. IS IN USE BEFORE
050760,000560: # SETTING ANY FLAGS.
050761,000561:
050762,000562: # THE FLAGS WHICH SHOULD BE SET OR CLEARED ARE
050763,000563: # VINTFLAG (IGNORED WHEN ENTERED FROM INTEGRVS)
050764,000564: # INTYPFLG
050765,000565: # DIM0FLAG
050766,000566: # D6OR9FLG
050767,000567:
050768,000568: # CALLING SEQUENCE
050769,000569: # L-X CALL
050770,000570: # L-Y INTSTALL
050771,000571: # L-1 SET OR CLEAR ALL FOUR FLAGS. ALSO CAN SET STATEFLG IF DESIRED
050772,000572: # AND DIM0FLAG IS CLEAR.
050773,000573: # L CALL
050774,000574: # L+1 INTEGRV
050775,000575:
050776,000576: # INITIALIZATION
050777,000577: # FLAGS AS ABOVE
050778,000578: # STORE TIME TO INTEGRATE TO IN TDEC1
050779,000579:
050780,000580: # OUTPUT
050781,000581: # RATT AS
050782,000582: # VATT DEFINED
Page 1216 |
050784,000584: # TAT BEFORE
050785,000585:
050786,000586: 13,3134 77620 INTEGRV STQ
050787,000587: 13,3135 02102 IRETURN
050788,000588: 13,3136 43014 INTEGRV1 SET SET
050789,000589: 13,3137 04060 RPQFLAG
050790,000590: 13,3140 04062 NEWIFLG
050791,000591: 13,3141 77731 INTEGRV2 SSP
050792,000592: 13,3142 00053 QPRET
050793,000593: 13,3143 27150 ALOADED
050794,000594: 13,3144 52014 BON GOTO
050795,000595: 13,3145 01714 VINTFLAG
050796,000596: 13,3146 26705 PTOACSM
050797,000597: 13,3147 26760 PTOALEM
050798,000598: 13,3150 77745 ALOADED DLOAD
050799,000599: 13,3151 00041 TDEC1
050800,000600: 13,3152 01116 STORE TDEC
050801,000601: 13,3153 52014 BOFF GOTO
050802,000602: 13,3154 01753 INTYPFLG
050803,000603: 13,3155 27257 TESTLOOP
050804,000604: 13,3156 27243 RVCON
050805,000605: 13,3157 77414 A-PCHK BOF EXIT
050806,000606: 13,3160 01752 STATEFLG
050807,000607: 13,3161 27200 RECTOUT
050808,000608: 13,3162 05353 TC PHASCHNG
050809,000609: 13,3163 04022 OCT 04022
050810,000610: 13,3164 05504 TC UPFLAG # PHASE CHANGE HAS OCCURRED BETWEEN
050811,000611: 13,3165 00236 ADRES REINTFLG # INTSTALL AND INTWAKE
050812,000612: 13,3166 06037 TC INTPRET
050813,000613: 13,3167 77731 SSP
050814,000614: 13,3170 00053 QPRET
050815,000615: 13,3171 27176 PHEXIT
050816,000616: 13,3172 52014 BON GOTO
050817,000617: 13,3173 01714 VINTFLAG
050818,000618: 13,3174 26661 ATOPCSM
050819,000619: 13,3175 26734 ATOPLEM
050820,000620: 13,3176 77624 PHEXIT CALL
050821,000621: 13,3177 11244 GRP2PC
050822,000622: 13,3200 45001 RECTOUT SETPD CALL
050823,000623: 13,3201 00001 0
050824,000624: 13,3202 23441 RECTIFY
050825,000625: 13,3203 53775 VLOAD VSL*
050826,000626: 13,3204 01503 RRECT
050827,000627: 13,3205 57576 0,2
050828,000628: 13,3206 53715 PDVL VSL* # RATT TO PD0
050829,000629: 13,3207 01511 VRECT
050830,000630: 13,3210 57576 0,2
050831,000631: 13,3211 63325 PDDL PDVL # VATT TO PD6 TAT TO PD12
050832,000632: 13,3212 01517 TET
Page 1217 |
050834,000634: 13,3213 01503 RRECT
050835,000635: 13,3214 64715 PDVL PDDL*
050836,000636: 13,3215 01511 VRECT
050837,000637: 13,3216 51770 MUEARTH,2
050838,000638: 13,3217 76006 PUSH AXT,1
050839,000639: 13,3220 77765 DEC -10 B-14
050840,000640: 13,3221 76014 BON AXT,1
050841,000641: 13,3222 00303 MOONFLAG
050842,000642: 13,3223 27225 +2
050843,000643: 13,3224 77775 DEC -2 B-14
050844,000644: 13,3225 40001 INTEXIT SETPD BOV
050845,000645: 13,3226 00001 0
050846,000646: 13,3227 27230 +1
050847,000647: 13,3230 43014 CLEAR CLEAR
050848,000648: 13,3231 04676 AVEMIDSW # ALLOW UPDATE OF DOWNLINK STATE VECTOR
050849,000649: 13,3232 01667 PRECIFLG
050850,000650: 13,3233 77614 CLEAR
050851,000651: 13,3234 01672 STATEFLG
050852,000652: 13,3235 77535 SLOAD EXIT
050853,000653: 13,3236 02103 IRETURN
050854,000654: 13,3237 30154 CA MPAC
050855,000655: 13,3240 50120 INDEX FIXLOC
050856,000656: 13,3241 54052 TS QPRET
050857,000657: 13,3242 03425 TC INTWAKE
050858,000658:
050859,000659: # RVCON SETS UP ORBIT INTEGRATION TO DO A CONIC SOLUTION FOR POSITION AND
050860,000660: # VELOCITY FOR THE INTERVAL (TET-TDEC)
050861,000661:
050862,000662: 13,3243 45345 RVCON DLOAD DSU
050863,000663: 13,3244 01116 TDEC
050864,000664: 13,3245 01517 TET
050865,000665: 13,3246 36074 STCALL TAU.
050866,000666: 13,3247 23441 RECTIFY
050867,000667: 13,3250 77624 CALL
050868,000668: 13,3251 22376 KEPPREP
050869,000669: 13,3252 43345 DLOAD DAD
050870,000670: 13,3253 01551 TC
050871,000671: 13,3254 01517 TET
050872,000672: 13,3255 35517 STCALL TET
050873,000673: 13,3256 27200 RECTOUT
050874,000674:
Page 1218 |
050876,000676: # TESTLOOP
050877,000677:
050878,000678: 13,3257 43014 TESTLOOP BOF CLRGO
050879,000679: 13,3260 04752 QUITFLAG
050880,000680: 13,3261 27264 +3
050881,000681: 13,3262 01632 STATEFLG
050882,000682: 13,3263 27225 INTEXIT # STOP INTEGRATION
050883,000683: 13,3264 73001 +3 SETPD LXA,2
050884,000684: 13,3265 00013 10D
050885,000685: 13,3266 02030 PBODY
050886,000686: 13,3267 51575 VLOAD ABVAL
050887,000687: 13,3270 01535 RCV
050888,000688: 13,3271 43006 PUSH CLEAR # RC TO 10D
050889,000689: 13,3272 00262 MIDFLAG
050890,000690: 13,3273 50023 DSU* BMN # MIDFLAG=0 IF R G.T. RMP
050891,000691: 13,3274 53755 RME,2
050892,000692: 13,3275 27300 +3
050893,000693: 13,3276 77614 SET
050894,000694: 13,3277 00062 MIDFLAG
050895,000695: 13,3300 41345 NORFINAL DLOAD DMP
050896,000696: 13,3301 00013 10D
050897,000697: 13,3302 00043 34D
050898,000698: 13,3303 55762 SR1R DDV*
050899,000699: 13,3304 51770 MUEARTH,2
050900,000700: 13,3305 41366 SQRT DMP
050901,000701: 13,3306 25752 .3D
050902,000702: 13,3307 40442 SR3 SR4 # DT IS TRUNCATED TO A MULTIPLE
050903,000703: 13,3310 54345 DLOAD SL
050904,000704: 13,3311 00155 MPAC
050905,000705: 13,3312 20220 15D # OF 128 CSECS.
050906,000706: 13,3313 40006 PUSH BOV
050907,000707: 13,3314 27341 MAXDT
050908,000708: 13,3315 50021 BDSU BMN
050909,000709: 13,3316 27413 DT/2MAX
050910,000710: 13,3317 27341 MAXDT
050911,000711: 13,3320 45345 DT/2COMP DLOAD DSU
050912,000712: 13,3321 01116 TDEC
050913,000713: 13,3322 01517 TET
050914,000714: 13,3323 54234 RTB SL
050915,000715: 13,3324 21612 SGNAGREE
050916,000716: 13,3325 20211 8D
050917,000717: 13,3326 02076 STORE DT/2 # B-19
050918,000718: 13,3327 51400 BOV ABS
050919,000719: 13,3330 27345 GETMAXDT
050920,000720: 13,3331 50025 DSU BMN # IS TIME TO INTEG. TO GR THAN MAXTIME
050921,000721: 13,3332 00015 12D
050922,000722: 13,3333 27351 P00HCHK
050923,000723: 13,3334 75345 USEMAXDT DLOAD SIGN
050924,000724: 13,3335 00015 12D
050925,000725: 13,3336 02076 DT/2
Page 1219 |
050927,000727: 13,3337 36076 STCALL DT/2
050928,000728: 13,3340 27351 P00HCHK
050929,000729: 13,3341 65345 MAXDT DLOAD PDDL # EXCHANGE DT/2MAX WITH COMPUTED MAX.
050930,000730: 13,3342 27413 DT/2MAX
050931,000731: 13,3343 77650 GOTO
050932,000732: 13,3344 27320 DT/2COMP
050933,000733: 13,3345 77634 GETMAXDT RTB
050934,000734: 13,3346 21712 SIGNMPAC
050935,000735: 13,3347 36076 STCALL DT/2
050936,000736: 13,3350 27334 USEMAXDT
050937,000737: 13,3351 51545 P00HCHK DLOAD ABS
050938,000738: 13,3352 02076 DT/2
050939,000739: 13,3353 50025 DSU BMN
050940,000740: 13,3354 27411 DT/2MIN
050941,000741: 13,3355 27157 A-PCHK
050942,000742: 13,3356 46135 SLOAD BHIZ
050943,000743: 13,3357 01012 MODREG
050944,000744: 13,3360 27363 +3
050945,000745: 13,3361 77650 GOTO
050946,000746: 13,3362 23252 TIMESTEP
050947,000747: 13,3363 77614 BON # WAS THIS CALL VIA CSM(LEM)PREC
050948,000748: 13,3364 01707 PRECIFLG
050949,000749: 13,3365 23252 TIMESTEP # YES
050950,000750: 13,3366 45345 DLOAD DSU
050951,000751: 13,3367 02076 DT/2
050952,000752: 13,3370 00015 12D
050953,000753: 13,3371 43040 BMN BOFCLR
050954,000754: 13,3372 27157 A-PCHK
050955,000755: 13,3373 04242 NEWIFLG
050956,000756: 13,3374 23252 TIMESTEP
050957,000757: 13,3375 45345 DLOAD DSU
050958,000758: 13,3376 01116 TDEC
050959,000759: 13,3377 01517 TET
050960,000760: 13,3400 77640 BMN # NO BACKWARD INTEGRATION
050961,000761: 13,3401 27225 INTEXIT
050962,000762: 13,3402 40525 PDDL SR4
050963,000763: 13,3403 02076 DT/2 # IS 4(DT) LS (TDEC - TET)
050964,000764: 13,3404 44322 SR2R BDSU # NO
050965,000765: 13,3405 52040 BMN GOTO
050966,000766: 13,3406 27225 INTEXIT
050967,000767: 13,3407 23252 TIMESTEP
050968,000768: 13,3410 00000 01400 DT/2MIN 2DEC 3 B-20
050969,000769:
050970,000770: 13,3412 14152 00000 DT/2MAX 2DEC 4000 E2 B-20
050971,000771:
050972,000772: 13,3414 77776 INTSTALL EXIT
050973,000773: 13,3415 30106 CA RASFLAG
050974,000774: 13,3416 73466 MASK INTBITAB # IS THIS STALL AREA FREE
050975,000775: 13,3417 00006 EXTEND
050976,000776: 13,3420 13460 BZF OKTOGRAB # YES
Page 1220 |
050978,000778: 13,3421 33465 CAF WAKESTAL
050979,000779: 13,3422 05133 TC JOBSLEEP
050980,000780: 13,3423 77776 INTWAKE0 EXIT
050981,000781: 13,3424 13445 TCF INTWAKE1
050982,000782:
050983,000783: 13,3425 40106 INTWAKE CS RASFLAG # IS THIS INTSTALLED ROUTINE TO BE
050984,000784: 13,3426 74745 MASK REINTBIT # RESTARTED
050985,000785: 13,3427 10000 CCS A
050986,000786: 13,3430 03445 TC INTWAKE1 # NO
050987,000787:
050988,000788: 13,3431 50120 INDEX FIXLOC
050989,000789: 13,3432 30052 CA QPRET
050990,000790: 13,3433 55055 TS TBASE2 # YES, DONT RESTART WITH SOMEONE ELSES Q
050991,000791:
050992,000792: 13,3434 05353 TC PHASCHNG
050993,000793: 13,3435 04022 OCT 04022
050994,000794:
050995,000795: 13,3436 31055 CA TBASE2
050996,000796: 13,3437 50120 INDEX FIXLOC
050997,000797: 13,3440 54052 TS QPRET
050998,000798:
050999,000799: 13,3441 34745 CAF REINTBIT
051000,000800: 13,3442 70106 MASK RASFLAG
051001,000801: 13,3443 00006 EXTEND
051002,000802: 13,3444 13463 BZF GOBAC # DONT INTWAKE IF WE CAME HERE VIA RESTART
051003,000803:
051004,000804: 13,3445 33465 INTWAKE1 CAF WAKESTAL
051005,000805: 13,3446 00004 INHINT
051006,000806: 13,3447 05137 TC JOBWAKE
051007,000807: 13,3450 10064 CCS LOCCTR
051008,000808: 13,3451 13445 TCF INTWAKE1
051009,000809: 13,3452 00051 FORTYONE DEC 41 B-14
051010,000810: 13,3453 43466 CS INTBITAB
051011,000811: 13,3454 70106 MASK RASFLAG
051012,000812: 13,3455 54106 TS RASFLAG # RELEASE STALL AREA
051013,000813: 13,3456 00003 RELINT
051014,000814: 13,3457 13463 TCF GOBAC
051015,000815: 13,3460 34736 OKTOGRAB CAF INTFLBIT
051016,000816: 13,3461 00004 INHINT
051017,000817: 13,3462 26106 ADS RASFLAG
051018,000818: 13,3463 06037 GOBAC TC INTPRET
051019,000819: 13,3464 77616 RVQ
051020,000820: 13,3465 27415 WAKESTAL CADR INTSTALL +1
051021,000821: 13,3466 20100 INTBITAB OCT 20100
051022,000822:
Page 1221 |
051024,000824: # AVETOMID
051025,000825:
051026,000826: # THIS ROUTINE PERFORMS THE TRANSITION FROM A THRUSTING PHASE TO THE COAST
051027,000827: # PHASE BY INITIALIZING THIS VEHICLES PERMANENT STATE VECTOR WITH THE
051028,000828: # VALUES LEFT BY THE AVERAGEG ROUTINE IN RN,VN,PIPTIME.
051029,000829:
051030,000830: # BEFORE THIS IS DONE THE W-MATRIX, IF ITS VALID (OR WFLAG OR RENDWFLG IS
051031,000831: # SET) IS INTEGRATED FORWARD TO PIPTIME WITH THE PRE-THRUST STATE VECTOR.
051032,000832:
051033,000833: # IN ADDITION, THE OTHER VEHICLE IS INTEGRATED (PERMANENT) TO PIPTIME.
051034,000834:
051035,000835: # FINALLY TRKMKCNT IS ZEROED
051036,000836:
051037,000837: 13,2000 SETLOC INTINIT
051038,000838: 13,2000 BANK
051039,000839:
051040,000840: 13,3467 COUNT* $$/INTIN
051041,000841: 13,3467 43020 AVETOMID STQ BON
051042,000842: 13,3470 02772 EGRESS
051043,000843: 13,3471 02716 RENDWFLG
051044,000844: 13,3472 27536 INT/W # W-MATRIX VALID, GO INTEGRATE IT
051045,000845: 13,3473 77614 BON
051046,000846: 13,3474 01711 ORBWFLAG
051047,000847: 13,3475 27536 INT/W # W-MATRIX VALID, GO INTEGRATE IT
051048,000848:
051049,000849: 13,3476 45145 OTHERS DLOAD CALL # GET SET FOR OTHER VEHICLE INTEGRATION
051050,000850: 13,3477 01235 PIPTIME # DESIRED TIME
051051,000851: 13,3500 27414 INTSTALL
051052,000852: 13,3501 45014 SET CALL
051053,000853: 13,3502 01474 VINTFLAG # CM
051054,000854: 13,3503 26644 SETIFLGS # SETS UP NONE W-MAT. PERMANENT INTEG.
051055,000855: 13,3504 34041 STCALL TDEC1
051056,000856: 13,3505 27134 INTEGRV
051057,000857:
051058,000858: 13,3506 45174 AXT,2 CALL # NOW MOVE PROPERLY SCALE RN,UN AS WELL AS
051059,000859: 13,3507 00002 2 # PIPTIME TO INTEGRATION ERASABLES.
051060,000860: 13,3510 27414 INTSTALL
051061,000861: 13,3511 77014 BON AXT,2
051062,000862: 13,3512 04304 MOONTHIS
051063,000863: 13,3513 27515 +2
051064,000864: 13,3514 00000 0
051065,000865: 13,3515 53775 VLOAD VSR*
051066,000866: 13,3516 01221 RN
051067,000867: 13,3517 57176 0,2
051068,000868: 13,3520 01503 STORE RRECT
051069,000869: 13,3521 15535 STODL RCV
051070,000870: 13,3522 01235 PIPTIME
051071,000871: 13,3523 25517 STOVL TET
051072,000872: 13,3524 01227 VN
Page 1222 |
051074,000874: 13,3525 45057 VSR* CALL
051075,000875: 13,3526 57176 0,2
051076,000876: 13,3527 23455 MINIRECT # FINISH SETTING UP STATE VECTOR
051077,000877: 13,3530 66234 RTB SSP
051078,000878: 13,3531 26747 MOVATHIS # PUT TEMP STATE VECTOR INTO PERMANENT
051079,000879: 13,3532 03463 TRKMKCNT
051080,000880: 13,3533 00000 0
051081,000881: 13,3534 77650 GOTO
051082,000882: 13,3535 47226 FAZAB5
051083,000883:
051084,000884: 13,3536 45145 INT/W DLOAD CALL
051085,000885: 13,3537 01235 PIPTIME # INTEGRATE W THRU BURN
051086,000886: 13,3540 27414 INTSTALL
051087,000887: 13,3541 43014 SET SET
051088,000888: 13,3542 01476 DIM0FLAG # DO W-MATRIX
051089,000889: 13,3543 04476 AVEMIDSW # SO WONT CLOBBER RN,VN,PIPTIME
051090,000890: 13,3544 43014 SET CLEAR
051091,000891: 13,3545 01475 D6OR9FLG # 9X9 FOR LM
051092,000892: 13,3546 01674 VINTFLAG # LM
051093,000893: 13,3547 34041 STCALL TDEC1
051094,000894: 13,3550 27134 INTEGRV
051095,000895: 13,3551 77650 GOTO
051096,000896: 13,3552 27476 OTHERS # NOW GO DO THE OTHER VEHICLE
051097,000897:
Page 1223 |
051099,000899: # MIDTOAV1
051100,000900:
051101,000901: # THIS ROUTINE INTEGRATES (PRECISION) TO THE TIME SPECIFIED IN TDEC1.
051102,000902: # IF, AT THE END OF AN INTEGRATION TIME STEP, CURRENT TIME PLUS A DELTA
051103,000903: # TIME (SEE TIMEDELT.....BASED ON THE COMPUTATUON TIME FOR ONE TIME STEP)
051104,000904: # IS GREATER THAN THE DESIRED TIME, ALARM 1703 IS SET AND THE INTEGRATION
051105,000905: # IS DONE TO THE CURRENT TIME.
051106,000906: # RETURN IS IN BASIC TO THE RETURN ADDRESS PLUS ONE.
051107,000907:
051108,000908: # IF THE INTEGRATION IS FINISHED TO THE DESIRED TIME, RETURN IS IN BASIC
051109,000909: # TO THE RETURN ADDRESS
051110,000910:
051111,000911: # IN EITHER CASE, BEFORE RETURNING, THE EXTRAPOLATED STATE VECTOR IS TRAN
051112,000912: # FERRED FROM R,VATT TO R,VN1-PIPTIME1 IS SET TO THE FINISHING INTEGRA-
051113,000913: # TION TIME AND MPAC IS SET TO THE DELTA TIME ---
051114,000914: # TAT MINUS CURRENT TIME.
051115,000915:
051116,000916: # MIDTOAV2
051117,000917:
051118,000918: # THIS ROUTINE INTEGRATES THIS VEHICLES STATE VECTOR TO THE CURRENT TIME.
051119,000919: # NO INPUTS ARE REQUIRED OF THE CALLER. RETURN IS IN BASIC TO THE RETURN
051120,000920: # ADDRESS WITH THE ABOVE TRANSFERS TO R,VN1-PIPTIME1-AND MPAC DONE
051121,000921:
051122,000922: 13,3553 E7,1744 EBANK= IRETURN1
051123,000923: 13,3553 43020 MIDTOAV2 STQ CLRGO # INTEGRATE TO PRESENT TIME PLUS TIMEDELT
051124,000924: 13,3554 03744 IRETURN1
051125,000925: 13,3555 04634 MID1FLAG
051126,000926: 13,3556 27572 ENTMID2
051127,000927:
051128,000928: 13,3557 43020 MIDTOAV1 STQ SET # INTEGRATE TO TDEC1
051129,000929: 13,3560 03744 IRETURN1
051130,000930: 13,3561 04474 MID1FLAG
051131,000931: 13,3562 43234 RTB DAD # INITIAL CHECK, IS TDEC1 IN THE FUTURE
051132,000932: 13,3563 21573 LOADTIME
051133,000933: 13,3564 27674 TIMEDELT
051134,000934: 13,3565 51021 BDSU BPL
051135,000935: 13,3566 00041 TDEC1
051136,000936: 13,3567 27576 ENTMID1 # Y5S
051137,000937: 13,3570 77624 CALL
051138,000938: 13,3571 27662 NOTIME # NO, SET ALARM, SWITCH TO MIDTOAV2
051139,000939:
051140,000940: 13,3572 43234 ENTMID2 RTB DAD
051141,000941: 13,3573 21573 LOADTIME
051142,000942: 13,3574 27674 TIMEDELT
051143,000943: 13,3575 00041 STORE TDEC1
051144,000944:
051145,000945: 13,3576 77624 ENTMID1 CALL
051146,000946: 13,3577 27414 INTSTALL
051147,000947: 13,3600 45014 CLEAR CALL
Page 1224 |
051149,000949: 13,3601 01676 DIM0FLAG # NO W-MATRIX
051150,000950: 13,3602 26066 THISVINT
051151,000951: 13,3603 43014 CLEAR SET
051152,000952: 13,3604 01673 INTYPFLG
051153,000953: 13,3605 04475 MIDAVFLG # LET INTEG. KNOW THE CALL IS FOR MIDTOAV.
051154,000954: 13,3606 77624 CALL
051155,000955: 13,3607 27134 INTEGRV # GO INTEGRATE
051156,000956: 13,3610 77214 CLEAR VLOAD
051157,000957: 13,3611 04675 MIDAVFLG
051158,000958: 13,3612 00001 RATT
051159,000959: 13,3613 27545 STOVL RN1
051160,000960: 13,3614 00007 VATT
051161,000961: 13,3615 17553 STODL VN1
051162,000962: 13,3616 00015 TAT
051163,000963: 13,3617 03561 STORE PIPTIME1
051164,000964: 13,3620 66134 SXA,2 SXA,1
051165,000965: 13,3621 02777 RTX2
051166,000966: 13,3622 02776 RTX1
051167,000967: 13,3623 77776 EXIT
051168,000968:
051169,000969: 13,3624 00004 INHINT
051170,000970: 13,3625 00006 EXTEND
051171,000971: 13,3626 40025 DCS TIME2
051172,000972: 13,3627 20155 DAS MPAC
051173,000973: 13,3630 07257 TC TPAGREE
051174,000974:
051175,000975: 13,3631 31744 CA IRETURN1
051176,000976: 13,3632 04640 TC BANKJUMP
051177,000977: 13,3633 47014 CKMID2 BOF RTB
051178,000978: 13,3634 04754 MID1FLAG
051179,000979: 13,3635 27652 MID2
051180,000980: 13,3636 21573 LOADTIME
051181,000981: 13,3637 44215 DAD BDSU
051182,000982: 13,3640 27674 TIMEDELT
051183,000983: 13,3641 01116 TDEC
051184,000984: 13,3642 45044 BPL CALL
051185,000985: 13,3643 27257 TESTLOOP # YES
051186,000986: 13,3644 27662 NOTIME
051187,000987:
051188,000988: 13,3645 43234 TIMEINC RTB DAD
051189,000989: 13,3646 21573 LOADTIME
051190,000990: 13,3647 27674 TIMEDELT
051191,000991: 13,3650 35116 STCALL TDEC
051192,000992: 13,3651 27257 TESTLOOP
051193,000993:
051194,000994: 13,3652 45345 MID2 DLOAD DSU
051195,000995: 13,3653 01116 TDEC
051196,000996: 13,3654 01517 TET
051197,000997: 13,3655 45246 ABS DSU
051198,000998: 13,3656 27672 3CSECS
051199,000999:
Page 1225 |
051201,001001: 13,3657 52040 BMN GOTO
051202,001002: 13,3660 27157 A-PCHK
051203,001003: 13,3661 27645 TIMEINC
051204,001004:
051205,001005: 13,3662 77414 NOTIME CLEAR EXIT # TOO LATE
051206,001006: 13,3663 04674 MID1FLAG
051207,001007: 13,3664 25744 INCR IRETURN1 # SET ERROR EXIT (CALLOC +2)
051208,001008: 13,3665 05567 TC ALARM # INSUFFICIENT TIME FOR INTEGRATION --
051209,001009: 13,3666 01703 OCT 1703 # TIG WILL BE SLIPPED...
051210,001010: 13,3667 06037 TC INTPRET
051211,001011: 13,3670 77616 RVQ
051212,001012:
051213,001013: 13,3671 00000 00003 3CSECS 2DEC 3 B-28
051214,001014:
051215,001015: 13,3673 00000 03720 TIMEDELT 2DEC 2000 B-28
051216,001016:
051217,001017: 27,3360 BANK 27
051218,001018: 04,2000 SETLOC UPDATE2
051219,001019: 04,2000 BANK
051220,001020: 04,3165 1167 EBANK= INTWAKUQ
051221,001021:
051222,001022: 04,3165 COUNT* $$/INTIN
051223,001023:
051224,001024: 04,3165 1167 INTWAKUQ = INTWAK1Q # TEMPORARY UNTIL NAME OF INTWAK1Q IS CHNG
051225,001025:
051226,001026: 04,3165 00003 INTWAKEU RELINT
051227,001027: 04,3166 00006 EXTEND
051228,001028: 04,3167 23167 QXCH INTWAKUQ # SAVE Q FOR RETURN
051229,001029:
051230,001030: 04,3170 06037 TC INTPRET
051231,001031:
051232,001032: 04,3171 53135 SLOAD BZE # IS THIS A CSM/LEM STATE VECTOR UPDATE
051233,001033: 04,3172 01502 UPSVFLAG # REQUEST. IF NOT GO TO INTWAKUP.
051234,001034: 04,3173 11232 INTWAKUP
051235,001035:
051236,001036: 04,3174 77775 VLOAD # MOVE RRECT(6) AND VRECT(6) INTO
051237,001037: 04,3175 01503 RRECT # RCV(6) AND VCV(6) RESPECTIVELY.
051238,001038: 04,3176 25535 STOVL RCV
051239,001039: 04,3177 01511 VRECT # NOW GO TO 'RECTIFY +13D' TO
051240,001040: 04,3200 77624 CALL # STORE VRECT INTO VCV AND ZERO OUT
051241,001041: 04,3201 23456 RECTIFY +13D # TDELTAV(6),TNUV(6),TC(2) AND XKEP(2)
051242,001042: 04,3202 51535 SLOAD ABS # COMPARE ABSOLUTE VALUE OF 'UPSVFLAG'
051243,001043: 04,3203 01502 UPSVFLAG # TO 'UPDATE MOON STATE VECTOR CODE'
051244,001044: 04,3204 53025 DSU BZE # TO DETERMINE WHETHER THE STATE VECTOR TO
051245,001045: 04,3205 11243 UPMNSVCD # BE UPDATED IS IN THE EARTH OR LUNAR
051246,001046: 04,3206 11213 INTWAKEM # SPHERE OF INFLUENCE.........
051247,001047: 04,3207 43174 AXT,2 CLRGO # EARTH SPHERE OF INFLUENCE.
051248,001048: 04,3210 00000 DEC 0 B-14
051249,001049: 04,3211 00223 MOONFLAG
Page 1226 |
051251,001051: 04,3212 11216 INTWAKEC
051252,001052: 04,3213 43174 INTWAKEM AXT,2 SET # LUNAR SPHERE OF INFLUENCE.
051253,001053: 04,3214 00002 DEC 2 B-14
051254,001054: 04,3215 00063 MOONFLAG
051255,001055: 04,3216 50135 INTWAKEC SLOAD BMN # COMMON CODING AFTER X2 INITIALIZED AND
051256,001056: # MOONFLAG SET (OR CLEARED).
051257,001057: 04,3217 01502 UPSVFLAG # IS THIS A REQUEST FOR A LEM OR CSM
051258,001058: 04,3220 11226 INTWAKLM # STATE VECTOR UPDATE......
051259,001059: 04,3221 77624 CALL # UPDATE CSM STATE VECTOR
051260,001060: 04,3222 26661 ATOPCSM
051261,001061:
051262,001062: 04,3223 52014 CLEAR GOTO
051263,001063: 04,3224 01671 ORBWFLAG
051264,001064: 04,3225 11230 INTWAKEX
051265,001065:
051266,001066: 04,3226 77624 INTWAKLM CALL # UPDATE LM STATE VECTOR
051267,001067: 04,3227 26734 ATOPLEM
051268,001068:
051269,001069: 04,3230 77614 INTWAKEX CLEAR
051270,001070: 04,3231 02676 RENDWFLG
051271,001071:
051272,001072: 04,3232 45131 INTWAKUP SSP CALL # REMOVE :UPDATE STATE VECTOR INDICATOR:
051273,001073: 04,3233 01502 UPSVFLAG
051274,001074: 04,3234 00000 0
051275,001075: 04,3235 27423 INTWAKE0 # RELEASE :GRAB: OF ORBIT INTEG
051276,001076: 04,3236 77776 EXIT
051277,001077:
051278,001078: 04,3237 05353 TC PHASCHNG
051279,001079: 04,3240 04026 OCT 04026
051280,001080: 04,3241 01167 TC INTWAKUQ
051281,001081:
051282,001082: 04,3242 00002 UPMNSVCD OCT 2
051283,001083: 04,3243 00000 OCT 0
051284,001084:
051285,001085: 04,3244 77420 GRP2PC STQ EXIT
051286,001086: 04,3245 02711 GRP2SVQ
051287,001087: 04,3246 05353 TC PHASCHNG
051288,001088: 04,3247 04022 OCT 04022
051289,001089: 04,3250 06037 TC INTPRET
051290,001090: 04,3251 77650 GOTO
051291,001091: 04,3252 02711 GRP2SVQ
051292,001092:
End of include-file INTEGRATION_INITIALIZATION.agc. Parent file is MAIN.agc