Source Code
These source-code files are part of a reconstructed copy of Luminary 97, the
second release of the Apollo 11 Lunar Module (LM) Apollo Guidance Computer
(AGC) software. It was created to fix two incorrect ephemeris constants in
Luminary 96, as described by anomaly report LNY-59.
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. |
013375,000002: ## Copyright: Public domain.
013376,000003: ## Filename: IMU_COMPENSATION_PACKAGE.agc
013377,000004: ## Purpose: A section of Luminary revision 97.
013378,000005: ## It is part of the reconstructed source code for the
013379,000006: ## second release of the flight software for the Lunar
013380,000007: ## Module's (LM) Apollo Guidance Computer (AGC) for Apollo 11.
013381,000008: ## It was created to fix two incorrect ephemeris constants in
013382,000009: ## Luminary 96, as described by anomaly report LNY-59.
013383,000010: ## The code has been recreated from a copy of Luminary 99
013384,000011: ## revision 001, using asterisks indicating changed lines in
013385,000012: ## the listing and Luminary Memos #83 and #85, which list
013386,000013: ## changes between Luminary 97 and 98, and 98 and 99. The
013387,000014: ## code has been adapted such that the resulting bugger words
013388,000015: ## exactly match those specified for Luminary 97 in NASA drawing
013389,000016: ## 2021152D, which gives relatively high confidence that the
013390,000017: ## reconstruction is correct.
013391,000018: ## Reference: pp. 326-337
013392,000019: ## Assembler: yaYUL
013393,000020: ## Contact: Ron Burkey <info@sandroid.org>.
013394,000021: ## Website: www.ibiblio.org/apollo/index.html
013395,000022: ## Mod history: 2019-07-28 MAS Created from Luminary 99.
013396,000023:
Page 326 |
013398,000025: 07,2667 BANK 7
013399,000026: 06,2000 SETLOC IMUCOMP
013400,000027: 06,2000 BANK
013401,000028:
013402,000029: 06,3263 E3,1460 EBANK= NBDX
013403,000030:
013404,000031: 06,3263 COUNT* $$/ICOMP
013405,000032: 06,3263 33531 1/PIPA CAF LGCOMP # SAVE EBANK OF CALLING PROGRAM
013406,000033: 06,3264 56003 XCH EBANK
013407,000034: 06,3265 54163 TS MODE
013408,000035:
013409,000036: 06,3266 11477 CCS GCOMPSW # BYPASS IF GCOMPSW NEGATIVE
013410,000037: 06,3267 13272 TCF +3
013411,000038: 06,3270 13272 TCF +2
013412,000039: 06,3271 13353 TCF IRIG1 # RETURN
013413,000040:
013414,000041: 06,3272 34751 1/PIPA1 CAF FOUR # PIPAZ, PIPAY, PIPAX
013415,000042: 06,3273 54132 TS BUF +2
013416,000043:
013417,000044: 06,3274 50132 INDEX BUF +2
013418,000045: 06,3275 31453 CA PIPASCF # (P.P.M.) X 2(-9)
013419,000046: 06,3276 00006 EXTEND
013420,000047: 06,3277 50132 INDEX BUF +2
013421,000048: 06,3300 70324 MP DELVX # (PP) X 2(+14) NOW (PIPA PULSES) X 2(+5)
013422,000049: 06,3301 54002 TS Q # SAVE MAJOR PART
013423,000050:
013424,000051: 06,3302 30001 CA L # MINOR PART
013425,000052: 06,3303 00006 EXTEND
013426,000053: 06,3304 74746 MP BIT6 # SCALE 2(+9) SHIFT RIGHT 9
013427,000054: 06,3305 50132 INDEX BUF +2
013428,000055: 06,3306 54325 TS DELVX +1 # FRACTIONAL PIPA PULSES SCALED 2(+14)
013429,000056:
013430,000057: 06,3307 30002 CA Q # MAJOR PART
013431,000058: 06,3310 00006 EXTEND
013432,000059: 06,3311 74746 MP BIT6 # SCALE 2(+9) SHIFT RIGHT 9
013433,000060: 06,3312 50132 INDEX BUF +2
013434,000061: 06,3313 20325 DAS DELVX # (PIPAI) + (PIPAI)(SFE)
013435,000062:
013436,000063: 06,3314 50132 INDEX BUF +2
013437,000064: 06,3315 41452 CS PIPABIAS # (PIPA PULSES)/(CS) X 2(-5) *
013438,000065: 06,3316 00006 EXTEND
013439,000066: 06,3317 71075 MP 1/PIPADT # (CS) X 2(+8) NOW (PIPA PULSES) X 2(+3) *
013440,000067: 06,3320 00006 EXTEND
013441,000068: 06,3321 74750 MP BIT4 # SCALE 2(+11) SHIFT RIGHT 11 *
013442,000069: 06,3322 50132 INDEX BUF +2
013443,000070: 06,3323 20325 DAS DELVX # (PIPAI) + (PIPAI)(SFE) - (BIAS)(DELTAT)
013444,000071:
013445,000072: 06,3324 10132 CCS BUF +2 # PIPAZ, PIPAY, PIPAX
013446,000073: 06,3325 67747 AD NEG1
013447,000074: 06,3326 13273 TCF 1/PIPA1 +1
Page 327 |
013449,000076: 06,3327 13330 NOOP # LESS THAN ZERO IMPOSSIBLE
013450,000077:
Page 328 |
013452,000079: 06,3330 55477 IRIGCOMP TS GCOMPSW # INDICATE COMMANDS 2 PULSES OR LESS.
013453,000080: 06,3331 54130 TS BUF # INDEX COUNTER. IRIGX, IRIGY, IRIGZ.
013454,000081:
013455,000082: 06,3332 03356 TC IRIGX # COMPENSATE ACCELERATION TERMS
013456,000083:
013457,000084: 06,3333 41460 CS NBDX # (GYRO PULSES)/(CS) X 2(-5)
013458,000085: 06,3334 03454 TC DRIFTSUB # -(NBOX)(DELTAT) (GYRO PULSES) X 2(+14)
013459,000086:
013460,000087: 06,3335 03373 TC IRIGY # COMPENSATE ACCELERATION TERMS
013461,000088:
013462,000089: 06,3336 41461 CS NBDY # (GYRO PULSES)/(CS) X 2(-5)
013463,000090: 06,3337 03454 TC DRIFTSUB # -(NBDY)(DELTAT) (GYRO PULSES) X 2(+14)
013464,000091:
013465,000092: 06,3340 03410 TC IRIGZ # COMPENSATE ACCELERATION TERMS
013466,000093:
013467,000094: 06,3341 31462 CA NBDZ # (GYRO PULSES)/(CS) X 2(-5)
013468,000095: 06,3342 03454 TC DRIFTSUB # +(NBDZ)(DELTAT) (GYRO PULSES) X 2(+14)
013469,000096:
013470,000097: 06,3343 11477 CCS GCOMPSW # ARE GYRO COMMANDS GREATER THAN 2 PULSES
013471,000098: 06,3344 13346 TCF +2 # YES SEND OUT GYRO TORQUING COMMANDS.
013472,000099: 06,3345 13353 TCF IRIG1 # NO RETURN
013473,000100:
013474,000101: 06,3346 35031 CA PRIO21 # PRIO GREATER THAN SERVICER
013475,000102: 06,3347 05072 TC NOVAC # SEND OUT GYRO TORQUING COMMANDS.
013476,000103: 06,3350 E3,1460 EBANK= NBDX
013477,000104: 06,3350 03507 14063 2CADR 1/GYRO
013478,000105:
013479,000106: 06,3352 00003 RELINT
013480,000107: 06,3353 30163 IRIG1 CA MODE # RESTORE CALLERS EBANK
013481,000108: 06,3354 54003 TS EBANK
013482,000109: 06,3355 14631 TCF SWRETURN
013483,000110:
Page 329 |
013485,000112: 06,3356 00006 IRIGX EXTEND
013486,000113: 06,3357 22156 QXCH MPAC +2 # SAVE Q
013487,000114: 06,3360 00006 EXTEND
013488,000115: 06,3361 40325 DCS DELVX # (PIPA PULSES) X 2(+14)
013489,000116: 06,3362 52155 DXCH MPAC
013490,000117: 06,3363 31463 CA ADIAX # (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013491,000118: 06,3364 03425 TC GCOMPSUB # -(ADIAX)(PIPAX) (GYRO PULSES) X 2(+14)
013492,000119:
013493,000120: 06,3365 00006 EXTEND #
013494,000121: 06,3366 40327 DCS DELVY # (PIPA PULSES) X 2(+14)
013495,000122: 06,3367 52155 DXCH MPAC #
013496,000123: 06,3370 41466 CS ADSRAX # (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013497,000124: 06,3371 03425 TC GCOMPSUB # -(ADSRAX)(PIPAY) (GYRO PULSES) X 2(+14)
013498,000125:
013499,000126: # EXTEND ***
013500,000127: # DCS DELVZ *** (PIPA PULSES) X 2(+14)
013501,000128: # DXCH MPAC ***
013502,000129: # CA ADOAX *** (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013503,000130: # TC GCOMPSUB *** -(ADOAX)(PIPAZ) (GYRO PULSES) X 2(+14)
013504,000131:
013505,000132: 06,3372 00156 TC MPAC +2
013506,000133:
013507,000134: 06,3373 00006 IRIGY EXTEND
013508,000135: 06,3374 22156 QXCH MPAC +2 # SAVE Q
013509,000136: 06,3375 00006 EXTEND
013510,000137: 06,3376 40327 DCS DELVY # (PIPA PULSES) X 2(+14)
013511,000138: 06,3377 52155 DXCH MPAC
013512,000139: 06,3400 31464 CA ADIAY # (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013513,000140: 06,3401 03425 TC GCOMPSUB # -(ADIAY)(PIPAY) (GYRO PULSES) X 2(+14)
013514,000141:
013515,000142: 06,3402 00006 EXTEND
013516,000143: 06,3403 40331 DCS DELVZ # (PIPA PULSES) X 2(+14)
013517,000144: 06,3404 52155 DXCH MPAC
013518,000145: 06,3405 41467 CS ADSRAY # (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013519,000146: 06,3406 03425 TC GCOMPSUB # +(ADSRAY)(PIPAZ) (GYRO PULSES) X 2(+14)
013520,000147:
013521,000148: # EXTEND ***
013522,000149: # DCS DELVX *** (PIPA PULSES) X 2(+14)
013523,000150: # DXCH MPAC ***
013524,000151: # CA ADOAY *** (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013525,000152: # TC GCOMPSUB *** -(ADOAY)(PIPAX) (GYRO PULSES) X 2(+14)
013526,000153:
013527,000154: 06,3407 00156 TC MPAC +2
013528,000155:
013529,000156: 06,3410 00006 IRIGZ EXTEND
013530,000157: 06,3411 22156 QXCH MPAC +2 # SAVE Q
013531,000158: 06,3412 00006 EXTEND
013532,000159: 06,3413 40327 DCS DELVY # (PIPA PULSES) X 2(+14)
013533,000160: 06,3414 52155 DXCH MPAC
013534,000161: 06,3415 31470 CA ADSRAZ # (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
Page 330 |
013536,000163: 06,3416 03425 TC GCOMPSUB # -(ADSRAZ)(PIPAY) (GYRO PULSES) X 2(+14)
013537,000164:
013538,000165: 06,3417 00006 EXTEND
013539,000166: 06,3420 40331 DCS DELVZ # (PIPA PULSES) X 2(+14)
013540,000167: 06,3421 52155 DXCH MPAC
013541,000168: 06,3422 31465 CA ADIAZ # (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013542,000169: 06,3423 03425 TC GCOMPSUB # -(ADIAZ)(PIPAZ) (GYRO PULSES) X 2(+14)
013543,000170:
013544,000171: # EXTEND ***
013545,000172: # DCS DELVX *** (PIPA PULSE) X 2(+14)
013546,000173: # DXCH MPAC ***
013547,000174: # CS ADOAZ *** (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013548,000175: # TC GCOMPSUB *** +(ADOAZ)(PIPAX) (GYRO PULSES) X 2(+14)
013549,000176:
013550,000177: 06,3424 00156 TC MPAC +2
013551,000178:
Page 331 |
013553,000180: 06,3425 56154 GCOMPSUB XCH MPAC # ADIA OR ADSRA COEFFICIENT ARRIVES IN A
013554,000181: 06,3426 00006 EXTEND # C(MPAC) = (PIPA PULSES) X 2(+14)
013555,000182: 06,3427 70154 MP MPAC # (GYRO PULSES)/(PIPA PULSE) X 2(-6) *
013556,000183: 06,3430 52123 DXCH VBUF # NOW = (GYRO PULSES) X 2(+8) *
013557,000184:
013558,000185: 06,3431 30155 CA MPAC +1 # MINOR PART PIPA PULSES
013559,000186: 06,3432 00006 EXTEND
013560,000187: 06,3433 70154 MP MPAC # ADIA OR ADSRA
013561,000188: 06,3434 54001 TS L
013562,000189: 06,3435 34755 CAF ZERO
013563,000190: 06,3436 20123 DAS VBUF # NOW = (GYRO PULSES) X 2(+8) *
013564,000191:
013565,000192: 06,3437 30122 CA VBUF # PARTIAL RESULT - MAJOR
013566,000193: 06,3440 00006 EXTEND
013567,000194: 06,3441 74743 MP BIT9 # SCALE 2(+6) SHIFT RIGHT 6 *
013568,000195: 06,3442 50130 INDEX BUF # RESULT = (GYRO PULSES) X 2(+14)
013569,000196: 06,3443 21472 DAS GCOMP # HI(ADIA)(PIPAI) OR HI(ADSRA)(PIPAI)
013570,000197:
013571,000198: 06,3444 30123 CA VBUF +1 # PARTIAL RESULT - MINOR
013572,000199: 06,3445 00006 EXTEND
013573,000200: 06,3446 74743 MP BIT9 # SCALE 2(+6) SHIFT RIGHT 6 *
013574,000201: 06,3447 54001 TS L
013575,000202: 06,3450 34755 CAF ZERO
013576,000203: 06,3451 50130 INDEX BUF # RESULT = (GYRO PULSES) X 2(+14)
013577,000204: 06,3452 21472 DAS GCOMP # (ADIA)(PIPAI) OR (ADSRA)(PIPAI)
013578,000205:
013579,000206: 06,3453 00002 TC Q
013580,000207:
Page 332 |
013582,000209: 06,3454 00006 DRIFTSUB EXTEND
013583,000210: 06,3455 22131 QXCH BUF +1
013584,000211:
013585,000212: 06,3456 00006 EXTEND # C(A) = NBD (GYRO PULSES)/(CS) X 2(-5)
013586,000213: 06,3457 71075 MP 1/PIPADT # (CS) X 2(+8) NOW (GYRO PULSES) X 2(+3)
013587,000214: 06,3460 22155 LXCH MPAC +1 # SAVE FOR FRACTIONAL COMPENSATION
013588,000215: 06,3461 00006 EXTEND
013589,000216: 06,3462 74750 MP BIT4 # SCALE 2(+11) SHIFT RIGHT 11
013590,000217: 06,3463 50130 INDEX BUF
013591,000218: 06,3464 21472 DAS GCOMP # HI(NBD)(DELTAT) (GYRO PULSES) X 2(+14)
013592,000219:
013593,000220: 06,3465 30155 CA MPAC +1 # NOW MINOR PART
013594,000221: 06,3466 00006 EXTEND
013595,000222: 06,3467 74750 MP BIT4 # SCALE 2(+11) SHIFT RIGHT 11
013596,000223: 06,3470 54001 TS L
013597,000224: 06,3471 34755 CAF ZERO
013598,000225: 06,3472 50130 INDEX BUF # ADD IN FRACTIONAL COMPENSATION
013599,000226: 06,3473 21472 DAS GCOMP # (NBD)(DELTAT) (GYRO PULSES) X 2(+14)
013600,000227:
013601,000228: 06,3474 34752 DRFTSUB2 CAF TWO # PIPAX, PIPAY, PIPAZ
013602,000229: 06,3475 60130 AD BUF
013603,000230: 06,3476 56130 XCH BUF
013604,000231: 06,3477 50000 INDEX A
013605,000232: 06,3500 11471 CCS GCOMP # ARE GYRO COMMANDS 1 PULSE OR GREATER
013606,000233: 06,3501 13503 TCF +2 # YES
013607,000234: 06,3502 00131 TC BUF +1 # NO
013608,000235:
013609,000236: 06,3503 73553 MASK COMPCHK # DEC -1
013610,000237: 06,3504 10000 CCS A # ARE GYRO COMMANDS GREATER THAN 2 PULSES
013611,000238: 06,3505 55477 TS GCOMPSW # YES - SET GCOMPSW POSITIVE
013612,000239: 06,3506 00131 TC BUF +1 # NO
013613,000240:
Page 333 |
013615,000242: 06,3507 34751 1/GYRO CAF FOUR # PIPAZ, PIPAY, PIPAX
013616,000243: 06,3510 54130 TS BUF
013617,000244:
013618,000245: 06,3511 50130 INDEX BUF # SCALE GYRO COMMANDS FOR IMUPULSE
013619,000246: 06,3512 31472 CA GCOMP +1 # FRACTIONAL PULSES
013620,000247: 06,3513 00006 EXTEND
013621,000248: 06,3514 74744 MP BIT8 # SHIFT RIGHT 7
013622,000249: 06,3515 50130 INDEX BUF
013623,000250: 06,3516 55472 TS GCOMP +1 # FRACTIONAL PULSES SCALED
013624,000251:
013625,000252: 06,3517 34755 CAF ZERO # SET GCOMP = 0 FOR DAS INSTRUCTION
013626,000253: 06,3520 50130 INDEX BUF
013627,000254: 06,3521 57471 XCH GCOMP # GYRO PULSES
013628,000255: 06,3522 00006 EXTEND
013629,000256: 06,3523 74744 MP BIT8 # SHIFT RIGHT 7
013630,000257: 06,3524 50130 INDEX BUF
013631,000258: 06,3525 21472 DAS GCOMP # ADD THESE TO FRACTIONAL PULSES ABOVE
013632,000259:
013633,000260: 06,3526 10130 CCS BUF # PIPAZ, PIPAY, PIPAX
013634,000261: 06,3527 67747 AD NEG1
013635,000262: 06,3530 13510 TCF 1/GYRO +1
013636,000263: 06,3531 01471 LGCOMP ECADR GCOMP # LESS THAN ZERO IMPOSSIBLE
013637,000264:
013638,000265: 06,3532 33531 CAF LGCOMP
013639,000266: 06,3533 04616 TC BANKCALL
013640,000267: 06,3534 17323 CADR IMUPULSE # CALL GYRO TORQUING ROUTINE
013641,000268: 06,3535 04616 TC BANKCALL
013642,000269: 06,3536 17716 CADR IMUSTALL # WAIT FOR PULSES TO GET OUT
013643,000270: 06,3537 15155 TCF ENDOFJOB # TEMPORARY
013644,000271:
013645,000272: 06,3540 34751 GCOMP1 CAF FOUR # PIPAZ, PIPAY, PIPAX
013646,000273: 06,3541 54130 TS BUF
013647,000274:
013648,000275: 06,3542 50130 INDEX BUF # RESCALE
013649,000276: 06,3543 31472 CA GCOMP +1
013650,000277: 06,3544 00006 EXTEND
013651,000278: 06,3545 74744 MP BIT8 # SHIFT MINOR PART LEFT 7 - MAJOR PART = 0
013652,000279: 06,3546 50130 INDEX BUF
013653,000280: 06,3547 23472 LXCH GCOMP +1 # BITS 8-14 OF MINOR PART WERE = 0
013654,000281:
013655,000282: 06,3550 10130 CCS BUF # PIPAZ, PIPAY, PIPAX
013656,000283: 06,3551 67747 AD NEG1
013657,000284: 06,3552 13541 TCF GCOMP1 +1
013658,000285: 06,3553 77776 COMPCHK DEC -1 B-14 # LESS THAN ZERO IMPOSSIBLE
013659,000286: 06,3554 15155 TCF ENDOFJOB
013660,000287:
Page 334 |
013662,000289: 06,3555 11477 NBDONLY CCS GCOMPSW # BYPASS IF GCOMPSW NEGATIVE
013663,000290: 06,3556 13561 TCF +3
013664,000291: 06,3557 13561 TCF +2
013665,000292: 06,3560 15155 TCF ENDOFJOB
013666,000293:
013667,000294: 06,3561 00004 INHINT
013668,000295: 06,3562 10076 CCS FLAGWRD2 # PREREAD T3RUPT MAY COINCIDE
013669,000296: 06,3563 15155 TCF ENDOFJOB
013670,000297: 06,3564 15155 TCF ENDOFJOB
013671,000298: 06,3565 13566 TCF +1
013672,000299:
013673,000300: 06,3566 30104 CA FLAGWRD8 # IF SURFACE FLAG IS SET, SET TEM1
013674,000301: 06,3567 74744 MASK BIT8 # POSITIVE SO THAT THE ACCELERATION TERMS
013675,000302: 06,3570 54141 TS TEM1 # WILL BE COMPENSATED.
013676,000303: 06,3571 00006 EXTEND
013677,000304: 06,3572 13575 BZF +3 # ARE WE ON THE SURFACE
013678,000305:
013679,000306: 06,3573 04674 TC IBNKCALL # ON THE SURFACE
013680,000307: 06,3574 77544 CADR PIPASR +3 # READ PIPAS, BUT DO NOT SCALE THEM
013681,000308:
013682,000309: 06,3575 30025 CA TIME1 # (CS) X 2(+14)
013683,000310: 06,3576 57075 XCH 1/PIPADT # PREVIOUS TIME
013684,000311: 06,3577 00003 RELINT
013685,000312: 06,3600 40000 COM
013686,000313: 06,3601 61075 AD 1/PIPADT # PRESENT TIME - PREVIOUS TIME
013687,000314: 06,3602 64736 NBD2 AD HALF # CORRECT FOR POSSIBLE TIME1 TICK
013688,000315: 06,3603 64736 AD HALF
013689,000316: 06,3604 56001 XCH L # IF TIME1 DID NOT TICK, REMOVE RESULTING
013690,000317: 06,3605 56001 XCH L # OVERFLOW.
013691,000318:
013692,000319: 06,3606 00006 NBD3 EXTEND # C(A) = DELTAT (CS) X 2(+14)
013693,000320: 06,3607 74742 MP BIT10 # SHIFT RIGHT 5
013694,000321: 06,3610 52125 DXCH VBUF +2
013695,000322:
013696,000323: 06,3611 34755 CA ZERO
013697,000324: 06,3612 55477 TS GCOMPSW # INDICATE COMMANDS 2 PULSES OR LESS.
013698,000325: 06,3613 54130 TS BUF # INDEX X, Y, Z.
013699,000326:
013700,000327: 06,3614 10141 CCS TEM1 # IF SURFACE FLAG IS SET,
013701,000328: 06,3615 03356 TC IRIGX # COMPENSATE ACCELERATION TERMS.
013702,000329:
013703,000330: 06,3616 00006 EXTEND
013704,000331: 06,3617 30125 DCA VBUF +2
013705,000332: 06,3620 52155 DXCH MPAC # DELTAT NOW SCALED (CS) X 2(+19)
013706,000333:
013707,000334: 06,3621 41460 CS NBDX # (GYRO PULSES)/(CS) X 2(-5)
013708,000335: 06,3622 03644 TC FBIASSUB # -(NBOX)(DELTAT) (GYRO PULSES) X 2(+14)
013709,000336:
013710,000337: 06,3623 10141 CCS TEM1 # IF SURFACE FLAG IS SET,
013711,000338: 06,3624 03373 TC IRIGY # COMPENSATE ACCELERATION TERMS.
Page 335 |
013713,000340: 06,3625 00006 EXTEND
013714,000341: 06,3626 40125 DCS VBUF +2
013715,000342: 06,3627 52155 DXCH MPAC # DELTAT SCALED (CS) X 2(+19)
013716,000343: 06,3630 31461 CA NBDY # (GYRO PULSES)/(CS) X 2(-5)
013717,000344: 06,3631 03644 TC FBIASSUB # -(NBDY)(DELTAT) (GYRO PULSES) X 2(+14)
013718,000345:
013719,000346: 06,3632 10141 CCS TEM1 # IF SURFACE FLAG IS SET,
013720,000347: 06,3633 03410 TC IRIGZ # COMPENSATE ACCELERATION TERMS
013721,000348:
013722,000349: 06,3634 00006 EXTEND
013723,000350: 06,3635 40125 DCS VBUF +2
013724,000351: 06,3636 52155 DXCH MPAC # DELTAT SCALED (CS) X 2(+19)
013725,000352: 06,3637 41462 CS NBDZ # (GYRO PULSES)/(CS) X 2(-5)
013726,000353: 06,3640 03644 TC FBIASSUB # +(NBDZ)(DELTAT) (GYRO PULSES) X 2(+14)
013727,000354:
013728,000355: 06,3641 11477 CCS GCOMPSW # ARE GYRO COMMANDS GREATER THAN 2 PULSES
013729,000356: 06,3642 13507 TCF 1/GYRO # YES
013730,000357: 06,3643 15155 TCF ENDOFJOB # NO
013731,000358:
Page 336 |
013733,000360: 06,3644 56002 FBIASSUB XCH Q
013734,000361: 06,3645 54131 TS BUF +1
013735,000362:
013736,000363: 06,3646 30002 CA Q # NBD SCALED (GYRO PULSES)/(CS) X 2(-5)
013737,000364: 06,3647 00006 EXTEND
013738,000365: 06,3650 70154 MP MPAC # DELTAT SCALED (CS) X 2(+19)
013739,000366: 06,3651 50130 INDEX BUF
013740,000367: 06,3652 21472 DAS GCOMP # HI(NBD)(DELTAT) (GYRO PULSES) X 2(+14)
013741,000368:
013742,000369: 06,3653 30002 CA Q # NOW FRACTIONAL PART
013743,000370: 06,3654 00006 EXTEND
013744,000371: 06,3655 70155 MP MPAC +1
013745,000372: 06,3656 54001 TS L
013746,000373: 06,3657 34755 CAF ZERO
013747,000374: 06,3660 50130 INDEX BUF
013748,000375: 06,3661 21472 DAS GCOMP # (NBD)(DELTAT) (GYRO PULSES) X 2(+14)
013749,000376:
013750,000377: 06,3662 13474 TCF DRFTSUB2 # CHECK MAGNITUDE OF COMPENSATION
013751,000378:
013752,000379: 06,3663 04616 LASTBIAS TC BANKCALL
013753,000380: 06,3664 17277 CADR PIPUSE1
013754,000381:
013755,000382: 06,3665 11477 CCS GCOMPSW
013756,000383: 06,3666 13671 TCF +3
013757,000384: 06,3667 13671 TCF +2
013758,000385: 06,3670 15155 TCF ENDOFJOB
013759,000386:
013760,000387: 06,3671 30104 CA FLAGWRD8 # IF SURFACE FLAG IS SET, SET TEM1
013761,000388: 06,3672 74744 MASK SURFFBIT # POSITIVE SO THAT THE ACCELERATION TERMS
013762,000389: 06,3673 54141 TS TEM1 # WILL BE COMPENSATED.
013763,000390:
013764,000391: 06,3674 37716 CAF PRIO31 # 2 SECONDS SCALED (CS) X 2(+8)
013765,000392: 06,3675 57075 XCH 1/PIPADT
013766,000393: 06,3676 40000 COM
013767,000394: 06,3677 61235 AD PIPTIME +1
013768,000395: 06,3700 13602 TCF NBD2
013769,000396:
013770,000397: 06,3701 33531 GCOMPZER CAF LGCOMP # ROUTINE TO ZERO GCOMP BEFORE FIRST
013771,000398: 06,3702 56003 XCH EBANK # CALL TO 1/PIPA
013772,000399: 06,3703 54163 TS MODE
013773,000400:
013774,000401: 06,3704 34755 CAF ZERO
013775,000402: 06,3705 55477 TS GCOMPSW
013776,000403: 06,3706 55471 TS GCOMP
013777,000404: 06,3707 55472 TS GCOMP +1
013778,000405: 06,3710 55473 TS GCOMP +2
013779,000406: 06,3711 55474 TS GCOMP +3
013780,000407: 06,3712 55475 TS GCOMP +4
Page 337 |
013782,000409: 06,3713 55476 TS GCOMP +5
013783,000410:
013784,000411: 06,3714 13353 TCF IRIG1 # RESTORE EBANK AND RETURN
013785,000412:
End of include-file IMU_COMPENSATION_PACKAGE.agc. Parent file is MAIN.agc