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