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.

039101,000002:                                                                                                  ## Copyright:   Public domain.
039102,000003:                                                                                                  ## Filename:    FINDCDUW_-_GUIDAP_INTERFACE.agc
039103,000004:                                                                                                  ## Purpose:     A section of Luminary revision 97.
039104,000005:                                                                                                  ##              It is part of the reconstructed source code for the
039105,000006:                                                                                                  ##              second release of the flight software for the Lunar 
039106,000007:                                                                                                  ##              Module's (LM) Apollo Guidance Computer (AGC) for Apollo 11.
039107,000008:                                                                                                  ##              It was created to fix two incorrect ephemeris constants in
039108,000009:                                                                                                  ##              Luminary 96, as described by anomaly report LNY-59.
039109,000010:                                                                                                  ##              The code has been recreated from a copy of Luminary 99
039110,000011:                                                                                                  ##              revision 001, using asterisks indicating changed lines in
039111,000012:                                                                                                  ##              the listing and Luminary Memos #83 and #85, which list 
039112,000013:                                                                                                  ##              changes between Luminary 97 and 98, and 98 and 99. The
039113,000014:                                                                                                  ##              code has been adapted such that the resulting bugger words
039114,000015:                                                                                                  ##              exactly match those specified for Luminary 97 in NASA drawing
039115,000016:                                                                                                  ##              2021152D, which gives relatively high confidence that the
039116,000017:                                                                                                  ##              reconstruction is correct.
039117,000018:                                                                                                  ## Reference:   pp. 908-925
039118,000019:                                                                                                  ## Assembler:   yaYUL
039119,000020:                                                                                                  ## Contact:     Ron Burkey <info@sandroid.org>.
039120,000021:                                                                                                  ## Website:     www.ibiblio.org/apollo/index.html
039121,000022:                                                                                                  ## Mod history: 2019-07-28 MAS  Created from Luminary 99.
039122,000023: 

Page 908

039124,000025:                                                                                                  #  PROGRAM NAME:  FINDCDUW
039125,000026:                                                                                                  #  MOD NUMBER:  1        68 07 15
039126,000027:                                                                                                  #  MOD AUTHOR:  KLUMPP
039127,000028: 
039128,000029:                                                                                                  #  OBJECTS OF MOD:       1.      TO SUPPLY COMMANDED GIMBAL ANGLES FOR NOUN 22.
039129,000030:                                                                                                  #                        2.      TO MAINTAIN CORRECT AND CURRENT THRUST
039130,000031:                                                                                                  #                                DIRECTION DATA IN ALL MODES.  THIS IS DONE BY
039131,000032:                                                                                                  #                                FETCHING FOR THE THRUST DIRECTION FILTER THE
039132,000033:                                                                                                  #                                CDUD'S IN PNGCS-AUTO, THE CDU'S IN ALL OTHER
039133,000034:                                                                                                  #                                MODES.
039134,000035:                                                                                                  #                        3.      TO SUBSTITUTE A STOPRATE FOR THE NORMAL
039135,000036:                                                                                                  #                                AUTOPILOT COMMANDS WHENEVER
039136,000037:                                                                                                  #                                1) NOT IN PNGCS-AUTO, OR
039137,000038:                                                                                                  #                                2) ENGINE IS OFF.
039138,000039: 
039139,000040:                                                                                                  #  FUNCTIONAL DESCRIPTION:
039140,000041: 
039141,000042:                                                                                                  #  FINDCDUW PROVIDES THE INTERFACES BETWEEN THE VARIOUS POWERED FLITE GUIDANCE PROGRAMS
039142,000043:                                                                                                  #  AND THE DIGITAL AUTOPILOT.  THE INPUTS TO FINDCDUW ARE THE THRUST COMMAND VECTOR
039143,000044:                                                                                                  #  AND THE WINDOW COMMAND VECTOR, AND THE OUTPUTS ARE THE GIMBAL ANGLE
039144,000045:                                                                                                  #  INCREMENTS, THE COMMANDED ATTITUDE ANGLE RATES, AND THE COMMANDED
039145,000046:                                                                                                  #  ATTITUDE LAG ANGLES (WHICH ACCOUNT FOR THE ANGLES BY WHICH THE BODY WILL
039146,000047:                                                                                                  #  LAG BEHIND A RAMP COMMAND IN ATTITUDE ANGLE DUE TO THE FINITE ANGULAR
039147,000048:                                                                                                  #  ACCELERATIONS AVAILABLE).
039148,000049: 
039149,000050:                                                                                                  #  FINDCDUW ALINES THE ESTIMATED THRUST VECTOR FROM THE THRUST DIRECTION
039150,000051:                                                                                                  #  FILTER WITH THE THRUST COMMAND VECTOR, AND, WHEN XOVINHIB SET,
039151,000052:                                                                                                  #  ALINES THE +Z HALF OF THE LM ZX PLANE WITH THE WINDOW COMMAND VECTOR.
039152,000053: 

Page 909

039154,000055:                                                                                                  #  SPECIFICATIONS:
039155,000056: 
039156,000057:                                                                                                  #  INITIALIZATION:       A SINGLE INTERPRETIVE CALL TO INITCDUW IS REQUIRED
039157,000058:                                                                                                  #                        BEFORE EACH GUIDED MANEUVER USING FINDCDUW.
039158,000059: 
039159,000060:                                                                                                  #  CALL:                 INTERPRETIVE CALL TO FINDCDUW WITH THE THRUST COMMAND
039160,000061:                                                                                                  #                        VECTOR IN MPAC.  INTERPRETIVE CALL TO FINDCDUW -2 WITH
039161,000062:                                                                                                  #                        THE THRUST COMMAND VECTOR IN UNFC/2 AND NOT IN MPAC.
039162,000063: 
039163,000064:                                                                                                  #  RETURNS:              NORMAL INTERPRETIVE IN ALL CASES
039164,000065:                                                                                                  #                        1.      NORMALLY ALL AUTOPILOT CMDS ARE ISSUED.
039165,000066:                                                                                                  #                        2.      IF NOT PNGCS AUTO, DO STOPRATE AND RETURN
039166,000067:                                                                                                  #                                WITHOUT ISSUING AUTOPILOT CMDS.
039167,000068:                                                                                                  #                        3.      IF ENGINE OFF, DO STOPRATE AND RETURN WITHOUT
039168,000069:                                                                                                  #                                ISSUING AUTOPILOT CMDS.
039169,000070: 
039170,000071:                                                                                                  #  ALARMS:               00401   IF INPUTS DETERMINE AN ATTITUDE IN GIMBAL LOCK.
039171,000072:                                                                                                  #                                FINDCDUW DRIVES CDUXD AND CDUYD TO THE RQD VALUES,
039172,000073:                                                                                                  #                                BUT DRIVES CDUZD ONLY TO THE GIMBAL LOCK CONE.
039173,000074: 
039174,000075:                                                                                                  #                        00402   IF UNFC/2 OR UNWC/2 PRODUCE OVERFLOW WHEN
039175,000076:                                                                                                  #                                UNITIZED USING NORMUNIT.  FINDCDUW ISSUES
039176,000077:                                                                                                  #                                STOPRATE AS ONLY INPUT TO AUTOPILOT.
039177,000078: 
039178,000079:                                                                                                  #  INPUTS:               UNFC/2          THRUST COMMAND VECTOR, NEED NOT BE SEMI-UNIT.
039179,000080:                                                                                                  #                        UNWC/2          WINDOW COMMAND VECTOR, NEED NOT BE SEMI-UNIT.
039180,000081:                                                                                                  #                        XOVINHIB        FLAG DENOTING X AXIS OVERRIDE INHIBITED.
039181,000082:                                                                                                  #                        CSMDOCKD        FLAG DENOTING CSM DOCKED.
039182,000083:                                                                                                  #                        STEERSW         FLAG DENOTING INSUFF THRUST FOR THRUST DIR FLTR.
039183,000084: 
039184,000085:                                                                                                  #  OUTPUTS:              DELCDUX,Y,Z
039185,000086:                                                                                                  #                        OMEGAPD,+1,+2
039186,000087:                                                                                                  #                        DELPEROR,+1,+2
039187,000088:                                                                                                  #                        CPHI,+1,+2 FOR NOUN22
039188,000089: 
039189,000090:                                                                                                  #  DEBRIS:               FINDCDUW DESTROYS SINCDUX,Y,Z AND COSCDUX,Y,Z BY
039190,000091:                                                                                                  #                        WRITING INTO THESE LOCATIONS THE SINES AND COSINES
039191,000092:                                                                                                  #                        OF THE CDUD'S IN PNGCS-AUTO, OF THE CDU'S OTHERWISE.
039192,000093: 

Page 910

039194,000095:                                                                                                  #  INITIALIZATION FOR FINDCDUW
039195,000096: 
039196,000097: 30,3104                                           BANK     30                                    
039197,000098: 30,2000                                           SETLOC   FCDUW                                 
039198,000099: 30,2000                                           BANK                                           
039199,000100: 
039200,000101: 30,3104  E6,1646                                  EBANK=   ECDUW                                 
039201,000102: 30,3104                                           COUNT*   $$/FCDUW                              
039202,000103: 
039203,000104: 30,3104           77775        INITCDUW           VLOAD                                          
039204,000105: 30,3105           06520                                    UNITX                                 
039205,000106: 30,3106           03270                           STORE    UNFV/2                                
039206,000107: 30,3107           03262                           STORE    UNWC/2                                
039207,000108: 30,3110           77616                           RVQ                                            
039208,000109: 
039209,000110:                                                                                                  #  FINDCDUW PRELIMINARIES
039210,000111: 
039211,000112: 30,3111           77775                           VLOAD                                          #  FINDCDUW -2:  ENTRY WHEN UNFC/2 PRE-STORD
039212,000113: 30,3112           03254                                    UNFC/2                                #  INPUT VECTORS NEED NOT BE SEMI-UNIT
039213,000114: 30,3113           40200        FINDCDUW           BOV      SETPD                                 #  FINDCDUW: ENTRY WHEN UNFC/2 IN MPAC
039214,000115: 30,3114           61113                                    FINDCDUW                              #  INTERPRETER NOW INITIALIZED
039215,000116: 30,3115           00023                                    22                                    #  LOCS 0 THRU 21 FOR DIRECTION COSINE MAT
039216,000117: 30,3116           77420                           STQ      EXIT                                  
039217,000118: 30,3117           03247                                    QCDUWUSR                              #  SAVE RETURN ADDRESS
039218,000119: 
039219,000120:                                                                                                  #  MORE HAUSKEEPING
039220,000121: 30,3120           33761                           CA       ECDUWL                                
039221,000122: 30,3121           56003                           XCH      EBANK                                 #  SET EBANK
039222,000123: 30,3122           55646                           TS       ECDUWUSR                              #  SAVE USER'S EBANK
039223,000124: 
039224,000125: 30,3123           30111                           CA       DAPBOOLS                              
039225,000126: 30,3124           74737                           MASK     CSMDOCKD                              #  CSMDOCKD MUST NOT BE BIT15
039226,000127: 30,3125           10000                           CCS      A                                     
039227,000128: 30,3126           34753                           CA       ONE                                   #  INDEX IF CSM DOCKED
039228,000129: 30,3127           55650                           TS       NDXCDUW                               
039229,000130: 
039230,000131: 30,3130           34743                           CA       XOVINHIB                              #  XOVINHIB MUST NOT BE BIT15
039231,000132: 30,3131           55652                           TS       FLPAUTNO                              #  SET TO POS-NON-ZERO FLAG PNGCS AUTO NOT
039232,000133: 
039233,000134: 30,3132           70111                           MASK     DAPBOOLS                              
039234,000135: 30,3133           55651                           TS       FLAGOODW                              #  FLAGOODW = ANY PNZ NUMBER IF XOV INHIBTD
039235,000136: 

Page 911

039237,000138:                                                                                                  #  FETCH BASIC DATA
039238,000139: 30,3134           00004                           INHINT                                         #  RELINT AT PAUTNO (TC INTPRET)
039239,000140: 
039240,000141: 30,3135           30032                           CA       CDUX                                  #  FETCH CDUX,CDUY,CDUZ IN ALL CASES, BUT
039241,000142: 30,3136           54772                           TS       CDUSPOTX                              #        REPLACE BELOW IF PNGCS AUTO
039242,000143: 30,3137           30033                           CA       CDUY                                  
039243,000144: 30,3140           54766                           TS       CDUSPOTY                              
039244,000145: 30,3141           30034                           CA       CDUZ                                  
039245,000146: 30,3142           54770                           TS       CDUSPOTZ                              
039246,000147: 
039247,000148: 30,3143           34742                           CA       BIT10                                 #  PNGCS CONTROL BIT
039248,000149: 30,3144           00006                           EXTEND                                         
039249,000150: 30,3145           02030                           RAND     CHAN30                                
039250,000151: 30,3146           10000                           CCS      A                                     
039251,000152: 30,3147           13164                           TCF      PAUTNO                                #  NOT PNGCS (BITS INVERTED)
039252,000153: 
039253,000154: 30,3150           34736                           CA       BIT14                                 #  AUTO MODE BIT
039254,000155: 30,3151           00006                           EXTEND                                         
039255,000156: 30,3152           02031                           RAND     CHAN31                                
039256,000157: 30,3153           10000                           CCS      A                                     
039257,000158: 30,3154           13164                           TCF      PAUTNO                                #  NOT AUTO (BITS INVERTED)
039258,000159: 
039259,000160: 30,3155           55652                           TS       FLPAUTNO                              #  RESET FLAG PNGCS AUTO NOT
039260,000161: 
039261,000162: 30,3156           31635                           CA       CDUXD                                 #  PNGCS AUTO:  FETCH CDUXD,CDUYD,CDUZD
039262,000163: 30,3157           54772                           TS       CDUSPOTX                              
039263,000164: 30,3160           31636                           CA       CDUYD                                 
039264,000165: 30,3161           54766                           TS       CDUSPOTY                              
039265,000166: 30,3162           31637                           CA       CDUZD                                 
039266,000167: 30,3163           54770                           TS       CDUSPOTZ                              
039267,000168: 

Page 912

039269,000170:                                                                                                  #  FETCH INPUTS
039270,000171: 30,3164           06037        PAUTNO             TC       INTPRET                               #  ENTERING THRUST CMD STILL IN MPAC
039271,000172: 30,3165           77634                           RTB                                            
039272,000173: 30,3166           21726                                    NORMUNIT                              
039273,000174: 30,3167           24001                           STOVL    UNX/2                                 #  SEMI-UNIT THRUST CMD AS INITIAL UNX/2
039274,000175: 30,3170           03262                                    UNWC/2                                
039275,000176: 30,3171           47034                           RTB      RTB                                   
039276,000177: 30,3172           21726                                    NORMUNIT                              
039277,000178: 30,3173           47615                                    QUICTRIG                              #  ALWAYS RQD TO OBTAIN TRIGS OF CDUD'S
039278,000179: 30,3174           24015                           STOVL    UNZ/2                                 #  SEMI-UNIT WINDOW CMD AS INITIAL UNZ/2
039279,000180: 30,3175           00325                                    DELV                                  
039280,000181: 30,3176           53404                           BOVB     UNIT                                  
039281,000182: 30,3177           61750                                    NOATTCNT                              #  AT LEAST ONE ENTERING CMD VCT ZERO
039282,000183: 30,3200           45000                           BOV      CALL                                  
039283,000184: 30,3201           61215                                    AFTRFLTR                              #  IF UNIT DELV OVERFLOWS, SKIP FILTER
039284,000185: 30,3202           47671                                    *SMNB*                                #  YIELDS UNIT(DELV) IN VEH COORDS FOR FLTR
039285,000186: 
039286,000187:                                                                                                  #  THRUST DIRECTION FILTER
039287,000188: 
039288,000189: 30,3203           77776                           EXIT                                           
039289,000190: 
039290,000191: 30,3204           31671                           CA       UNFVY/2                               #  FOR RESTARTS, UNFV/2 ALWAYS INTACT, MPAC
039291,000192: 30,3205           22157                           LXCH     MPAC       +3                         #        RENEWED AFTER RETURN FROM CALLER,
039292,000193: 30,3206           03503                           TC       FLTRSUB                               #        TWO FILTER UPDATES MAY BE DONE.
039293,000194: 30,3207           55671                           TS       UNFVY/2                               #  UNFV/2 NEED NOT BE EXACTLY SEMI-UNIT.
039294,000195: 
039295,000196: 30,3210           31673                           CA       UNFVZ/2                               
039296,000197: 30,3211           22161                           LXCH     MPAC       +5                         
039297,000198: 30,3212           03503                           TC       FLTRSUB                               
039298,000199: 30,3213           55673                           TS       UNFVZ/2                               
039299,000200: 
039300,000201: 30,3214           06037                           TC       INTPRET                               #  COMPLETES FILTER
039301,000202: 

Page 913

039303,000204:                                                                                                  #  FIND A SUITABLE WINDOW POINTING VECTOR
039304,000205: 
039305,000206: 30,3215           46135        AFTRFLTR           SLOAD    BHIZ                                  #  IF XOV NOT INHIBITED, GO FETCH ZNB
039306,000207: 30,3216           03252                                    FLAGOODW                              
039307,000208: 30,3217           61223                                    FETCHZNB                              
039308,000209: 30,3220           45175                           VLOAD    CALL                                  
039309,000210: 30,3221           00015                                    UNZ/2                                 
039310,000211: 30,3222           61523                                    UNWCTEST                              
039311,000212: 
039312,000213: 30,3223           77775        FETCHZNB           VLOAD                                          
039313,000214: 30,3224           02162                                    ZNBPIP                                
039314,000215: 30,3225           34015                           STCALL   UNZ/2                                 
039315,000216: 30,3226           61523                                    UNWCTEST                              
039316,000217: 
039317,000218: 30,3227           57575                           VLOAD    VCOMP                                 #  Z AND -X CAN'T BOTH PARALLEL UNFC/2
039318,000219: 30,3230           02146                                    XNBPIP                                
039319,000220: 30,3231           00015                           STORE    UNZ/2                                 
039320,000221: 
039321,000222:                                                                                                  #  COMPUTE THE REQUIRED DIRECTION COSINE MATRIX
039322,000223: 
039323,000224: 30,3232           47375        DCMCL              VLOAD    VXV                                   
039324,000225: 30,3233           00015                                    UNZ/2                                 
039325,000226: 30,3234           00001                                    UNX/2                                 
039326,000227: 30,3235           41456                           UNIT     PUSH                                  #  UNY/2 FIRST ITERATION
039327,000228: 30,3236           76435                           VXV      VSL1                                  
039328,000229: 30,3237           00001                                    UNX/2                                 
039329,000230: 30,3240           00015                           STORE    UNZ/2                                 #  -UNZ/2 FIRST ITERATION
039330,000231: 30,3241           63361                           VXSC     PDVL                                  #  EXCHANGE -UNFVZ/2 UNZ/2 FOR UNY/2
039331,000232: 30,3242           03274                                    UNFVZ/2                               #  MUST BE SMALL
039332,000233: 30,3243           51361                           VXSC     BVSU                                  #  YIELDS -UNFVY/2 UNY/2-UNFVZ/2 UNZ/2
039333,000234: 30,3244           03272                                    UNFVY/2                               #  MUST BE SMALL
039334,000235: 30,3245           53372                           VSL1     VAD                                   
039335,000236: 30,3246           00001                                    UNX/2                                 
039336,000237: 30,3247           77656                           UNIT                                           #  TOTALLY ELIMINATES THRUST POINTING ERROR
039337,000238: 30,3250           00001                           STORE    UNX/2                                 #  UNX/2
039338,000239: 30,3251           76435                           VXV      VSL1                                  
039339,000240: 30,3252           00015                                    UNZ/2                                 #  -UNZ/2 WAS STORED HERE REMEMBER
039340,000241: 30,3253           00007                           STORE    UNY/2                                 #  UNY/2
039341,000242: 30,3254           47276                           VCOMP    VXV                                   
039342,000243: 30,3255           00001                                    UNX/2                                 
039343,000244: 30,3256           77772                           VSL1                                           
039344,000245: 30,3257           00015                           STORE    UNZ/2                                 #  UNZ/2
039345,000246: 

Page 914

039347,000248:                                                                                                  #  COMPUTE THE REQUIRED GIMBAL ANGLES
039348,000249: 
039349,000250: 30,3260           77624                           CALL                                           
039350,000251: 30,3261           61533                                    NB2CDUSP                              #  YIELDS THE RQD GIMBAL ANGLES, 2'S, PI
039351,000252: 30,3262           77776                           EXIT                                           
039352,000253: 
039353,000254:                                                                                                  #  LIMIT THE MIDDLE GIMBAL ANGLE & COMPUTE THE UNLIMITED GIMBAL ANGLE CHGS
039354,000255: 
039355,000256: 30,3263           30156                           CA       MPAC       +2                         #  LIMIT THE MGA
039356,000257: 30,3264           54001                           TS       L                                     #  CAN'T LXCH:  NEED UNLIMITED MGA FOR ALARM
039357,000258: 30,3265           33773                           CA       CDUZDLIM                              
039358,000259: 30,3266           03727                           TC       LIMITSUB                              #  YIELDS LIMITED MGA.  1 BIT ERROR POSSIBLE
039359,000260: 30,3267           56156                           XCH      MPAC       +2                         #        BECAUSE USING 2'S COMP.  WHO CARES?
039360,000261: 30,3270           00006                           EXTEND                                         
039361,000262: 30,3271           20156                           MSU      MPAC       +2                         #  THIS BETTER YIELD ZERO
039362,000263: 30,3272           00006                           EXTEND                                         
039363,000264: 30,3273           13275                           BZF      +2                                    
039364,000265: 30,3274           13756                           TCF      ALARMMGA                              
039365,000266: 
039366,000267: 30,3275           00004        MGARET             INHINT                                         #  RELINT AT TC INTPRET AFTER TCQCDUW
039367,000268: 
039368,000269: 30,3276           22007                           ZL                                             
039369,000270: 30,3277           34752                           CA       TWO                                   
039370,000271: 30,3300           54142        DELGMBLP           TS       TEM2                                  
039371,000272: 
039372,000273: 30,3301           30001                           CA       L                                     #  TO PREVENT FALSE STARTS ABOUT X, ZERO
039373,000274: 30,3302           00006                           EXTEND                                         #        FLAGOODW IF DELGMBZ OR Y TOO BIG.
039374,000275: 30,3303           70000                           SQUARE                                         
039375,000276: 30,3304           64350                           AD       HI5                                   #  WITHIN 1 BIT OF -(45 DEG SQUARED)
039376,000277: 30,3305           00006                           EXTEND                                         
039377,000278: 30,3306           63311                           BZMF     +3                                    
039378,000279: 30,3307           34755                           CA       ZERO                                  
039379,000280: 30,3310           55651                           TS       FLAGOODW                              
039380,000281: 
039381,000282: 30,3311           50142                           INDEX    TEM2                                  
039382,000283: 30,3312           30154                           CA       MPAC                                  
039383,000284: 30,3313           50142                           INDEX    TEM2                                  
039384,000285: 30,3314           54321                           TS       CPHI                                  #  OUTPUTS TO NOUN22
039385,000286: 30,3315           00006                           EXTEND                                         
039386,000287: 30,3316           50142                           INDEX    TEM2                                  
039387,000288: 30,3317           21635                           MSU      CDUXD                                 #  NO MATTER THAT THESE SLIGHTLY DIFFERENT
039388,000289: 30,3320           40000                           COM                                            #  FROM WHEN WE INITIALLY FETCHED THEM
039389,000290: 30,3321           50142                           INDEX    TEM2                                  
039390,000291: 30,3322           55675                           TS       -DELGMB                               #  -UNLIMITED GIMBAL ANGLE CHGS, 1'S, PI
039391,000292: 30,3323           54001                           TS       L                                     #  FOR PRECEDING TEST ON NEXT LOOP PASS
039392,000293: 30,3324           10142                           CCS      TEM2                                  
039393,000294: 30,3325           13300                           TCF      DELGMBLP                              
039394,000295: 

Page 915

039396,000297:                                                                                                  #  BRANCHES TO NOATTCNT
039397,000298: 30,3326           11652                           CCS      FLPAUTNO                              
039398,000299: 30,3327           13752                           TCF      NOATTCNT   +2                         #  NOT PNGCS AUTO
039399,000300: 
039400,000301: 30,3330           30101                           CA       FLAGWRD5                              
039401,000302: 30,3331           74745                           MASK     ENGONBIT                              
039402,000303: 30,3332           00006                           EXTEND                                         
039403,000304: 30,3333           13752                           BZF      NOATTCNT   +2                         #  ENGINE NOT ON
039404,000305: 

Page 916

039406,000307:                                                                                                  #  LIMIT THE ATTITUDE ANGLE CHANGES
039407,000308: 
039408,000309:                                                                                                  #  THIS SECTION LIMITS THE ATTITUDE ANGLE CHANGES ABOUT A SET OF ORTHOGONAL VEHICLE AXES X,YPRIME,ZPRIME.
039409,000310:                                                                                                  #  THESE AXES COINCIDE WITH THE COMMANDED VEHICLE AXES IF AND ONLY IF CDUXD IS ZERO.  THE PRIME SYSTEM IS
039410,000311:                                                                                                  #  THE COMMANDED VEHICLE SYSTEM ROTATED ABOUT THE X AXIS TO BRING THE Z AXIS INTO ALINEMENT WITH THE MIDDLE GIMBAL
039411,000312:                                                                                                  #  AXIS.  ATTITUDE ANGLE CHANGES IN THE PRIME SYSTEM ARE RELATED TO SMALL GIMBAL ANGLE CHANGES BY:
039412,000313: 
039413,000314:                                                                                                  #        *   -DELATTX    *   * 1     SIN(CDUZD)     0 * * -DELGMBX *
039414,000315:                                                                                                  #        *               *   *                        * *          *
039415,000316:                                                                                                  #        * -DELATTYPRIME * = * 0     COS(CDUZD)     0 * * -DELGMBY *
039416,000317:                                                                                                  #        *               *   *                        * *          *
039417,000318:                                                                                                  #        * -DELATTZPRIME *   * 0         0          1 * * -DELGMBZ *
039418,000319: 
039419,000320: 30,3334           23677                           LXCH     -DELGMB    +2                         #  SAME AS -DELATTZPRIME UNLIMITED
039420,000321: 30,3335           51650                           INDEX    NDXCDUW                               
039421,000322: 30,3336           33767                           CA       DAZMAX                                
039422,000323: 30,3337           03727                           TC       LIMITSUB                              
039423,000324: 30,3340           55677                           TS       -DELGMB    +2                         #  -DELGMBZ
039424,000325: 
039425,000326: 30,3341           31676                           CA       -DELGMB    +1                         
039426,000327: 30,3342           00006                           EXTEND                                         
039427,000328: 30,3343           70746                           MP       COSCDUZ                               #  YIELDS -DELATTYPRIME/2 UNLIMITED
039428,000329: 30,3344           54001                           TS       L                                     
039429,000330: 30,3345           51650                           INDEX    NDXCDUW                               
039430,000331: 30,3346           33771                           CA       DAY/2MAX                              
039431,000332: 30,3347           03727                           TC       LIMITSUB                              
039432,000333: 30,3350           00006                           EXTEND                                         
039433,000334: 30,3351           10746                           DV       COSCDUZ                               
039434,000335: 30,3352           57676                           XCH      -DELGMB    +1                         #  -DELGMBY, FETCHING UNLIMITED VALUE
039435,000336: 
039436,000337: 30,3353           00006                           EXTEND                                         
039437,000338: 30,3354           70740                           MP       SINCDUZ                               
039438,000339: 30,3355           20001                           DDOUBL                                         
039439,000340: 30,3356           40000                           COM                                            
039440,000341: 30,3357           00006                           EXTEND                                         #  YIELDS +DELATTX UNLIMITD, MAG < 180 DEG,
039441,000342: 30,3360           21675                           MSU      -DELGMB                               #        BASED ON UNLIMITED DELGMBY.
039442,000343: 30,3361           54001                           TS       L                                     #        ONE BIT ERROR IF OPERANDS IN MSU
039443,000344: 30,3362           51650                           INDEX    NDXCDUW                               #        OF MIXED SIGNS.  WHO CARES?
039444,000345: 30,3363           33767                           CA       DAXMAX                                
039445,000346: 30,3364           03727                           TC       LIMITSUB                              
039446,000347: 30,3365           55675                           TS       -DELGMB                               #  SAVE LIMITED +DELATTX
039447,000348: 30,3366           11651                           CCS      FLAGOODW                              
039448,000349: 30,3367           41675                           CS       -DELGMB                               #  FETCH IT BACK CHGING SIGN IF WINDOW GOOD
039449,000350: 30,3370           55675                           TS       -DELGMB                               #  OTHERWISE USE ZERO FOR -DELATTX
039450,000351: 30,3371           41676                           CS       -DELGMB    +1                         
039451,000352: 30,3372           00006                           EXTEND                                         
039452,000353: 30,3373           70740                           MP       SINCDUZ                               
039453,000354: 30,3374           20001                           DDOUBL                                         #  YIELDS -CNTRIB TO -DELATTX FROM -DELGMBY
039454,000355: 30,3375           27675                           ADS      -DELGMB                               #  -DELGMBX.  NO OVERFLOW SINCE LIMITED TO
039455,000356:                                                                                                  #  20DEG(1+SIN(70DEG)/COS(70DEG)) < 180DEG
039456,000357: 

Page 917

039458,000359:                                                                                                  #  COMPUTE COMMANDED ATTITUDE RATES
039459,000360: 
039460,000361:                                                                                                  #        * OMEGAPD *   * -2         -4 SINCDUZ              +0    * * -DELGMBX *
039461,000362:                                                                                                  #        *         *   *                                          * *          *
039462,000363:                                                                                                  #        * OMEGAQD * = * +0     -8 COSCDUZ COSCDUX     -4 SINCDUX * * -DELGMBY *
039463,000364:                                                                                                  #        *         *   *                                          * *          *
039464,000365:                                                                                                  #        * OMEGARD *   * +0     +8 COSCDUZ SINCDUX     -4 COSCDUX * * -DELGMBZ *
039465,000366: 
039466,000367:                                                                                                  #  ATTITUDE ANGLE RATES IN UNITS OF PI/4 RAD/SEC = K TRIG FCNS IN UNITS OF 2 X GIMBAL ANGLE RATES IN UNITS OF
039467,000368:                                                                                                  #  PI/2 RAD/SEC.  THE CONSTANTS ARE BASED ON DELGMB BEING THE GIMBAL ANGLE CHANGES IN UNITS OF PI RADIANS,
039468,000369:                                                                                                  #  AND 2 SECONDS BEING THE COMPUTATION PERIOD (THE PERIOD BETWEEN SUCCESSIVE PASSES THRU FINDCDUW).
039469,000370: 
039470,000371: 30,3376           41675                           CS       -DELGMB                               
039471,000372: 30,3377           55643                           TS       OMEGAPD                               
039472,000373: 30,3400           41676                           CS       -DELGMB    +1                         
039473,000374: 30,3401           00006                           EXTEND                                         
039474,000375: 30,3402           70740                           MP       SINCDUZ                               
039475,000376: 30,3403           20001                           DDOUBL                                         
039476,000377: 30,3404           27643                           ADS      OMEGAPD                               
039477,000378: 30,3405           27643                           ADS      OMEGAPD                               
039478,000379: 
039479,000380: 30,3406           41676                           CS       -DELGMB    +1                         
039480,000381: 30,3407           00006                           EXTEND                                         
039481,000382: 30,3410           70750                           MP       COSCDUX                               
039482,000383: 30,3411           20001                           DDOUBL                                         
039483,000384: 30,3412           00006                           EXTEND                                         
039484,000385: 30,3413           70746                           MP       COSCDUZ                               
039485,000386: 30,3414           55644                           TS       OMEGAQD                               
039486,000387: 30,3415           41677                           CS       -DELGMB    +2                         
039487,000388: 30,3416           00006                           EXTEND                                         
039488,000389: 30,3417           70742                           MP       SINCDUX                               
039489,000390: 30,3420           27644                           ADS      OMEGAQD                               
039490,000391: 30,3421           27644                           ADS      OMEGAQD                               
039491,000392: 30,3422           27644                           ADS      OMEGAQD                               
039492,000393: 
039493,000394: 30,3423           31676                           CA       -DELGMB    +1                         
039494,000395: 30,3424           00006                           EXTEND                                         
039495,000396: 30,3425           70742                           MP       SINCDUX                               
039496,000397: 30,3426           20001                           DDOUBL                                         
039497,000398: 30,3427           00006                           EXTEND                                         
039498,000399: 30,3430           70746                           MP       COSCDUZ                               
039499,000400: 30,3431           55645                           TS       OMEGARD                               
039500,000401: 30,3432           41677                           CS       -DELGMB    +2                         
039501,000402: 30,3433           00006                           EXTEND                                         
039502,000403: 30,3434           70750                           MP       COSCDUX                               
039503,000404: 30,3435           27645                           ADS      OMEGARD                               
039504,000405: 30,3436           27645                           ADS      OMEGARD                               
039505,000406: 30,3437           27645                           ADS      OMEGARD                               
039506,000407: 

Page 918

039508,000409:                                                                                                  #  FINAL TRANSFER
039509,000410: 
039510,000411: 30,3440           34752                           CA       TWO                                   
039511,000412: 30,3441           54142        CDUWXFR            TS       TEM2                                  
039512,000413: 30,3442           50142                           INDEX    TEM2                                  
039513,000414: 30,3443           31675                           CA       -DELGMB                               
039514,000415: 30,3444           00006                           EXTEND                                         
039515,000416: 30,3445           73774                           MP       DT/DELT                               #  RATIO OF DAP INTERVAL TO CDUW INTERVAL
039516,000417: 30,3446           03743                           TC       ONESTO2S                              
039517,000418: 30,3447           50142                           INDEX    TEM2                                  
039518,000419: 30,3450           55640                           TS       DELCDUX                               #  ANGLE INTERFACE
039519,000420: 
039520,000421: 30,3451           50142                           INDEX    TEM2                                  
039521,000422: 30,3452           11643                           CCS      OMEGAPD                               
039522,000423: 30,3453           64753                           AD       ONE                                   
039523,000424: 30,3454           13456                           TCF      +2                                    
039524,000425: 30,3455           64753                           AD       ONE                                   
039525,000426: 30,3456           00006                           EXTEND                                         #  WE NOW HAVE ABS(OMEGAPD,QD,RD)
039526,000427: 30,3457           50142                           INDEX    TEM2                                  
039527,000428: 30,3460           71643                           MP       OMEGAPD                               
039528,000429: 30,3461           00006                           EXTEND                                         
039529,000430: 30,3462           74741                           MP       BIT11                                 #  1/16
039530,000431: 30,3463           00006                           EXTEND                                         
039531,000432: 30,3464           50142                           INDEX    TEM2                                  #                   2
039532,000433: 30,3465           11530                           DV       1JACC                                 #  UNITS PI/4 RAD/SEC
039533,000434: 30,3466           54001                           TS       L                                     
039534,000435: 30,3467           33771                           CA       DELERLIM                              
039535,000436: 30,3470           03727                           TC       LIMITSUB                              
039536,000437: 30,3471           50142                           INDEX    TEM2                                  
039537,000438: 30,3472           55277                           TS       DELPEROR                              #  LAG ANGLE = OMEGA ABS(OMEGA)/2 ACCEL
039538,000439: 30,3473           10142                           CCS      TEM2                                  
039539,000440: 30,3474           13441                           TCF      CDUWXFR                               
039540,000441: 
039541,000442:                                                                                                  #  HAUSKEEPING AND RETURN
039542,000443: 
039543,000444: 30,3475           31646        TCQCDUW            CA       ECDUWUSR                              
039544,000445: 30,3476           54003                           TS       EBANK                                 #  RETURN USER'S EBANK
039545,000446: 
039546,000447: 30,3477           06037                           TC       INTPRET                               
039547,000448: 30,3500           52001                           SETPD    GOTO                                  
039548,000449: 30,3501           00001                                    0                                     
039549,000450: 30,3502           03247                                    QCDUWUSR                              #  NORMAL AND ABNORMAL RETURN TO USER
039550,000451: 

Page 919

039552,000453:                                                                                                  #  THRUST VECTOR FILTER SUBROUTINE
039553,000454: 
039554,000455: 30,3503           00006        FLTRSUB            EXTEND                                         
039555,000456: 30,3504           22142                           QXCH     TEM2                                  
039556,000457: 30,3505           54143                           TS       TEM3                                  #  SAVE ORIGINAL OFFSET
039557,000458: 30,3506           40000                           COM                                            #  ONE MCT, NO WDS, CAN BE SAVED IF NEG OF
039558,000459: 30,3507           60001                           AD       L                                     #        ORIG OFFSET ARRIVES IN A, BUT IT'S
039559,000460: 30,3510           00006                           EXTEND                                         #        NOT WORTH THE INCREASED OBSCURITY.
039560,000461: 30,3511           51650                           INDEX    NDXCDUW                               
039561,000462: 30,3512           73762                           MP       GAINFLTR                              
039562,000463: 30,3513           54001                           TS       L                                     #  INCR TO OFFSET, UNLIMITED
039563,000464: 30,3514           33764                           CA       DUNFVLIM                              #  SAME LIMIT FOR Y AND Z
039564,000465: 30,3515           03727                           TC       LIMITSUB                              #  YIELDS INCR TO OFFSET, LIMITED
039565,000466: 30,3516           60143                           AD       TEM3                                  #  ORIGINAL OFFSET
039566,000467: 30,3517           54001                           TS       L                                     #  TOTAL OFFSET, UNLIMITED
039567,000468: 30,3520           33765                           CA       UNFVLIM                               #  SAME LIMIT FOR Y AND Z
039568,000469: 30,3521           03727                           TC       LIMITSUB                              #  YIELDS TOTAL OFFSET, LIMITED
039569,000470: 30,3522           00142                           TC       TEM2                                  
039570,000471: 
039571,000472:                                                                                                  #  SUBR TO TEST THE ANGLE BETWEEN THE PROPOSED WINDOW AND THRUST CMD VCTS
039572,000473: 
039573,000474: 30,3523           63441        UNWCTEST           DOT      DSQ                                   
039574,000475: 30,3524           00001                                    UNX/2                                 
039575,000476: 30,3525           50025                           DSU      BMN                                   
039576,000477: 30,3526           21767                                    DOTSWFMX                              
039577,000478: 30,3527           61232                                    DCMCL                                 
039578,000479: 30,3530           43531                           SSP      RVQ                                   #  RVQ FOR ALT CHOICE IF DOT MAGN TOO LARGE
039579,000480: 30,3531           03252                                    FLAGOODW                              #        ZEROING WINDOW GOOD FLAG
039580,000481: 30,3532           00000                                    0                                     
039581,000482: 

Page 920

039583,000484:                                                                                                  #  NB2CDUSP RETURNS THE 2'S COMPLEMENT, PI, SP CDU ANGLES X,Y,Z IN MPAC,+1,+2 GIVEN THE MATRIX WHOSE ROW VECTORS
039584,000485:                                                                                                  #  ARE THE SEMI-UNIT NAV BASE VECTORS X,Y,Z EXPRESSED IN STABLE MEMBER COORDINATES, LOCATED AT 0 IN THE PUSH LIST.
039585,000486:                                                                                                  #  NB2CDUSP USES ARCTRGSP WHICH HAS A MAXIMUM ERROR OF +-4 BITS.
039586,000487: 
039587,000488: 30,3533           63545        NB2CDUSP           DLOAD    DSQ                                   
039588,000489: 30,3534           00003                                    2                                     
039589,000490: 30,3535           51021                           BDSU     BPL                                   
039590,000491: 30,3536           06512                                    DP1/4TH                               
039591,000492: 30,3537           61542                                    +3                                    
039592,000493: 30,3540           77745                           DLOAD                                          
039593,000494: 30,3541           06522                                    ZEROVECS                              #  IN CASE SIN WAS SLIGHTLY > 1/2
039594,000495: 30,3542           77566                           SQRT     EXIT                                  #  YIELDS COS(CDUZ) IN UNITS OF 2
039595,000496: 
039596,000497: 30,3543           00006                           EXTEND                                         
039597,000498: 30,3544           30155                           DCA      MPAC                                  
039598,000499: 30,3545           20001                           DDOUBL                                         
039599,000500: 30,3546           54145                           TS       TEM5                                  
039600,000501: 30,3547           13552                           TCF      +3                                    
039601,000502: 30,3550           34733                           CA       POSMAX                                #  OVERFLOW.  FETCH POSMAX, MPAC ALWAYS POS
039602,000503: 30,3551           54145                           TS       TEM5                                  #  COS(CDUZ) IN TEM5, UNITS 1
039603,000504: 
039604,000505: 30,3552           50120                           INDEX    FIXLOC                                
039605,000506: 30,3553           30002                           CA       2                                     
039606,000507: 30,3554           22154                           LXCH     MPAC                                  
039607,000508: 30,3555           03622                           TC       ARCTRGSP                              
039608,000509: 30,3556           54156                           TS       MPAC       +2                         #  CDUZ
039609,000510: 
039610,000511: 30,3557           34755                           CA       ZERO                                  
039611,000512: 30,3560           03600                           TC       DVBYCOSM                              
039612,000513: 30,3561           34751                           CA       FOUR                                  
039613,000514: 30,3562           03600                           TC       DVBYCOSM                              
039614,000515: 30,3563           40141                           CS       TEM1                                  
039615,000516: 30,3564           03622                           TC       ARCTRGSP                              
039616,000517: 30,3565           54155                           TS       MPAC       +1                         #  CDUY
039617,000518: 
039618,000519: 30,3566           34750                           CA       BIT4                                  
039619,000520: 30,3567           03600                           TC       DVBYCOSM                              
039620,000521: 30,3570           33577                           CA       16OCT                                 
039621,000522: 30,3571           03600                           TC       DVBYCOSM                              
039622,000523: 30,3572           40141                           CS       TEM1                                  
039623,000524: 30,3573           03622                           TC       ARCTRGSP                              
039624,000525: 30,3574           54154                           TS       MPAC                                  #  CDUX
039625,000526: 
039626,000527: 30,3575           06037                           TC       INTPRET                               
039627,000528: 30,3576           77616                           RVQ                                            
039628,000529: 
039629,000530: 30,3577           00016        16OCT              OCT      16                                    
039630,000531: 

Page 921

039632,000533:                                                                                                  #  THE ELEMENTS OF THE NAV BASE MATRIX WHICH WE MUST DIVIDE BY COS(MGA)
039633,000534:                                                                                                  #  ALREADY CONTAIN COS(MGA)/2 AS A FACTOR. THEREFORE THE QUOTIENT SHOULD
039634,000535:                                                                                                  #  ORDINARILY NEVER EXCEED 1/2 IN MAGNITUDE.  BUT IF THE MGA IS NEAR PI/2
039635,000536:                                                                                                  #  THEN COS(MGA) IS NEAR ZERO, AND THERE MAY BE SOME CHAFF IN THE OTHER
039636,000537:                                                                                                  #  ELEMENTS OF THE MATRIX WHICH WOULD PRODUCE CHAOS UNDER DIVISION.
039637,000538:                                                                                                  #  BEFORE DIVIDING WE MAKE SURE COS(MGA) IS AT LEAST ONE BIT LARGER
039638,000539:                                                                                                  #  THAN THE MAGNITUDE OF THE HIGH ORDER PART OF THE OPERAND.
039639,000540: 
039640,000541:                                                                                                  #  IF ONE OR MORE DIVIDES CANNOT BE PERFORMED, THIS MEANS THAT THE
039641,000542:                                                                                                  #  REQUIRED MGA IS VERY NEARLY +-PI/2 AND THEREFORE THE OTHER GIMBAL
039642,000543:                                                                                                  #  ANGLES ARE INDETERMINATE.  THE INNER AND OUTER GIMBAL ANGLES RETURNED
039643,000544:                                                                                                  #  IN THIS CASE WILL BE RANDOM MULTIPLES OF PI/2.
039644,000545: 
039645,000546: 30,3600           60120        DVBYCOSM           AD       FIXLOC                                
039646,000547: 30,3601           54116                           TS       ADDRWD                                #  ADRES OF OPERAND
039647,000548: 
039648,000549: 30,3602           50116                           INDEX    ADDRWD                                #  FETCH NEG ABS OF OPERAND, AD TEM5, AND
039649,000550: 30,3603           30000                           CA       0                                     #        SKIP DIVIDE IF RESULT NEG OR ZERO
039650,000551: 30,3604           00006                           EXTEND                                         
039651,000552: 30,3605           63607                           BZMF     +2                                    
039652,000553: 30,3606           40000                           COM                                            
039653,000554: 30,3607           60145                           AD       TEM5                                  #  C(A) ZERO OR NEG, C(TEM5) ZERO OR POS
039654,000555: 30,3610           00006                           EXTEND                                         
039655,000556: 30,3611           63617                           BZMF     TSL&TCQ                               #  DIFFERENCE ALWAYS SMALL IF BRANCH
039656,000557: 
039657,000558: 30,3612           00006                           EXTEND                                         #  TEM5 EXCEEDS ABS HIGH ORDER PART OF
039658,000559: 30,3613           50116                           INDEX    ADDRWD                                #        OPERAND BY AT LEAST ONE BIT.
039659,000560: 30,3614           30001                           DCA      0                                     #        THEREFORE IT EXCEEDS THE DP OPERAND
039660,000561: 30,3615           00006                           EXTEND                                         #        AND DIVISION WILL ALWAYS SUCCEED.
039661,000562: 30,3616           10145                           DV       TEM5                                  
039662,000563: 30,3617           54001        TSL&TCQ            TS       L                                     
039663,000564: 30,3620           22141                           LXCH     TEM1                                  
039664,000565: 30,3621           00002                           TC       Q                                     
039665,000566: 

Page 922

039667,000568:                                                                                                  #  ARCTRGSP RETURNS THE 2'S COMPLEMENT, PI, SP ANGLE IN THE A REGISTER GIVEN ITS SINE IN A AND ITS COSINE IN L IN
039668,000569:                                                                                                  #  UNITS OF 2.  THE RESULT IS AN UNAMBIGUOUS ANGLE ANYWHERE IN THE CIRCLE, WITH A MAXIMUM ERROR OF +-4 BITS.
039669,000570:                                                                                                  #  THE ERROR IS PRODUCED BY THE SUBROUTINE SPARCSIN WHICH IS USED ONLY IN THE REGION +-45 DEGREES.
039670,000571: 
039671,000572: 30,3622           00006        ARCTRGSP           EXTEND                                         
039672,000573: 30,3623           13665                           BZF      SINZERO                               #  TO AVOID DIVIDING BY ZERO
039673,000574: 
039674,000575: 30,3624           00006                           EXTEND                                         
039675,000576: 30,3625           22144                           QXCH     TEM4                                  
039676,000577: 30,3626           54142                           TS       TEM2                                  
039677,000578: 30,3627           30001                           CA       L                                     
039678,000579: 30,3630           54143                           TS       TEM3                                  
039679,000580: 30,3631           34755                           CA       ZERO                                  
039680,000581: 30,3632           00006                           EXTEND                                         
039681,000582: 30,3633           10142                           DV       TEM2                                  
039682,000583: 30,3634           00006                           EXTEND                                         
039683,000584: 30,3635           13654                           BZF      USECOS                                
039684,000585: 
039685,000586: 30,3636           10143                           CCS      TEM3                                  #  SIN IS SMALLER OR EQUAL
039686,000587: 30,3637           34755                           CA       ZERO                                  
039687,000588: 30,3640           13644                           TCF      +4                                    
039688,000589: 30,3641           40142                           CS       TEM2                                  #  IF COS NEG, REVERSE SIGN OF SIN,
039689,000590: 30,3642           54142                           TS       TEM2                                  #        ANGLE = PI-ARCSIN(SIN)
039690,000591: 30,3643           34735                           CA       NEGMAX                                #  PICK UP PI, 2'S COMPLEMENT
039691,000592: 30,3644           54143                           TS       TEM3                                  #  WE NO LONGER NEED COS
039692,000593: 30,3645           30142                           CA       TEM2                                  
039693,000594: 30,3646           03672                           TC       SPARCSIN   -1                         
039694,000595: 30,3647           03743                           TC       ONESTO2S                              
039695,000596: 30,3650           00006                           EXTEND                                         
039696,000597: 30,3651           20143                           MSU      TEM3                                  
039697,000598: 30,3652           03743        1TO2&TCQ           TC       ONESTO2S                              
039698,000599: 30,3653           00144                           TC       TEM4                                  
039699,000600: 
039700,000601: 30,3654           40143        USECOS             CS       TEM3                                  #  COS IS SMALLER
039701,000602: 30,3655           03672                           TC       SPARCSIN   -1                         #  ANGLE = SIGN(SIN)(PI/2-ARCSIN(COS))
039702,000603: 30,3656           64736                           AD       HALF                                  
039703,000604: 30,3657           54143                           TS       TEM3                                  #  WE NO LONGER NEED COS
039704,000605: 30,3660           10142                           CCS      TEM2                                  
039705,000606: 30,3661           30143                           CA       TEM3                                  
039706,000607: 30,3662           13652                           TCF      1TO2&TCQ                              
039707,000608: 30,3663           40143                           CS       TEM3                                  
039708,000609: 30,3664           13652                           TCF      1TO2&TCQ                              
039709,000610: 
039710,000611: 30,3665           10001        SINZERO            CCS      L                                     
039711,000612: 30,3666           34755                           CA       ZERO                                  
039712,000613: 30,3667           00002                           TC       Q                                     
039713,000614: 30,3670           34735                           CA       NEGMAX                                #  PI, 2'S COMP
039714,000615: 30,3671           00002                           TC       Q                                     
039715,000616: 

Page 923

039717,000618:                                                                                                  #  SPARCSIN TAKES AN ARGUMENT SCALED UNITY IN A AND RETURNS AN ANGLE SCALED
039718,000619:                                                                                                  #  180 DEGREES IN A.  IT HAS BEEN UNIT TESTED IN THE REGION +-.94 (+-70
039719,000620:                                                                                                  #  DEGREES) AND THE MAXIMUM ERROR IS +-5 BITS WITH AN AVERAGE TIME OF
039720,000621:                                                                                                  #  450 MICROSECONDS.  SPARCSIN -1 TAKES THE ARGUMENT SCALED TWO.  (BOB CRISP)
039721,000622: 
039722,000623: 30,3672           60000                           DOUBLE                                         
039723,000624: 30,3673           54021        SPARCSIN           TS       SR                                    
039724,000625: 30,3674           13700                           TCF      +4                                    
039725,000626: 30,3675           50000                           INDEX    A                                     
039726,000627: 30,3676           44734                           CS       LIMITS                                
039727,000628: 30,3677           54021                           TS       SR                                    
039728,000629: 30,3700           00006                           EXTEND                                         
039729,000630: 30,3701           70000                           MP       A                                     
039730,000631: 30,3702           54141                           TS       TEM1                                  
039731,000632: 30,3703           00006                           EXTEND                                         
039732,000633: 30,3704           73726                           MP       DPL9                                  
039733,000634: 30,3705           63725                           AD       DPL7                                  
039734,000635: 30,3706           00006                           EXTEND                                         
039735,000636: 30,3707           70141                           MP       TEM1                                  
039736,000637: 30,3710           63724                           AD       DPL5                                  
039737,000638: 30,3711           00006                           EXTEND                                         
039738,000639: 30,3712           70141                           MP       TEM1                                  
039739,000640: 30,3713           63723                           AD       DPL3                                  
039740,000641: 30,3714           00006                           EXTEND                                         
039741,000642: 30,3715           70141                           MP       TEM1                                  
039742,000643: 30,3716           63722                           AD       DPL1                                  
039743,000644: 30,3717           00006                           EXTEND                                         
039744,000645: 30,3720           70021                           MP       SR                                    
039745,000646: 30,3721           00002                           TC       Q                                     
039746,000647: 30,3722           24406        DPL1               DEC      10502      B-14                       
039747,000648: 30,3723           00660        DPL3               DEC      432        B-14                       
039748,000649: 30,3724           16204        DPL5               DEC      7300       B-14                       
039749,000650: 30,3725           50744        DPL7               DEC      -11803     B-14                       
039750,000651: 30,3726           20315        DPL9               DEC      8397       B-14                       
039751,000652: 

Page 924

039753,000654:                                                                                                  #  LIMITSUB LIMITS THE MAGNITUDE OF THE POSITIVE OR NEGATIVE VARIABLE
039754,000655:                                                                                                  #  ARRIVING IN L TO THE POSITIVE LIMIT ARRIVING IN A.
039755,000656:                                                                                                  #  THE SIGNED LIMITED VARIABLE IS RETURNED IN A.
039756,000657: 
039757,000658:                                                                                                  #  VERSION COURTESY HUGH BLAIR-SMITH
039758,000659: 
039759,000660: 30,3727           54141        LIMITSUB           TS       TEM1                                  
039760,000661: 30,3730           34755                           CA       ZERO                                  
039761,000662: 30,3731           00006                           EXTEND                                         
039762,000663: 30,3732           10141                           DV       TEM1                                  
039763,000664: 30,3733           10000                           CCS      A                                     
039764,000665: 30,3734           22141                           LXCH     TEM1                                  
039765,000666: 30,3735           13737                           TCF      +2                                    
039766,000667: 30,3736           13741                           TCF      +3                                    
039767,000668: 30,3737           30001                           CA       L                                     
039768,000669: 30,3740           00002                           TC       Q                                     
039769,000670: 30,3741           40141                           CS       TEM1                                  
039770,000671: 30,3742           00002                           TC       Q                                     
039771,000672: 
039772,000673:                                                                                                  #  SUBROUTINE TO CONVERT 1'S COMP SP TO 2'S COMP
039773,000674: 
039774,000675: 30,3743           10000        ONESTO2S           CCS      A                                     
039775,000676: 30,3744           64753                           AD       ONE                                   
039776,000677: 30,3745           00002                           TC       Q                                     
039777,000678: 30,3746           40000                           CS       A                                     
039778,000679: 30,3747           00002                           TC       Q                                     
039779,000680: 
039780,000681:                                                                                                  #  NO ATTITUDE CONTROL
039781,000682: 
039782,000683: 30,3750           05567        NOATTCNT           TC       ALARM                                 
039783,000684: 30,3751           00402                           OCT      00402                                 #  NO ATTITUDE CONTROL
039784,000685: 
039785,000686: 30,3752           00004                 +2        INHINT                                         #  COME HERE FOR NOATTCNT WITHOUT ALARM
039786,000687: 30,3753           04674                           TC       IBNKCALL                              #  RELINT AT TC INTPRET AFTER TCQCDUW
039787,000688: 30,3754           40165                           FCADR    STOPRATE                              
039788,000689: 30,3755           13475                           TCF      TCQCDUW                               #  RETURN TO USER SKIPPING AUTOPILOT CMDS
039789,000690: 
039790,000691:                                                                                                  #  MIDDLE GIMBAL ANGLE ALARM
039791,000692: 
039792,000693: 30,3756           05567        ALARMMGA           TC       ALARM                                 
039793,000694: 30,3757           00401                           OCT      00401                                 
039794,000695: 30,3760           13275                           TCF      MGARET                                
039795,000696: 

Page 925

039797,000698:                                                                                                  # ************************************************************************
039798,000699:                                                                                                  #  CONSTANTS
039799,000700:                                                                                                  # ************************************************************************
039800,000701: 
039801,000702:                                                                                                  #  ADDRESS CONSTANTS
039802,000703: 
039803,000704: 30,3761           03246        ECDUWL             ECADR    ECDUW                                 
039804,000705: 
039805,000706:                                                                                                  #  THRUST DIRECTION FILTER CONSTANTS
039806,000707: 
039807,000708: 30,3762           06315        GAINFLTR           DEC      .2                                    #  GAIN FILTER SANS CSM
039808,000709: 30,3763           03146                           DEC      .1                                    #  GAIN FILTER WITH CSM
039809,000710: 
039810,000711: 30,3764           00071        DUNFVLIM           DEC      .007       B-1                        #  7 MR MAX CHG IN F DIR IN VEH IN 2 SECS.
039811,000712:                                                                                                  #  THIS DOES NOT ALLOW FOR S/C ROT RATE.
039812,000713: 
039813,000714: 30,3765           02041        UNFVLIM            DEC      .129       B-1                        #  129 MR MAX THRUST OFFSET.  105 MR TRAVEL
039814,000715:                                                                                                  #  +10MR DEFL+5MR MECH MOUNT+9MR ABLATION.
039815,000716: 
039816,000717:                                                                                                  #  CONSTANTS RELATED TO GIMBAL ANGLE COMPUTATIONS
039817,000718: 
039818,000719: 30,3766           01673        DOTSWFMX           DEC      .93302     B-4                        #  LIM COLNRTY OF UNWC/2 & UNFC/2 TO 85 DEG
039819,000720:                                                                                                  #  LOWER PART COMES FROM NEXT CONSTANT
039820,000721: 
039821,000722: 30,3767           03434        DAXMAX             DEC      .11111111111                            #  DELATTX LIM TO 20 DEG IN 2 SECS, 1'S, PI
039822,000723: 30,3770           00266                           DEC      .0111111111                            #  2 DEG WHEN CSM DOCKED
039823,000724: 
039824,000725: 30,3771           01616        DAY/2MAX           DEC      .05555555555                            #  LIKEWISE FOR DELATTY
039825,000726: 30,3772           00133                           DEC      .0055555555                            
039826,000727: 
039827,000728: 30,3773  30,3767               DAZMAX             =        DAXMAX                                #  LIKEWISE FOR DELATTZ
039828,000729: 
039829,000730: 30,3773           14344        CDUZDLIM           DEC      .3888888888                            #  70 DEG LIMIT FOR MGA, 1'S, PI
039830,000731: 
039831,000732:                                                                                                  #  CONSTANTS FOR DATA TRANSFER
039832,000733: 
039833,000734: 30,3774           01463        DT/DELT            DEC      .05                                   #  .1 SEC/2 SEC WHICH IS THE AUTOPILOT
039834,000735:                                                                                                  #  CONTROL SAMPLE PERIOD/COMPUTATION PERIOD
039835,000736: 
039836,000737: 30,3775  30,3771               DELERLIM           =        DAY/2MAX                              #  10 DEG LIMIT FOR LAG ANGLES, 1'S, PI
039837,000738: 

End of include-file FINDCDUW_-_GUIDAP_INTERFACE.agc.  Parent file is MAIN.agc