Google
 

Trailing-Edge - PDP-10 Archives - AP-D480B-SB_1978 - forplt.mac
There is 1 other file named forplt.mac in the archive. Click here to see a list.
	TITLE AXIS	%5A(631)
	SUBTTL D.TODD	/DRT/MD/CLRH/MEB		16-DEC-76
	SEARCH	FORPRM



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.

;COPYRIGHT (C) 1969,1977 BY DIGITAL EQUIPMENT CORPORATION
;REVISION HISTORY
;----------------
;EDIT	SPR	COMMENT
;----	---	-------
;516	18207	FIX CALLS TO INT TO CALLS TO INT., ETC.
;532	18896	FIX AXIS TO OUTPUT CORRECT SCALE FACTOR
;555	-----	DO NOT USE CHANNEL 17 WITHOUT CALLING ALCHN.
;562	20376	MAKE MKTBL CORRECTLY SET TABLE ADDRESS IN CTBL
;601	Q00688	MAKE STACK SIZE IN PLOT ROUTINES 40 WORDS TO ALLOW
;			ROOM FOR FORERR CALLS
;
;	BEGIN VERSION 5A, 7-NOV-76
;
;623	21441	USE EXP2.. RATHER THAN EXP2.0 SO THAT PLOT
;			ROUTINES WILL LOAD IF FORSIN WAS COMPILED
;			WITH F40LIB TURNED OFF.
;631	21591	SET XMIN PROPERLY IF INT(LOWEST X/DX)=0, AND 
;			SET AN ARBITRARY XMIN AND A DX IF ALL
;			THE VALUES TO BE SCALED ARE EQUAL
;			(THIS AVOIDS DIVIDING BY ZERO).
;632	-----	MODIFICATION TO PLOTS TO ALLOW FOR
;			DIFFERENT STEP SIZE PLOTTER
;*************** END OF REVISION HISTORY *******************
REPEAT 0,<
	THE MACRO CODE LISTED BELOW WAS GENERATED BY THE FORTRA-10
	COMPILER. THE CODE WAS THEN EDITED TO ASSEMBLE WITH MACRO-10
	AND BE SHARABLE WITH BOTH FORTRAN-10 AND F40 COMPILERS.
	THE FORTRAN SOURCE CODE IS INCLUDED AS A REFERENCE.

	SUBROUTINE AXIS (X,Y,BCD,NC,SIZE,THETA,YMIN,DY)
	DIMENSION BCD(2)
	SIGN=1.0
	IF(NC)1,2,2
1	SIGN = -1.0
2	NAC=IABS(NC)
	N=SIZE+.5
	CTH=COSD(THETA)
	STH=SIND(THETA)
	TN=N
	XB=X
	YB=Y
	XA=X-.1*SIGN*STH
	YA=Y+.1*SIGN*CTH
	CALL PLOT(XA,YA,3)
	DO 20 I=1,N
	CALL PLOT(XB,YB,2)
	XC=XB+CTH
	YC=YB+STH
	CALL PLOT(XC,YC,2)
	XA=XA+CTH
	YA=YA+STH
	CALL PLOT(XA,YA,2)
	XB=XC
20	YB=YC
	EXP=0
	NT=INT(ALOG10(DY)+.001)
	IF(NT+1)80,81,81
81	IF(NT-1)93,93,80
80	EXP=NT
93	ADY=DY*10.**(-EXP)
	ABSV=YMIN*10.**(-EXP)+TN*ADY
	XA=XB-(.20*SIGN-.05)*STH-.0857*CTH
	YA=YB+(.20*SIGN-.05)*CTH-.0857*STH
	N=N+1
	DO 30 I=1,N
	CALL NUMBER(XA,YA,.1,ABSV,THETA,3)
	ABSV=ABSV-ADY
	XA=XA-CTH
30	YA=YA-STH
	TNC=NAC+7
	XA=X+(SIZE/2.-.06*TNC)*CTH-(-.07+SIGN*.36)*STH
	YA=Y+(SIZE/2.-.06*TNC)*STH+(-.07+SIGN*.36)*CTH
	CALL SYMBOL(XA,YA,.12,BCD,THETA,NAC)
	XA=XA+((TNC-6.)*.12)*CTH
	YA=YA+((TNC-6.)*.12)*STH
	IF(EXP)35,50,35
35	CALL SYMBOL(XA,YA,.12,7H(X10  ) ,THETA,7)
	XA=XA+.48*CTH-.07*STH
	YA=YA+.48*STH+.07*CTH
	IF(EXP)40,50,40
40	CALL NUMBER(XA,YA,.1,EXP,THETA,-1)
50	RETURN
	END
	SUBROUTINE LINE (X,Y,N,K)
	DIMENSION X(1),Y(1)
	I3=3
	NP=N*K
	DO 10 I=1,NP,K
	CALL PLOT(X(I),Y(I),I3)
10	I3=2
	END
>
	HELLO	(AXIS)
	MOVEM	16,.AXI16
	MOVEM	15,.AXI15	;[323] FOR F40
	MOVE	0,@0(16)
	MOVEM	0,X
	MOVE	0,@1(16)
	MOVEM	0,Y
	MOVEI	0,@2(16)
	MOVEM	0,BCD
	MOVE	0,@3(16)
	MOVEM	0,NC
	MOVE	0,@4(16)
	MOVEM	0,SIZE
	MOVE	0,@5(16)
	MOVEM	0,THETA
	MOVE	0,@6(16)
	MOVEM	0,YMIN
	MOVE	0,@7(16)
	MOVEM	0,DY
	JRST	0,%4M
%3M:
	MOVE	16,.AXI16
	MOVE	15,.AXI15	;[323] RESTORE 15
	POPJ	17,0
%4M:
	MOVSI	15,201400
	MOVEM	15,SIGN
	SKIPL	0,NC
	JRST	0,%2P
%1P:
	MOVSI	15,576400
	MOVEM	15,SIGN
%2P:
	MOVEI	16,%5M
	PUSHJ	17,IABS.##
	MOVEM	0,NAC
	MOVE	15,[177560507534]
	FMPR	15,SIGN
	MOVEM	15,.O0001
	MOVSI	15,200400
	FADR	15,SIZE
IFE CPU-KI10,<
	FIX	15,15
>
IFE CPU-KA10,<
	PUSHJ	17,IFX.15##
>
	MOVEM	15,N
	MOVEI	16,%6M
	PUSHJ	17,COSD.##
	MOVEM	0,CTH
	MOVEI	16,%7M
	PUSHJ	17,SIND.##
	MOVEM	0,STH
IFE CPU-KI10,<
	FLTR	14,N
>
IFE CPU-KA10,<
	MOVE	14,N
	PUSHJ	17,FLT.14##
>
	MOVEM	14,TN
	MOVE	15,X
	MOVEM	15,XB
	MOVE	15,Y
	MOVEM	15,YB
	MOVE	15,[602146314631]
	FMPR	15,SIGN
	FMPR	15,STH
	FADR	15,X
	MOVEM	15,XA
	MOVE	15,[175631463146]
	FMPR	15,SIGN
	FMPR	15,CTH
	FADR	15,Y
	MOVEM	15,YA
	MOVEI	16,%8M
	PUSHJ	17,PLOT##
	MOVN	14,N
	MOVEI	15,1
	MOVEM	14,.S0000
%9M:
	MOVEM	15,I
%10M:
	MOVEI	16,%11M
	PUSHJ	17,PLOT##
	MOVE	13,CTH
	FADR	13,XB
	MOVEM	13,XC
	MOVE	13,STH
	FADR	13,YB
	MOVEM	13,YC
	MOVEI	16,%12M
	PUSHJ	17,PLOT##
	MOVE	13,CTH
	FADR	13,XA
	MOVEM	13,XA
	MOVE	13,STH
	FADR	13,YA
	MOVEM	13,YA
	MOVEI	16,%13M
	PUSHJ	17,PLOT##
	MOVE	13,XC
	MOVEM	13,XB
%20P:
	MOVE	13,YC
	MOVEM	13,YB
	AOS	15,I
	AOSGE	0,.S0000
	JRST	0,%10M
	SETZB	15,.EXP
	MOVEI	16,%14M
	PUSHJ	17,ALG10.##
	FADR	0,[167406111564]
IFE CPU-KI10,<
	FIX	0,0
>
IFE CPU-KA10,<
	PUSHJ	17,IFX.0##
>
	MOVEM	0,NT
	MOVN	15,NT
	CAILE	15,1
	JRST	0,%80P
%81P:
	MOVE	15,NT
	CAIG	15,1
	JRST	0,%93P
%80P:
IFE CPU-KI10,<
	FLTR	14,NT
>
IFE CPU-KA10,<
	MOVE	14,NT
	PUSHJ	17,FLT.14##
>
	MOVEM	14,.EXP
%93P:
	MOVN	15,.EXP
	MOVEM	15,.Q0000
	MOVEI	16,%15M
	PUSHJ	17,EXP3.##
	FMPR	0,DY
	MOVEM	0,ADY
	MOVE	14,TN
	FMPR	14,ADY
	MOVN	15,.EXP
	MOVEM	15,.Q0000
	MOVEI	16,%16M
	PUSHJ	17,EXP3.##
	FMPR	0,YMIN
	FADR	0,14
	MOVEM	0,ABSV
	MOVE	14,[602240762045]
	FMPR	14,CTH
	MOVE	15,[601146314631]
	FMPR	15,SIGN
	FADR	15,[174631463146]
	FMPR	15,STH
	FADR	15,XB
	FADR	15,14
	MOVEM	15,XA
	MOVE	14,[602240762045]
	FMPR	14,STH
	MOVE	15,[176631463146]
	FMPR	15,SIGN
	FADR	15,[603146314631]
	FMPR	15,CTH
	FADR	15,YB
	FADR	15,14
	MOVEM	15,YA
	MOVEI	15,1
	ADD	15,N
	MOVEM	15,N
	MOVN	14,N
	MOVEI	15,1
	MOVEM	14,.S0001
%17M:
	MOVEM	15,I
%18M:
	MOVEI	16,%19M
	PUSHJ	17,NUMBER##
	MOVN	13,ADY
	FADR	13,ABSV
	MOVEM	13,ABSV
	MOVN	13,CTH
	FADR	13,XA
	MOVEM	13,XA
%30P:
	MOVN	13,STH
	FADR	13,YA
	MOVEM	13,YA
	AOS	15,I
	AOSGE	0,.S0001
	JRST	0,%18M
	MOVEI	15,7
	ADD	15,NAC
IFE CPU-KI10,<
	FLTR	15,15
>
IFE CPU-KA10,<
	PUSHJ	17,FLT.15##
>
	MOVEM	15,TNC
	MOVE	15,[603024365605]
	FMPR	15,TNC
	MOVEM	15,.O0000
	MOVSI	15,574200
	FADR	15,TNC
	FMPR	15,[175753412172]
	MOVEM	15,.O0003
	MOVE	14,[175436560507]
	FSBR	14,.O0001
	FMPR	14,STH
	MOVE	15,SIZE
	FSC	15,777777
	FADR	15,.O0000
	FMPR	15,CTH
	FADR	15,X
	FADR	15,14
	MOVEM	15,XA
	MOVE	14,[602341217270]
	FADR	14,.O0001
	FMPR	14,CTH
	MOVE	15,SIZE
	FSC	15,777777
	FADR	15,.O0000
	FMPR	15,STH
	FADR	15,Y
	FADR	15,14
	MOVEM	15,YA
	MOVEI	16,%20M
	PUSHJ	17,SYMBOL##
	MOVE	15,.O0003
	FMPR	15,CTH
	FADR	15,XA
	MOVEM	15,XA
	MOVE	15,.O0003
	FMPR	15,STH
	FADR	15,YA
	MOVEM	15,YA
	SKIPN	0,.EXP
	JRST	0,%50P
%35P:
	MOVEI	16,%21M
	PUSHJ	17,SYMBOL##
	MOVE	14,[602341217270]
	FMPR	14,STH
	MOVE	15,[177753412172]
	FMPR	15,CTH
	FADR	15,XA
	FADR	15,14
	MOVEM	15,XA
	MOVE	14,[175436560507]
	FMPR	14,CTH
	MOVE	15,[177753412172]
	FMPR	15,STH
	FADR	15,YA
	FADR	15,14
	MOVEM	15,YA
	SKIPN	0,.EXP
	JRST	0,%50P
%40P:
	MOVEI	16,%22M
	PUSHJ	17,NUMBER##
%50P:
	JRST	0,%3M

;ARGUMENT BLOCKS:

	0,,0
%2M:	0,,0
	777772,,0
%22M:	200,,XA
	200,,YA
	200,,[175631463146]
	200,,.EXP
	200,,THETA
	0,,[777777777777]
	777772,,0
%21M:	200,,XA
	200,,YA
	200,,[175753412172]
;**; [532] CHANGE @ %21M + 3L	MEB	7-APR-76
	740,,[ASCII /(X10  )/]		;[532] LABEL FOR SCALE
	200,,THETA
	0,,[000000000007]
	777772,,0
%20M:	200,,XA
	200,,YA
	200,,[175753412172]
	220,,BCD
	200,,THETA
	0,,NAC
	777772,,0
%19M:	200,,XA
	200,,YA
	200,,[175631463146]
	200,,ABSV
	200,,THETA
	0,,[000000000003]
	777776,,0
%16M:	200,,[204500000000]
	200,,.Q0000
	777776,,0
%15M:	200,,[204500000000]
	200,,.Q0000
	777777,,0
%14M:	200,,DY
	777775,,0
%13M:	200,,XA
	200,,YA
	0,,[000000000002]
	777775,,0
%12M:	200,,XC
	200,,YC
	0,,[000000000002]
	777775,,0
%11M:	200,,XB
	200,,YB
	0,,[000000000002]
	777775,,0
%8M:	200,,XA
	200,,YA
	0,,[000000000003]
	777777,,0
%7M:	200,,THETA
	777777,,0
%6M:	200,,THETA
	777777,,0
%5M:	0,,NC
ABSV:	BLOCK	1
ADY:	BLOCK	1
BCD:	BLOCK	1
CTH:	BLOCK	1
DY:	BLOCK	1
.EXP:	BLOCK	1
GENERA:	BLOCK	1
I:	BLOCK	1
LABEL:	BLOCK	1
N:	BLOCK	1
NAC:	BLOCK	1
NC:	BLOCK	1
NT:	BLOCK	1
SIGN:	BLOCK	1
SIZE:	BLOCK	1
STH:	BLOCK	1
THETA:	BLOCK	1
TN:	BLOCK	1
TNC:	BLOCK	1
X:	BLOCK	1
XA:	BLOCK	1
XB:	BLOCK	1
XC:	BLOCK	1
Y:	BLOCK	1
YA:	BLOCK	1
YB:	BLOCK	1
YC:	BLOCK	1
YMIN:	BLOCK	1
.AXI16:	BLOCK	1
.AXI15:	BLOCK	1	;[323] TO SAVE REG 15
.O0000:	BLOCK	1
.O0001:	BLOCK	1
.O0003:	BLOCK	1
.Q0000:	BLOCK	1
.S0000:	BLOCK	1
.S0001:	BLOCK	1


	PRGEND
	TITLE	LINE	%4.(323)
	SUBTTL	D.TODD	/DRT/MD		04-JUN-1974
;REVISION HISTORY
;----------------
;EDIT	SPR	COMMENT
;----	---	-------
;323	(13373)	SAVE REGISTER 15 (FOR F40 COMPATIBILITY)
;
	SEARCH	FORPRM
	HELLO	(LINE)
	MOVEM	16,.LIN16
	MOVEM	15,.LIN15	;[323] SAVE 15
	MOVEI	0,@0(16)
	MOVEM	0,X
	MOVEI	0,@1(16)
	MOVEM	0,Y
	MOVE	0,@2(16)
	MOVEM	0,N
	MOVE	0,@3(16)
	MOVEM	0,K
	JRST	0,%4M
%3M:
	MOVE	16,.LIN16
	MOVE	15,.LIN15	;[323] RESTORE 15
	POPJ	17,0
%4M:
	MOVEI	15,3
	MOVEM	15,I3
	MOVE	15,N
	IMUL	15,K
	MOVEM	15,NP
	MOVEI	13,1
	SUB	13,NP
	IDIV	13,K
	SUBI	13,1
	MOVEI	15,1
	MOVEM	13,.S0000
%5M:
	MOVEM	15,I
%6M:
	MOVE	14,I
	ADD	14,X
	MOVEI	14,777777(14)
	MOVEM	14,.Q0000
	MOVE	14,I
	ADD	14,Y
	MOVEI	14,777777(14)
	MOVEM	14,.Q0001
	MOVEI	16,%7M
	PUSHJ	17,PLOT##
%10P:
	MOVEI	14,2
	MOVEM	14,I3
	MOVE	15,K
	ADDM	15,I
	AOSGE	0,.S0000
	JRST	0,%6M
%1M:
	JRST	0,%3M

;ARGUMENT BLOCKS:

	0,,0
%2M:	0,,0
	777775,,0
%7M:	220,,.Q0000
	220,,.Q0001
	0,,I3
I:	BLOCK	1
I3:	BLOCK	1
K:	BLOCK	1
N:	BLOCK	1
NP:	BLOCK	1
X:	BLOCK	1
Y:	BLOCK	1
.LIN16:	BLOCK	1
.LIN15:	BLOCK	1		;[323] TO SAVE 15
.Q0000:	BLOCK	1
.Q0001:	BLOCK	1
.S0000:	BLOCK	1
	PRGEND
TITLE	SCALE	%5.(631) PLOT SUBPROGRAM
SUBTTL	R CLEMENTS/DMN/HPW/CLRH		16-DEC-76



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.

;COPYRIGHT (C) 1972,1977 BY DIGITAL EQUIPMENT CORPORATION

SUBTTL	REVISION HISORTY

;EDIT	SPR	COMMENTS
;----	---	--------
;243	(12167)	CORRECT SCALE FOR NEGATIVE XMIN
;623	21441	USE EXP2.. RATHER THAN EXP2.0 SO THAT PLOT ROUTINES
;			WILL LOAD IF FORSIN WAS COMPILED WITH F40LIB
;			TURNED OFF.
;631	21591	FIX XMIN WHEN INT(LOWEST X/DX)=0, AND AVOID DIVIDING
;			BY ZERO WHEN ALL THE VALUES TO BE SCALED
;			ARE THE SAME.
;*** END OF REVISION HISTORY ***

	P=17	;SYSTEM PDL
	Q=16	;FOR JSA
;	0	FOR TEMPS AND ARGS
;	1	ALSO
	A=2
	X=3
	XMAX=4
	XMIN=5

ENTRY SCALE
SEARCH	FORPRM
	HELLO	(SCALE)		;ENTRY POINT TO SCALE
	MOVEM 5,ACS+5	;SAVE ACS
	MOVEI 5,ACS
	BLT 5,ACS+4
	MOVEI	X,@0(Q)		;[221] LOAD ARRAY ADDRESS
	HRLI X,A	;FOR INDEXING INTO X
	MOVEI A,0
	MOVE XMAX,@X
	MOVE XMIN,@X	;INITIAL VALUES=X(1)
L1:	CAMGE XMAX,@X
	MOVE XMAX,@X
	CAMLE XMIN,@X
	MOVE XMIN,@X
	ADDI A,1
	CAMGE A,@1(Q)	;ARRAY LENGTH
	JRST L1

;**; [631] INSERT @ L1+6 1/2	CLRH	16-DEC-76
	CAMN	XMIN,XMAX	;[631] ALL VALUES WERE THE SAME?
	JRST	[SKIPN	XMAX		;[631] YES, WERE THEY ALL ZERO?
		MOVE	XMAX,[10.0]	;[631] ARBITRARILY SET A MAX.
		FMPR	XMAX,[2.0]	;[631] DOUBLE VALUE FOR MAX
		MOVEI	XMIN,0		;[631] AND ZERO FOR MIN
		SKIPGE	XMAX		;[631] UNLESS VALUE WAS NEG.
		EXCH	XMIN,XMAX	;[631] SWITCH VALUES IF NEG.
		JRST	.+1	]	;[631] AND CONTINUE
	MOVE A,XMAX
	FSBR A,XMIN
	FMPR A,[10.0]
	FDVR A,@2(Q)	;LENGTH OF LINE
	FADR A,XMIN
	MOVEM A,XMAX
	FSBR A,XMIN
	MOVMS A
	MOVEM A,D
	FUNCT	ALG10.,<D>	; [516]
	MULI	0,400		;USE OLD NON-SYMETRIC FIX ROUTINE
	TSC	0,0		;CODED IN LINE TO SAVE TIME
	EXCH	0,1
	ASH	0,-243(1)
	MOVEM 0,IE
	MOVSI 0,(10.0)
	MOVE 1,IE
;**; [623] CHANGE @ L1+24(10)L IN SCALE	CLRH	18-NOV-76
	PUSHJ P,EXP2..##	;[623] DO NOT USE F40 CALL
	MOVE 1,D
	FDVR 1,0
	CAMLE 1,[8.0]
	JRST P2P
	CAMG 1,[8.0]
	MOVSI 0,(8.0)
	CAMG 1,[5.0]
	MOVSI 0,(5.0)
	CAMG 1,[4.0]
	MOVSI 0,(4.0)
	CAMG 1,[2.0]
	MOVSI 0,(2.0)
	CAMG 1,[1.0]
	MOVSI 0,(1.0)
	JRST P1P
P2P:	MOVSI 0,(1.0)
	AOS IE
P1P:	MOVEM 0,S
	MOVE 1,IE
	SUBI 1,1
	MOVSI 0,(10.0)
;**; [623] CHANGE @ P1P+4L IN SCALE	CLRH	18-NOV-76
	PUSHJ P,EXP2..##	;[623] DO NOT USE F40 CALL
	MOVEM 0,E1
	FMPR 0,S
	MOVEM 0,D
	MOVEM 0,@4(Q)	;RETURN DX TO CALLER
	MOVE A,XMIN
	FDVR A,D
	MOVEM	A,XMAX		;[243] REMEMBER SCALED VALUED
	FUNCT	INT.,<A>	; [516]
	MOVEM 0,A
	FUNCT FLOAT.,<A>	; [516]
;**; [631] CHANGE @ P3P-3L	CLRH	16-DEC-76
	JUMPGE	P3P		;[631] [243] WAS XMIN/DX NEGATIVE
	CAME	XMAX		;[243] AND NON INTEGRAL
	FSBRI	(1.0)		;[243] YES - CORRECT SCALING
P3P:	FMPR	0,D		;[243] CONVERT TO *DX UNITS
	MOVEM 0,XMIN
	MOVEI A,0
L2:	MOVE 0,@X
	FSBR 0,XMIN
	FDVR 0,D
	MOVEM 0,@X
	ADDI A,1
	CAMGE A,@1(Q)
	JRST L2

	MOVEM XMIN,@3(Q)	;RETURN XMIN
	MOVSI 5,ACS
	BLT 5,5
	GOODBY	(5)		;SCALE RETURN

ACS:	BLOCK 6

IE:	0
E1:	0
S:	0
D:	0

	LIT
	PRGEND
	TITLE	PLOTF (FEANORIAN CHARACTER SET) %4,(100)
	SUBTTL	BILL WEIHER: STANFORD A-I; 21 OCT 67



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.

;COPYRIGHT (C) 1972,1977 BY DIGITAL EQUIPMENT CORPORATION
	ENTRY	PLOTF

PLOTF:	REPEAT 40,<XWD 0,0>
	XWD 1,SP
	XWD 5,LCR
	XWD 3,UDOT
	XWD 7,SCR
	XWD 21,OFTHE
	XWD 14,FQA
	REPEAT 4,<XWD 0,0>
	XWD 17,OF
	XWD 11,FHW
	XWD 11,F12
	XWD 3,OVBR
	XWD 11,F11
	XWD 17,THE
	XWD 12,F0
	XWD 11,FTH
	XWD 11,FSH
	XWD 12,FKH
	XWD 17,FDH
	XWD 17,FZH
	XWD 17,FGH
	XWD 17,F7
	XWD 17,F8
	XWD 11,F9
	XWD 5,FOLY
	XWD 16,MODR
	XWD 13,ALTS
	XWD 0,0
	XWD 25,ALTZ
	XWD 0,0
	XWD 0,0
	XWD 7,FA
	XWD 16,FB
	XWD 11,FC
	XWD 16,FD
	XWD 3,FE
	XWD 12,FF
	XWD 16,FG
	XWD 6,FH
	XWD 3,FI
	XWD 17,FJ
	XWD 11,FK
	XWD 10,FL
	XWD 17,FM
	XWD 17,FN
	XWD 12,FO
	XWD 11,FP
	XWD 14,FQ
	XWD 14,FR
	XWD 13,FS
	XWD 10,FT
	XWD 12,FU
	XWD 17,FV
	XWD 12,FW
	XWD 11,FX
	XWD 7,FY
	XWD 25,FZ
	REPEAT 46,<XWD 0,0>
RADIX 10
FSH:	BYTE (5) 0,2,15,1,0,13,1,0,8,1,2,6,1,4,6,1,6,8,0,6,21
	BYTE (5) 1,6,6,0,11,6
FKH:	BYTE (5) 0,0,13,1,0,8,1,2,6,1,4,6,1,6,8,0,0,13,1,6,13
	BYTE (5) 0,6,21,1,6,6,0,11,6
FDH:	BYTE (5) 0,0,21,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 1,4,4,0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,1,10,4
	BYTE (5) 0,17,6
FV:	BYTE (5) 0,0,21,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,0,0,6,1,13,6
	BYTE (5) 0,17,6
FZH:	BYTE (5) 0,2,15,1,0,13,1,0,8,1,2,6,1,4,6,1,6,8,1,6,13
	BYTE (5) 1,8,15,0,6,8,1,8,6,1,10,6,1,12,8,0,12,21,1,12,6
	BYTE (5) 0,17,6
FGH:	BYTE (5) 0,0,13,1,0,8,1,2,6,1,4,6,1,6,8,1,6,13,0,6,8
	BYTE (5) 1,8,6,1,10,6,1,12,8,0,0,13,1,12,13,0,12,21,1,12,6
	BYTE (5) 0,17,6
F9:	BYTE (5) 0,0,13,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 1,4,4,0,11,6
F0:	BYTE (5) 0,0,13,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 0,0,6,1,7,6,0,11,6
FT:	BYTE (5) 0,0,0,1,0,11,1,2,13,1,4,13,1,6,11,1,6,6,1,4,4
	BYTE (5) 0,11,6
FP:	BYTE (5) 0,0,0,1,0,11,1,2,13,1,4,13,1,6,11,1,6,6,0,0,6
	BYTE (5) 1,7,6,0,11,6
FC:	BYTE (5) 0,2,15,1,0,13,1,0,8,1,2,6,1,4,6,1,6,8,0,6,15
	BYTE (5) 1,6,0,0,11,6
FK:	BYTE (5) 0,0,13,1,0,8,1,2,6,1,4,6,1,6,8,0,0,13,1,6,13
	BYTE (5) 1,6,0,0,11,6
FD:	BYTE (5) 0,0,0,1,0,11,1,2,13,1,4,13,1,6,11,1,6,6,1,4,4
	BYTE (5) 0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,1,10,4,0,17,6
FB:	BYTE (5) 0,0,0,1,0,11,1,2,13,1,4,13,1,6,11,1,6,6,0,6,11
	BYTE (5) 1,8,13,1,10,13,1,12,11,1,12,6,0,0,6,1,13,6,0,17,6
FJ:	BYTE (5) 0,2,15,1,0,13,1,0,8,1,2,6,1,4,6,1,6,8,1,6,13
	BYTE (5) 1,8,15,0,6,8,1,8,6,1,10,6,1,12,8,0,12,15,1,12,0
	BYTE (5) 0,17,6
FG:	BYTE (5) 0,0,13,1,0,8,1,2,6,1,4,6,1,6,8,1,6,13,0,6,8
	BYTE (5) 1,8,6,1,10,6,1,12,8,0,0,13,1,12,13,1,12,0,0,17,6
FTH:	BYTE (5) 0,0,21,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 1,4,4,0,11,6
FF:	BYTE (5) 0,0,21,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 0,0,6,1,7,6,0,11,6
ALTS:	BYTE (5) 0,4,15,1,0,11,1,0,8,1,2,6,1,4,6,1,6,8,1,6,10
	BYTE (5) 1,4,12,1,3,12,1,2,11,0,11,6
FS:	BYTE (5) 0,4,7,1,3,6,1,2,6,1,0,8,1,0,10,1,2,12,1,4,12
	BYTE (5) 1,6,10,1,6,7,1,2,3,0,11,6
ALTZ:	BYTE (5) 0,4,16,1,0,12,1,0,9,1,2,7,1,4,7,1,6,9,1,6,11
	BYTE (5) 1,4,13,1,3,13,1,2,12,0,2,7,1,0,5,1,0,2,1,2,0
	BYTE (5) 1,4,0,1,6,2,1,6,4,1,4,6,1,3,6,1,2,5,0,11,6
FZ:	BYTE (5) 0,2,0,1,6,4,1,6,7,1,4,9,1,2,9,1,0,7,1,0,5
	BYTE (5) 1,2,3,1,3,3,1,4,4,0,4,9,1,6,11,1,6,14,1,4,16
	BYTE (5) 1,2,16,1,0,14,1,0,12,1,2,10,1,3,10,1,4,11,0,11,6
FU:	BYTE (5) 0,0,16,1,3,19,1,4,19,1,5,18,1,5,17,1,4,16,1,3,16
	BYTE (5) 1,2,17,1,2,18,0,0,6
FO:	BYTE (5) 0,3,18,1,3,17,1,2,16,1,1,16,1,0,17,1,0,18,1,1,19
	BYTE (5) 1,2,19,1,5,16,0,0,6
FI:	BYTE (5) 0,3,16,1,3,18,0,0,6
FE:	BYTE (5) 0,2,16,1,5,19,0,0,6
FA:	BYTE (5) 0,1,16,1,1,18,0,3,18,1,3,20,0,5,16,1,5,18,0,0,6
FOLY:	BYTE (5) 0,2,16,1,2,18,0,4,16,1,4,18,0,0,6
OVBR:	BYTE (5) 0,1,16,1,5,16,0,0,6
OF:	BYTE (5) 0,0,21,1,0,0,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,0,0,6,1,13,6
	BYTE (5) 0,17,6
OFTHE:	BYTE (5) 0,0,21,1,0,0,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,0,0,6,1,13,6
	BYTE (5) 0,0,3,1,6,3,0,17,6
THE:	BYTE (5) 0,0,21,1,0,0,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 1,4,4,0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,1,10,4
	BYTE (5) 0,17,6
SCR:	BYTE (5) 0,7,12,1,2,12,1,0,10,1,0,6,1,2,4,1,7,4,0,12,6
UDOT:	BYTE (5) 0,5,2,1,5,0,0,0,6
LCR:	BYTE (5) 0,5,12,1,5,4,1,2,1,1,0,1,0,11,6
FW:	BYTE (5) 0,0,8,1,2,6,1,4,6,1,6,8,1,6,10,1,4,12,1,2,12
	BYTE (5) 1,0,10,1,0,8,0,11,6
FR:	BYTE (5) 0,0,11,1,5,6,0,4,13,1,6,15,1,8,15,1,10,13,1,10,11
	BYTE (5) 1,2,3,1,2,1,1,3,0,1,5,0,0,15,6
MODR:	BYTE (5) 0,0,11,1,5,6,0,4,13,1,6,15,1,8,15,1,10,13,1,10,11
	BYTE (5) 1,2,3,1,2,1,1,3,0,1,5,0,0,4,8,1,1,5,0,15,6
FH:	BYTE (5) 0,0,15,1,9,6,1,11,6,0,5,10,1,1,6,0,17,6
FY:	BYTE (5) 0,1,12,1,3,12,1,9,6,1,11,6,0,5,10,1,1,6,0,17,6
FL:	BYTE (5) 0,0,11,1,12,11,0,6,11,1,3,8,1,3,4,1,6,1,1,9,1
	BYTE (5) 0,17,6
FX:	BYTE (5) 0,0,11,1,9,11,0,5,11,1,3,9,1,3,7,1,5,5,1,5,3
	BYTE (5) 1,3,1,0,14,6
F11:	BYTE (5) 0,2,15,1,0,13,1,0,8,1,2,6,1,4,6,1,6,8,0,6,15
	BYTE (5) 1,6,6,0,11,6
F12:	BYTE (5) 0,0,13,1,0,8,1,2,6,1,4,6,1,6,8,0,0,13,1,6,13
	BYTE (5)  1,6,6,0,11,6
FN:	BYTE (5) 0,0,13,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 1,4,4,0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,1,10,4
	BYTE (5) 0,17,6
FM:	BYTE (5) 0,0,13,1,0,6,0,0,11,1,2,13,1,4,13,1,6,11,1,6,6
	BYTE (5) 0,6,11,1,8,13,1,10,13,1,12,11,1,12,6,0,0,6,1,13,6
	BYTE (5) 0,17,6
F7:	BYTE (5) 0,2,15,1,0,13,1,0,8,1,2,6,1,4,6,1,6,8,1,6,13
	BYTE (5) 1,8,15,0,6,8,1,8,6,1,10,6,1,12,8,0,12,15,1,12,6
	BYTE (5) 0,17,6
F8:	BYTE (5) 0,0,13,1,0,8,1,2,6,1,4,6,1,6,8,1,6,13,0,6,8
	BYTE (5) 1,8,6,1,10,6,1,12,8,0,0,13,1,12,13,1,12,6,0,17,6
SP:	BYTE (5) 0,17,6
FHW:	BYTE (5) 0,6,18,1,6,6,0,6,12,1,2,12,1,0,10,1,0,8,1,2,6
	BYTE (5) 1,9,6,0,14,6
FQ:	BYTE (5) 0,0,16,1,2,18,0,2,16,1,2,20,1,3,21,1,4,21,1,5,20
	BYTE (5) 1,5,19,1,4,18,1,3,18,1,2,19,0,0,6
FQA:	BYTE (5) 0,1,16,1,3,18,0,3,16,1,3,20,1,2,21,1,1,21,1,0,20
	BYTE (5) 1,0,19,1,1,18,1,2,18,1,3,19,0,0,6
PRGEND
	TITLE	PLOTC (RUSSIAN CHARACTER SET) %4.(100)
	SUBTTL	BILL WEIHER: STANFORD A-I; 21 OCT 67



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.

;COPYRIGHT (C) 1972,1977 BY DIGITAL EQUIPMENT CORPORATION
ENTRY PLOTC
RADIX 10
T21:	BYTE (5) 1,0,12,1,2,14,1,4,14,1,6,12,1,6,6,0,6,9,1,0,9
	BYTE (5) 0,8,6
T22:	BYTE (5) 1,0,14,1,4,14,0,0,10,1,3,10,1,4,9,1,4,7,1,3,6
	BYTE (5) 1,0,6,0,8,6
T23:	BYTE (5) 1,0,14,1,5,14,1,6,13,1,6,11,1,5,10,1,0,10,0,5,10
	BYTE (5) 1,6,9,1,6,7,1,5,6,1,0,6,0,8,6
T24:	BYTE (5) 1,0,14,1,5,14,1,5,12,0,8,6
T25:	BYTE (5) 1,0,7,1,2,9,1,2,14,1,6,14,1,6,6,1,6,7,1,0,7
	BYTE (5) 0,8,6
T26:	BYTE (5) 1,0,14,1,6,14,0,4,10,1,0,10,0,0,6,1,6,6,0,8,6
T27:	BYTE (5) 1,0,14,1,6,14,0,4,10,1,0,10,0,0,6,1,6,6,0,2,15
	BYTE (5) 1,2,16,0,4,16,1,4,15,0,8,6
T210:	BYTE (5) 1,4,10,1,0,14,0,4,10,1,7,10,1,11,14,0,5,14,1,5,6
	BYTE (5) 0,11,6,1,7,10,0,13,6
T211:	BYTE (5) 0,0,7,1,1,6,1,3,6,1,4,7,1,4,9,1,3,10,1,2,10
	BYTE (5) 1,3,10,1,4,11,1,4,13,1,3,14,1,1,14,1,0,13,0,8,6
T212:	BYTE (5) 0,0,14,1,0,6,1,0,7,1,6,13,1,6,14,1,6,6,0,8,6
T214:	BYTE (5) 0,1,6,1,1,14,0,1,10,1,5,14,0,1,10,1,5,6,0,8,6
T215:	BYTE (5) 1,1,6,1,2,7,1,2,14,1,6,14,1,6,6,0,8,6
T216:	BYTE (5) 1,0,14,1,3,11,1,6,14,1,6,6,0,8,6
T217:	BYTE (5) 1,0,14,0,0,10,1,6,10,0,6,14,1,6,6,0,8,6
T220:	BYTE (5) 0,0,8,1,0,12,1,2,14,1,4,14,1,6,12,1,6,8,1,4,6
	BYTE (5) 1,2,6,1,0,8,0,8,6
T221:	BYTE (5) 1,0,14,1,6,14,1,6,6,0,8,6
T222:	BYTE (5) 1,0,14,1,5,14,1,6,13,1,6,11,1,5,10,1,0,10,0,8,6
T223:	BYTE (5) 0,6,13,1,5,14,1,2,14,1,0,12,1,0,8,1,2,6,1,5,6
	BYTE (5) 1,6,7,0,8,6
T224:	BYTE (5) 0,3,6,1,3,14,0,0,14,1,6,14,0,8,6
T225:	BYTE (5) 0,0,14,1,3,11,1,6,14,0,3,11,1,3,6,0,8,6
T226:	BYTE (5) 0,0,9,1,0,11,1,2,13,1,4,13,1,6,11,1,6,9,1,4,7
	BYTE (5) 1,2,7,1,0,9,0,3,14,1,3,6,0,8,6
T227:	BYTE (5) 1,6,12,0,0,12,1,6,6,0,8,6
T230:	BYTE (5) 0,0,14,1,0,6,1,3,6,1,3,14,0,3,6,1,4,5,0,8,6
T231:	BYTE (5) 0,0,14,1,0,12,1,1,11,1,4,11,0,4,14,1,4,6,0,8,6
T232:	BYTE (5) 0,0,14,1,0,6,1,3,6,1,3,14,0,3,6,1,6,6,1,6,14
	BYTE (5) 0,8,6
T233:	BYTE (5) 0,0,14,1,0,6,1,3,6,1,3,14,0,3,6,1,6,6,1,6,14
	BYTE (5) 0,6,6,1,7,5,0,9,6
T237:	BYTE (5) 0,0,13,1,1,14,1,4,14,1,6,12,1,6,8,1,4,6,1,1,6
	BYTE (5) 1,0,7,0,6,10,1,3,10,0,8,6
T240:	BYTE (5) 1,0,14,0,0,10,1,2,10,1,2,13,1,3,14,1,5,14,1,6,13
	BYTE (5) 1,6,7,1,5,6,1,3,6,1,2,7,1,2,10,0,8,6
T241:	BYTE (5) 0,6,6,1,6,14,1,1,14,1,0,13,1,0,11,1,1,10,1,6,10
	BYTE (5) 0,4,10,1,0,6,0,8,6
T2101:	BYTE (5) 0,0,9,1,1,10,1,3,10,1,4,9,1,4,6,0,4,8,1,3,9
	BYTE (5) 1,1,9,1,0,8,1,0,7,1,1,6,1,3,6,1,4,7,0,8,6
T2102:	BYTE (5) 0,0,8,1,1,9,1,3,9,1,4,8,1,4,7,1,3,6,1,1,6
	BYTE (5) 1,0,7,1,0,10,1,2,12,1,3,12,1,4,11,0,8,6
T2103:	BYTE (5) 1,0,10,1,3,10,1,4,9,1,3,8,1,0,8,0,3,8,1,4,7
	BYTE (5) 1,3,6,1,0,6,0,8,6
T2104:	BYTE (5) 1,0,10,1,3,10,1,3,9,0,8,6
T2105:	BYTE (5) 1,0,7,1,1,8,1,1,10,1,4,10,1,4,6,1,4,7,1,0,7
	BYTE (5) 0,8,6
T2106:	BYTE (5) 0,0,8,1,4,8,1,4,9,1,3,10,1,1,10,1,0,9,1,0,7
	BYTE (5) 1,1,6,1,3,6,1,4,7,0,8,6
T2107:	BYTE (5) 0,0,8,1,4,8,1,4,9,1,3,10,1,1,10,1,0,9,1,0,7
	BYTE (5) 1,1,6,1,3,6,1,4,7,0,1,11,1,1,12,0,3,12,1,3,11
	BYTE (5) 0,8,6
T2110:	BYTE (5) 1,2,8,1,0,10,0,3,10,1,3,6,0,6,6,1,4,8,1,6,10
	BYTE (5) 0,2,8,1,4,8,0,8,6
T2111:	BYTE (5) 0,0,9,1,1,10,1,3,10,1,4,9,1,3,8,1,2,8,0,3,8
	BYTE (5) 1,4,7,1,3,6,1,1,6,1,0,7,0,8,6
T2112:	BYTE (5) 0,0,10,1,0,6,1,4,10,1,4,6,0,8,6
T2113:	BYTE (5) 0,0,10,1,0,6,1,4,10,1,4,6,0,1,12,1,2,11,1,3,12
	BYTE (5) 0,8,6
T2114:	BYTE (5) 1,0,10,0,2,10,1,0,8,1,2,6,0,8,6
T2115:	BYTE (5) 1,1,6,1,2,7,1,2,10,1,4,10,1,4,6,0,8,6
T2116:	BYTE (5) 1,0,10,1,2,8,1,4,10,1,4,6,0,8,6
T2117:	BYTE (5) 1,0,10,0,4,10,1,4,6,0,4,8,1,0,8,0,8,6
T2120:	BYTE (5) 0,0,7,1,0,9,1,1,10,1,3,10,1,4,9,1,4,7,1,3,6
	BYTE (5) 1,1,6,1,0,7,0,8,6
T2121:	BYTE (5) 1,0,10,1,4,10,1,4,6,0,8,6
T2122:	BYTE (5) 1,0,9,1,1,10,1,3,10,1,4,9,1,4,7,1,3,6,1,1,6
	BYTE (5) 1,0,7,1,0,4,0,8,6
T2123:	BYTE (5) 0,4,9,1,3,10,1,1,10,1,0,9,1,0,7,1,1,6,1,3,6
	BYTE (5) 1,4,7,0,8,6
T2124:	BYTE (5) 0,0,10,1,4,10,0,2,10,1,2,6,0,8,6
T2125:	BYTE (5) 0,0,9,1,3,6,0,6,9,1,1,4,1,0,4,0,8,6
T2126:	BYTE (5) 0,0,7,1,0,9,1,1,10,1,3,10,1,4,9,1,4,7,1,3,6
	BYTE (5) 1,1,6,1,0,7,0,2,11,1,2,5,0,8,6
T2127:	BYTE (5) 1,4,10,0,0,10,1,4,6,0,8,6
T2130:	BYTE (5) 0,0,10,1,0,6,1,2,6,1,2,10,0,2,6,1,3,5,0,8,6
T2131:	BYTE (5) 0,0,10,1,0,9,1,1,8,1,3,8,0,3,10,1,3,6,0,8,6
T2132:	BYTE (5) 0,0,10,1,0,6,1,2,6,1,2,10,0,2,6,1,4,6,1,4,10
	BYTE (5) 0,8,6
T2133:	BYTE (5) 0,0,10,1,0,6,1,2,6,1,2,10,0,2,6,1,4,6,1,4,10
	BYTE (5) 0,4,6,1,5,5,0,8,6
T2134:	BYTE (5) 0,0,10,1,0,11,1,2,11,1,2,6,1,3,6,1,4,7,1,4,8
	BYTE (5) 1,3,9,1,2,9,0,8,6
T2135:	BYTE (5) 0,0,11,1,0,6,1,1,6,1,2,7,1,2,8,1,1,9,1,0,9
	BYTE (5) 0,3,6,1,3,11,0,8,6
T2136:	BYTE (5) 0,0,11,1,0,6,1,1,6,1,2,7,1,2,8,1,1,9,1,0,9
	BYTE (5) 0,8,6
T2137:	BYTE (5) 0,0,7,1,1,6,1,3,6,1,4,7,1,4,9,1,3,10,1,1,10
	BYTE (5) 1,0,9,0,4,8,1,2,8,0,8,6
T2140:	BYTE (5) 1,0,10,0,0,8,1,2,8,1,2,9,1,3,10,1,4,9,1,4,7
	BYTE (5) 1,3,6,1,2,7,1,2,8,0,8,6
T2141:	BYTE (5) 0,4,6,1,4,10,1,1,10,1,0,9,1,1,8,1,4,8,0,2,8
	BYTE (5) 1,0,6,0,8,6
T2142:	BYTE (5) 0,8,6
RADIX 8
PLOTC:	XWD 0,0
	XWD 10,T21
	XWD 11,T22
	XWD 14,T23
	XWD 4,T24
	XWD 10,T25
	XWD 7,T26
	XWD 13,T27
	XWD 12,T210
	XWD 16,T211
	XWD 7,T212
	XWD 0,0
	XWD 7,T214
	XWD 6,T215
	XWD 5,T216
	XWD 6,T217
	XWD 12,T220
	XWD 4,T221
	XWD 7,T222
	XWD 11,T223
	XWD 5,T224
	XWD 6,T225
	XWD 14,T226
	XWD 4,T227
	XWD 7,T230
	XWD 7,T231
	XWD 10,T232
	XWD 12,T233
	EXP 0,0,0
	XWD 13,T237
	XWD 15,T240
	XWD 12,T241
	REPEAT 37,<XWD 0,0>
	XWD 16,T2101
	XWD 15,T2102
	XWD 12,T2103
	XWD 4,T2104
	XWD 10,T2105
	XWD 13,T2106
	XWD 17,T2107
	XWD 12,T2110
	XWD 14,T2111
	XWD 5,T2112
	XWD 10,T2113
	XWD 5,T2114
	XWD 6,T2115
	XWD 5,T2116
	XWD 6,T2117
	XWD 12,T2120
	XWD 4,T2121
	XWD 12,T2122
	XWD 11,T2123
	XWD 5,T2124
	XWD 6,T2125
	XWD 14,T2126
	XWD 4,T2127
	XWD 7,T2130
	XWD 7,T2131
	XWD 10,T2132
	XWD 12,T2133
	XWD 12,T2134
	XWD 12,T2135
	XWD 10,T2136
	XWD 13,T2137
	XWD 13,T2140
	XWD 11,T2141
	XWD 1,T2142
	REPEAT 36,<XWD 0,0>
PRGEND
	TITLE	PLOT	%5A(716) PLOT SUBROUTINES
	SUBTTL	D. TODD /DRT/HPW/CLRH/SWG/SJW	14-OCT-77




;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.

;COPYRIGHT (C) 1972,1977 BY DIGITAL EQUIPMENT CORPORATION

;REVISION HISTORY
;632	-----	FIX PLOTS TO ACCEPT OPTIONAL 2ND ARG WHICH IS STEP SIZE
;640	-----	ADD F20LIB SWITCH ON STPSIZ IN PLOTS
;716	23432	AUGMENT EDIT 555 TO USE SAME OUTPUT CHANNEL FOR
;		  MULTIPLE CALLS TO PLOTS

;END REVISION HISTORY

;THIS PACKAGE CONTAINS THE PLOT ROUTINES FOR THE XY10 PLOTTER.
;THE CALLING SEQUENCE IS THAT USED BY FORTRAN IV

;THE CALLS ARE:
;	CALL PLOTS (I)
;	CALL PLOT (X,Y,PEN)
;	CALL SYMBOL (X,Y,SIZE,BCD,THETA,NBCD
;	CALL SETABL (TABLE,ANSWER)
;	CALL MKTBL (TABLENUMBER,ADDRESS)
;	CALL WHERE (X,Y)
;	CALL NUMBER (X,Y,SIZE,FPNUM,THETA,FRACTDIGITS)
;
;	X,Y ARE INCHES FROM ORIGIN, FLT PT
;	SIZE IS CHARACTER HEIGHT, FLT PT, SHOULD BE
;	 A MULTIPLE OF .08" IF SMALL
;
;	THETA IS IN DEGREES, FLT PT.
;	PEN IS
;	3 PEN UP
;	2 PEN DOWN
;	1 PEN UNCHANGED
;	-N = N AND THEN CLEAR X,Y AND OUTPUT

;PLOTTER COMMANDS (USING CALCOMP'S AXIS CONVENTIONS)

	PENUP=40
	PENDWN=20
	MVLFT=10	;-X DRUM UP
	MVRT=4		;+X DRUM DOWN
	MVDWN=1		;-Y CARRIAGE RIGHT
	MVUP=2		;+Y CARRIAGE LEFT

;**; [601] BEFORE AC DEFS IN PLOT	CLRH	24-SEP-76
	PDPSIZ==40		;[601] [555] PUSHDOWN STACK SIZE
;ACCUMULATOR DEFINITIONS

;  0	;TEMP USED BY F4LIB
SC=1	;SCALER IN BRM IN PLOT.
TX=2	;TEMP FOR X IN PLOT.
TY=3	;TEMP FOR Y IN PLOT.
;  4	;CLOBBERED IN PLOT. BY IDIV
CHAR=5	;CHARACTER IN SYMBOL
STROKE=6	;STROKE BYTE POINTER
SCT=7	;STROKE COUNT
XO=10	;ORIGIN OF CHAR IN SYMBOL
YO=11	;ORIGIN OF CHAR IN SYMBOL
TP=12	;BYTE POINTER TO TEXT
TDX=13	;TEMP FOR DAT FOR X IN PLOT.
TDY=14	;TEMP FOR DAT FOR Y IN PLOT.
DAT=15	;ARGUMENT FOR PLT1,TEMP IN SYMBOL
Q=16	;JSA AC
P=17	;PUSHDOWN POINTER

ENTRY PLOTS
SEARCH	FORPRM

	HELLO	(PLOTS)
;**; [555] CHANGE @ PLOTS + 3	CLRH	14-JUN-76
;**; [716] @PLOTS + 3  SJW  14-OCT-77
	DMOVEM	0,SV0		;[716][555] SAVE REGISTERS
	SKIPE	PCHN		;[716] IS PLOTTER ALREADY OPEN ?
	  JRST	PLOTS4		;[716] YES: USE IT AND NOT ANOTHER ONE
	PUSH	P,Q		;[555]
	MOVEI	Q,PLOTS1	;[555] GET ALCHN. PARAMETER BLOCK
	PUSHJ	P,ALCHN.##	;[555] GET A CHANNEL
	POP	P,Q		;[555] RESTORE Q
	JUMPL	0,FOOP		;[555] NO CHANNEL
	LSH	0,5		;[555] MOVE CHANNEL TO CORRECT BITS
	HRLZM	0,PCHN		;[555] AND STORE
	MOVE	1,PCHN		;[555] GET CHANNEL
	TLO	1,(OPEN)	;[555] MAKE OPEN
	HRRI	1,PLOTS3	;[555] GET ARG BLOCK ADDRESS
	XCT	1		;[555] DO OPEN
	JRST	FOOP		;ERROR RETURN
	HLLZS	PFNAM+1
	SETZM	PFNAM+2
	SETZM	PFNAM+3
;**; [555] CHANGE @ PLOTS + 12	CLRH	14-JUN-76
	MOVE	1,PCHN		;[555] GET CHANNEL
	TLO	1,(ENTER)	;[555] MAKE ENTER
	HRRI	1,PFNAM		;[555] GET ENTER ARGS
	XCT	1		;[555] DO THE ENTER
	JRST	FOOP		;CANT ENTER FILE
	SETOM	PEN		;MARK PEN DOWN TO FORCE RAISE
;**; [555] CHANGE @ PLOTS + 15	CLRH	14-JUN-76
	MOVE	1,PCHN		;[555] CHANNEL
	TLO	1,(OUTBUF)	;[555] MAKE OUTBUF
	HRRI	1,2		;[555] PUT IN NUMBER OF BUFFERS
	XCT	1		;[555] DO OUTBUF
	MOVSI	0,600		;IMPROVE PACKING
	HLLM	0,POB+1		;BY CHANGING BYTE SIZE
;**; [716] @PLOTS + 32L  SJW  14-OCT-77
PLOTS4:	MOVE	0,SV0		;[716] RESTORE AC
	SETZM	@0(Q)		;MARK SUCCESS
;**; [632] INSERT AT PLOTS +33	SWG	17-DEC-76
IFN F40LIB <
	TLNN	Q,-1		;[632] F40 CALL?
	JRST	F10C		;[632] NO F10 CALL
	MOVE	T1,1(Q)		;[632] GET 2ND ARG ADDR
	TLC	T1,(<JUMP>)	;[632] IS THE OPCODE OF
	TLNN	T1,777000	;[632] 2ND ARG A JUMP?
	JRST	STPST		;[632] GO CHANGE STEPSIZE
	JRST	RONE		;[632] NO ONLY ONE ARG
>				;[632]
F10C:	HLRE	T1,-1(Q)	;[632] GET ARG COUNT
	MOVNS	T1		;[632] NEGATE IT
	CAIG	T1,1		;[632] MORE THAN ONE ARG?
	JRST	RONE		;[632] NO - CONTINUE AS USUAL
STPST:	MOVE	T1,@1(Q)	;[632] GET SECOND ARG = STEPSIZE
	MOVEM	T1,STPSIZ	;[632] SET STEPSIZE
RONE:	MOVE	1,SV0+1		;[632] RESTORE REG 1
	FUNCT	PLOT,<X,Y,[-3]>	;LIFT PEN
	GOODBY	(1)
;**; [555] INSERT BEFORE FOOP		CLRH	14-JUN-76
	-1,,0			;[555] ALCHN. ARG BLOCK COUNT
PLOTS1:	0,,PLOTS2		;[555] ALCHN. ARG BLOCK
PLOTS2:	0			;[555] ALLOCATE ANY AVAILABLE CHANNEL
PCHN:	0			;[555] STORAGE FOR CHANNEL NUMBER
PLOTS3:	13			;[555] OPEN BLOCK; IMAGE BINARY MODE
	SIXBIT	/PLT/		;[555] PLOTTER
	XWD	POB,0		;[555] OUT HEADER IS  AT POB

FOOP:	SETOM	@0(Q)		;ERROR INDICATION
;**; [555] INSERT@ FOOP + 1/2		CLRH	14-JUN-76
;**; [716] @FOOP + 1  SJW  14-OCT-77
	SETZM	PCHN		;[716] CLEAR CHANNEL NUMBER IF THERE
	DMOVE	0,SV0		;[716][555] RESTORE REGISTERS
	GOODBY	(1)		;RETURN

PFNAM:	SIXBIT	/DATA/		;FILE NAME FOR PLOT FILE
	SIXBIT	/PLT/
	0
	0
	ENTRY	PLOT

	HELLO	(PLOT)		;ENTRY TO PLOT
	MOVEM 17,SV17
	MOVEI 17,ARGS-1
	PUSH 17,@0(Q)	;SVX
	PUSH 17,@1(Q)	;SVY
	PUSH 17,@2(Q)	;SVPEN
	MOVEI 17,SV0
	BLT 17,SV0+16	;SAVE AC'S
	MOVE P,PPDP	;PLOT PUSHDOWN POINTER
	PUSHJ P,PLOT.	;DO WORK
	MOVSI 17,SV0
	BLT 17,17
	GOODBY	(3)	;RETURN TO CALLER

;**; [555] CHANGE @ PLT1	CLRH	14-JUN-76
PLT2:	PUSH	P,1		;[555] GET REGISTER
	MOVE	1,PCHN		;[555] GET CHANNEL NUMBER
	TLO	1,(OUTPUT)	;[555] MAKE OUTPUT UUO
	XCT	1		;[555] DO OUTPUT
	POP	P,1		;[555] RESTORE REGISTER
PLT1:	SOSGE	POB+2		;[555] ROOM IN BUFFER ?
	JRST	PLT2		;[555]  NO,  SO OUTPUT IT
	IDPB	DAT,POB+1
	POPJ	P,0

	ENTRY	PLOT.
PLOT.:
PENCK:	MOVM TX,SVPEN
	CAIG TX,1
	JRST PENOK
	SUBI TX,3
	CAMN TX,PEN
	JRST PENOK
	MOVEI DAT,PENUP
	SKIPGE TX
	MOVEI DAT,PENDWN
	PUSHJ P,PLT1
	MOVEM TX,PEN
PENOK:	MOVE TX,SVX
	FMPR TX,STPSIZ
	FADR TX,[DEC 0.5]
	SKIPGE	SVX
	FSBR	TX,[DEC 1.0]
	FUNCT	INT.,<TX>	; [516]
	MOVEM 0,ISX
	MOVE TX,0
	MOVE TY,SVY
	FMPR TY,STPSIZ
	FADR TY,[DEC 0.5]
	SKIPGE	SVY
	FSBR	TY,[DEC 1.0]
	FUNCT	INT.,<TY>	; [516]
	MOVEM 0,ISY
	MOVE TY,0
	SUB TX,IX
	MOVEI TDX,MVLFT
	SKIPL TX
	MOVEI TDX,MVRT
	SUB TY,IY
	MOVEI TDY,MVDWN
	SKIPL TY
	MOVEI TDY,MVUP
	MOVMS TX
	MOVMS TY
	CAMG TY,TX
	JRST NOSWAP
	EXCH TX,TY
	EXCH TDX,TDY
NOSWAP:	JUMPE TX,ENDOU1	;NO MOTION
	JUMPE TY,NORM
	MOVEI SC,0
NY:	TLNE TY,200000
	JRST NX
	LSH TY,1
	TRO TY,1
	AOJA SC,NY
NX:	SUBI SC,^D34
MKSC:	IDIV TY,TX
	MOVNS SC
	LSH TY,0(SC)
NORM:	MOVEM TY,STEP
	MOVEI TY,0
	IOR TDY,TDX
INLOOP:	ADD TY,STEP
	MOVE DAT,TDX
	TLZE TY,200000
	MOVE DAT,TDY
	PUSHJ P,PLT1
	SOJG TX,INLOOP

	MOVE TY,ISX
	MOVEM TY,IX
	MOVE TY,SVX
	MOVEM TY,X
	MOVE TY,ISY
	MOVEM TY,IY
	MOVE TY,SVY
	MOVEM TY,Y
ENDOU1:	SKIPL SVPEN
	JRST ENDOUT
;**;  [555] CHANGE @ ENDOU1 + 2	CLRH	14-JUN-76
	PUSH	P,1		;[555] SAVE 1
	MOVE	1,PCHN		;[555]  GET CHANNEL
	TLO	1,(OUTPUT)	;[555] MAKE OUTPUT
	XCT	1		;[555]  DO OUTPUT
	POP	P,1		;[555] RESTORE 1
	SETZM X
	SETZM Y
	SETZM IX
	SETZM IY
ENDOUT:	SETZM SVPEN
	POPJ P,0
	ENTRY SYMBOL
	HELLO	(SYMBOL)
	MOVEM	17,SV17
	MOVEI	17,SV0		;[221] LOCATE AC SAVE BLOCK
	BLT	17,SV0+16	;[221] SAVE AC'S
	MOVEI	17,ARGS-1	;[221] LOCATE ARG AREA
	PUSH	17,@0(Q)	;[221] SET SVX
	PUSH	17,@1(Q)	;[221] SET SVY
	MOVEI	17,SVSZ-1	;[221] LOCATE ARG AREA
	PUSH	17,@2(Q)	;[221] SET SVSZ
	MOVEI	@3(Q)		;[221] LOAD TEXT ADDRESS
	PUSH	17,0		;[221] SET SVTXT
	PUSH	17,@4(Q)	;[221] SET SVOR
	PUSH	17,@5(Q)	;[221] SET SVNTXT
	MOVE P,PPDP
	FUNCT	COSD.,<SVOR>	; [516]
	MOVEM 0,COSOR
	FUNCT	SIND.,<SVOR>	; [516]
	MOVEM 0,SINOR
	MOVEI TX,3
	MOVEM TX,SVPEN	;PEN UP
	PUSHJ P,PLOT.	;MOVE TO X,Y SUPPLIED
	SKIPG SVSZ
	JRST ENDTXT	;SIZE MUST BE >0
	MOVE TP,SVTXT
	HRLI TP,440700	;POINTER TO ASCII
LP1:	SOSGE SVNTXT
	JRST ENDTXT
	ILDB CHAR,TP	;GET TEXT CHAR
	MOVSI STROKE,440500	;SET UP FOR SYM STROKES

;FOLLOWING TWO LOCATIONS ARE MODIFIED TO GET DIFFERENT
;CHARACTER SETS.
T1M:	HRR STROKE,TBL1(CHAR)
T2M:	HLRZ SCT,TBL1(CHAR)	;NUMBER OF STROKES
	JUMPE SCT,LP1	;UNDEFINED CHAR
	MOVE XO,X
	MOVE YO,Y	;ORIGIN OF THE CHARACTER
OUT1:	ILDB TX,STROKE	;1 FOR MARK, 0 FOR BLANK
	MOVNS TX
	ADDI TX,3
	MOVEM TX,SVPEN
	ILDB TX,STROKE
	ILDB TY,STROKE
	SUBI TY,6	;OFFSET FOR VERTICAL
	FSC TX,230	;FLOAT AND DIVIDE BY 8
	FSC TY,230	;"
	FMPR TX,SVSZ
	FMPR TY,SVSZ
	MOVE DAT,TX
	FMPR DAT,COSOR
	MOVN 0,TY
	FMPR 0,SINOR
	FADR 0,DAT
	FADR 0,XO
	MOVEM 0,SVX
	MOVE DAT,TY
	FMPR DAT,COSOR
	MOVE 0,TX
	FMPR 0,SINOR
	FADR 0,DAT
	FADR 0,YO
	MOVEM 0,SVY
	PUSHJ P,PLOT.
	SOJG SCT,OUT1
	JRST LP1

ENDTXT:	MOVSI 17,SV0
	BLT 17,17	;RESTORE AC'S
	GOODBY	(6)		;RETURN TO CALLER
;FORMAT OF CHARACTER TABLE IS: LEFT HALF, NUMBER OF LINE
;SEGMENTS IN CHARACTER. RIGHT HALF, ADDRESS OF BYTE TABLE
;DESCRIBING SEGMENTS
TBL1:	;THIS IS VERY LONG, SO XLIST
XLIST
	XWD 0,0		;CHARACTER TABLE
	XWD 6,T11
	XWD 11,T12
	XWD 17,T13
	XWD 4,T14
	XWD 4,T15
	XWD 13,T16
	XWD 7,T17
	XWD 5,T110
	XWD 13,T111
	XWD 15,T112
	XWD 11,T113
	XWD 7,T114
	XWD 16,T115
	XWD 14,T116
	XWD 14,T117
	XWD 7,T120
	XWD 7,T121
	XWD 7,T122
	XWD 7,T123
	XWD 6,T124
	XWD 6,T125
	XWD 15,T126
	XWD 11,T127
	XWD 3,T130
	XWD 6,T131
	XWD 4,T132
	XWD 6,T133
	XWD 5,T134
	XWD 5,T135
	XWD 7,T136
	XWD 4,T137
	XWD 1,T140
	XWD 5,T141
	XWD 5,T142
	XWD 11,T143
	XWD 17,T144
	XWD 23,T145
	XWD 14,T146
	XWD 3,T147
	XWD 5,T150
	XWD 4,T151
	XWD 11,T152
	XWD 5,T153
	XWD 7,T154
	XWD 3,T155
	XWD 6,T156
	XWD 2,T157
	XWD 14,T160
	XWD 4,T161
	XWD 12,T162
	XWD 14,T163
	XWD 5,T164
	XWD 13,T165
	XWD 13,T166
	XWD 4,T167
	XWD 21,T170
	XWD 13,T171
	XWD 13,T172
	XWD 14,T173
	XWD 4,T174
	XWD 5,T175
	XWD 4,T176
	XWD 12,T177
	XWD 23,T1100
	XWD 5,T1101
	XWD 14,T1102
	XWD 11,T1103
	XWD 7,T1104
	XWD 7,T1105
	XWD 5,T1106
	XWD 13,T1107
	XWD 6,T1110
	XWD 7,T1111
	XWD 10,T1112
	XWD 7,T1113
	XWD 4,T1114
	XWD 5,T1115
	XWD 4,T1116
	XWD 12,T1117
	XWD 7,T1120
	XWD 14,T1121
	XWD 11,T1122
	XWD 13,T1123
	XWD 5,T1124
	XWD 7,T1125
	XWD 4,T1126
	XWD 6,T1127
	XWD 4,T1130
	XWD 6,T1131
	XWD 5,T1132
	XWD 5,T1133
	XWD 3,T1134
	XWD 5,T1135
	XWD 6,T1136
	XWD 6,T1137
	XWD 3,T1140
	XWD 16,T1141
	XWD 12,T1142
	XWD 11,T1143
	XWD 14,T1144
	XWD 13,T1145
	XWD 10,T1146
	XWD 16,T1147
	XWD 7,T1150
	XWD 7,T1151
	XWD 7,T1152
	XWD 6,T1153
	XWD 3,T1154
	XWD 14,T1155
	XWD 7,T1156
	XWD 12,T1157
	XWD 13,T1160
	XWD 13,T1161
	XWD 6,T1162
	XWD 13,T1163
	XWD 10,T1164
	XWD 10,T1165
	XWD 4,T1166
	XWD 6,T1167
	XWD 4,T1170
	XWD 6,T1171
	XWD 5,T1172
	XWD 10,T1173
	XWD 3,T1174
	XWD 10,T1175
	XWD 5,T1176
	XWD 4,T1177
RADIX 10
;FORMAT OF BYTE TABLE: BYTE COME IN TRIPLES. FIRST IS
;0 FOR PEN UP, 1 PEN DOWN. SECOND IS X COORDINATE OF OTHER
;END OF SEGMENT. THIRD IS SAME FOR Y. CHARACTER ASSUMED
;TO START AT (0,6)
T11:	BYTE (5) 0,0,9,1,3,6,1,3,14,0,3,6,1,6,9,0,8,6
T12:	BYTE (5) 0,6,6,1,3,9,1,1,9,1,0,8,1,0,7,1,1,6,1,3,6
	BYTE (5) 1,6,9,0,8,6
T13:	BYTE (5) 1,2,8,1,2,13,1,3,14,1,5,14,1,6,13,1,6,12,1,5,11
	BYTE (5) 1,2,11,0,5,11,1,6,10,1,6,9,1,5,8,1,3,8,1,2,9
	BYTE (5) 0,8,6
T14:	BYTE (5) 0,0,8,1,3,11,1,6,8,0,8,6
T15:	BYTE (5) 0,1,10,1,5,10,1,5,8,0,8,6
T16:	BYTE (5) 0,3,9,1,2,10,1,1,10,1,0,9,1,0,7,1,1,6,1,2,6
	BYTE (5) 1,3,7,0,2,8,1,0,8,0,8,6
T17:	BYTE (5) 0,0,10,1,6,10,0,4,10,1,4,6,0,2,6,1,2,10,0,8,6
T110:	BYTE (5) 1,3,9,0,0,11,1,1,11,1,6,6,0,8,6
T111:	BYTE (5) 0,0,11,1,1,12,1,2,12,1,5,9,1,5,7,1,4,6,1,3,6
	BYTE (5) 1,2,7,1,2,8,1,6,12,0,8,6
T112:	BYTE (5) 0,2,10,1,1,10,1,0,9,1,0,7,1,1,6,1,3,6,1,4,7
	BYTE (5) 1,4,9,1,3,10,1,2,10,1,2,12,1,4,12,0,8,6
T113:	BYTE (5) 0,0,7,1,1,6,1,2,6,1,3,7,1,3,12,1,4,13,1,5,13
	BYTE (5) 1,6,12,0,8,6
T114:	BYTE (5) 0,0,9,1,4,9,0,2,11,1,2,7,0,0,7,1,4,7,0,8,6
T115:	BYTE (5) 0,0,8,1,0,7,1,1,6,1,3,6,1,4,7,1,4,9,1,3,10
	BYTE (5) 1,1,10,1,0,9,1,0,8,1,4,8,0,2,10,1,2,6,0,8,6
T116:	BYTE (5) 0,0,10,1,1,9,1,2,9,1,4,11,1,5,11,1,6,10,1,5,9
	BYTE (5) 1,4,9,1,2,11,1,1,11,1,0,10,0,8,6
T117:	BYTE (5) 0,4,8,1,3,9,1,1,9,1,0,8,1,0,7,1,1,6,1,3,6
	BYTE (5) 1,4,7,1,4,10,1,2,12,1,1,12,0,8,6
T120:	BYTE (5) 0,3,11,1,1,11,1,0,10,1,0,8,1,1,7,1,3,7,0,8,6
T121:	BYTE (5) 0,0,11,1,2,11,1,3,10,1,3,8,1,2,7,1,0,7,0,8,6
T122:	BYTE (5) 0,0,10,1,0,8,1,1,7,1,3,7,1,4,8,1,4,10,0,8,6
T123:	BYTE (5) 0,0,7,1,0,9,1,1,10,1,3,10,1,4,9,1,4,7,0,8,6
T124:	BYTE (5) 0,0,14,1,3,6,1,6,14,0,1,11,1,5,11,0,8,6
T125:	BYTE (5) 1,6,6,1,6,14,1,0,14,0,2,10,1,6,10,0,8,6
T126:	BYTE (5) 1,4,10,0,0,10,1,4,6,0,3,6,1,1,6,1,0,7,1,0,9
	BYTE (5) 1,1,10,1,3,10,1,4,9,1,4,7,1,3,6,0,8,6
T127:	BYTE (5) 0,2,8,1,0,10,1,2,12,0,0,10,1,6,10,0,4,12,1,6,10
	BYTE (5) 1,4,8,0,8,6
T130:	BYTE (5) 0,0,5,1,4,5,0,0,6
T131:	BYTE (5) 0,0,10,1,6,10,0,3,13,1,6,10,1,3,7,0,8,6
T132:	BYTE (5) 0,2,16,1,3,17,1,4,16,0,0,6
T133:	BYTE (5) 1,6,12,0,0,10,1,6,10,0,0,8,1,6,8,0,8,6
T134:	BYTE (5) 1,3,6,0,3,7,1,0,10,1,3,13,0,8,6
T135:	BYTE (5) 1,3,6,0,0,7,1,3,10,1,0,13,0,8,6
T136:	BYTE (5) 0,0,7,1,6,7,0,6,9,1,0,9,0,0,11,1,6,11,0,8,6
T137:	BYTE (5) 0,0,11,1,3,8,1,6,11,0,8,6
T140:	BYTE (5) 0,8,6
T141:	BYTE (5) 0,2,6,1,2,7,0,2,8,1,2,13,0,8,6
T142:	BYTE (5) 0,2,12,1,2,14,0,4,14,1,4,12,0,8,6
T143:	BYTE (5) 0,2,7,1,2,13,0,4,13,1,4,7,0,6,9,1,0,9,0,0,11
	BYTE (5) 1,6,11,0,8,6
T144:	BYTE (5) 0,0,8,1,2,6,1,4,6,1,6,8,1,4,10,1,2,10,1,0,12
	BYTE (5) 1,2,14,1,4,14,1,6,12,0,4,14,1,4,6,0,2,6,1,2,14
	BYTE (5) 0,8,6
T145:	BYTE (5) 1,6,12,1,1,12,1,0,11,1,0,10,1,1,9,1,2,9,1,3,10
	BYTE (5) 1,3,11,1,2,12,0,4,9,1,3,8,1,3,7,1,4,6,1,5,6
	BYTE (5) 1,6,7,1,6,8,1,5,9,1,4,9,0,8,6
T146:	BYTE (5) 0,6,6,1,1,11,1,1,13,1,2,14,1,3,14,1,4,13,1,0,9
	BYTE (5) 1,0,7,1,1,6,1,3,6,1,5,8,0,8,6
T147:	BYTE (5) 0,2,12,1,4,14,0,8,6
T150:	BYTE (5) 0,2,6,1,0,8,1,0,12,1,2,14,0,8,6
T151:	BYTE (5) 1,2,8,1,2,12,1,0,14,0,8,6
T152:	BYTE (5) 0,0,8,1,4,12,0,2,12,1,2,8,0,4,8,1,0,12,0,0,10
	BYTE (5) 1,4,10,0,8,6
T153:	BYTE (5) 0,2,7,1,2,11,0,0,9,1,4,9,0,8,6
T154:	BYTE (5) 0,3,6,1,3,7,1,2,7,1,2,6,1,3,6,1,2,5,0,8,6
T155:	BYTE (5) 0,0,9,1,4,9,0,8,6
T156:	BYTE (5) 0,2,6,1,3,6,1,3,7,1,2,7,1,2,6,0,8,6
T157:	BYTE (5) 1,6,12,0,8,6
T160:	BYTE (5) 0,0,7,1,6,13,0,6,12,1,4,14,1,2,14,1,0,12,1,0,8
	BYTE (5) 1,2,6,1,4,6,1,6,8,1,6,12,0,8,6
T161:	BYTE (5) 0,1,12,1,3,14,1,3,6,0,8,6
T162:	BYTE (5) 0,0,12,1,0,13,1,1,14,1,5,14,1,6,13,1,6,11,1,0,7
	BYTE (5) 1,0,6,1,6,6,0,8,6
T163:	BYTE (5) 0,0,13,1,1,14,1,5,14,1,6,13,1,6,12,1,4,10,1,6,8
	BYTE (5) 1,6,7,1,5,6,1,1,6,1,0,7,0,8,6
T164:	BYTE (5) 0,5,6,1,5,14,1,0,9,1,6,9,0,8,6
T165:	BYTE (5) 0,0,7,1,1,6,1,4,6,1,6,8,1,6,9,1,5,10,1,1,10
	BYTE (5) 1,0,9,1,0,14,1,6,14,0,8,6
T166:	BYTE (5) 0,0,9,1,1,10,1,5,10,1,6,9,1,6,7,1,5,6,1,1,6
	BYTE (5) 1,0,7,1,0,10,1,4,14,0,8,6
T167:	BYTE (5) 0,0,14,1,6,14,1,1,6,0,8,6
T170:	BYTE (5) 0,1,10,1,0,9,1,0,7,1,1,6,1,5,6,1,6,7,1,6,9
	BYTE (5) 1,5,10,1,6,11,1,6,13,1,5,14,1,1,14,1,0,13,1,0,11
	BYTE (5) 1,1,10,1,5,10,0,8,6
T171:	BYTE (5) 0,2,6,1,6,10,1,6,13,1,5,14,1,1,14,1,0,13,1,0,11
	BYTE (5) 1,1,10,1,5,10,1,6,11,0,8,6
T172:	BYTE (5) 0,2,6,1,3,6,1,3,7,1,2,7,1,2,6,0,2,10,1,3,10
	BYTE (5) 1,3,11,1,2,11,1,2,10,0,8,6
T173:	BYTE (5) 0,3,6,1,3,7,1,2,7,1,2,6,1,3,6,1,2,5,0,2,10
	BYTE (5) 1,3,10,1,3,11,1,2,11,1,2,10,0,8,6
T174:	BYTE (5) 0,3,7,1,0,10,1,3,13,0,8,6
T175:	BYTE (5) 0,0,8,1,6,8,0,6,10,1,0,10,0,8,6
T176:	BYTE (5) 0,0,7,1,3,10,1,0,13,0,8,6
T177:	BYTE (5) 0,1,13,1,2,14,1,4,14,1,5,13,1,5,12,1,3,10,1,3,8
	BYTE (5) 0,3,7,1,3,6,0,8,6
T1100:	BYTE (5) 0,1,6,1,0,7,1,0,11,1,1,12,1,5,12,1,6,11,1,6,8
	BYTE (5) 1,5,7,1,4,8,1,4,11,0,4,10,1,3,11,1,2,11,1,1,10
	BYTE (5) 1,1,9,1,2,8,1,3,8,1,4,9,0,8,6
T1101:	BYTE (5) 1,3,14,1,6,6,0,1,9,1,5,9,0,8,6
T1102:	BYTE (5) 1,0,14,1,5,14,1,6,13,1,6,11,1,5,10,1,0,10,0,5,10
	BYTE (5) 1,6,9,1,6,7,1,5,6,1,0,6,0,8,6
T1103:	BYTE (5) 0,6,13,1,5,14,1,2,14,1,0,12,1,0,8,1,2,6,1,5,6
	BYTE (5) 1,6,7,0,8,6
T1104:	BYTE (5) 1,0,14,1,4,14,1,6,12,1,6,8,1,4,6,1,0,6,0,8,6
T1105:	BYTE (5) 1,0,14,1,6,14,0,4,10,1,0,10,0,0,6,1,6,6,0,8,6
T1106:	BYTE (5) 1,0,14,1,6,14,0,4,10,1,0,10,0,8,6
T1107:	BYTE (5) 0,6,13,1,5,14,1,2,14,1,0,12,1,0,8,1,2,6,1,4,6
	BYTE (5) 1,6,8,1,6,10,1,4,10,0,8,6
T1110:	BYTE (5) 1,0,14,0,6,14,1,6,6,0,0,10,1,6,10,0,8,6
T1111:	BYTE (5) 0,1,6,1,5,6,0,3,6,1,3,14,0,1,14,1,5,14,0,8,6
T1112:	BYTE (5) 0,1,7,1,2,6,1,3,6,1,4,7,1,4,14,0,2,14,1,6,14
	BYTE (5) 0,8,6
T1113:	BYTE (5) 0,1,6,1,1,14,0,1,10,1,5,14,0,1,10,1,5,6,0,8,6
T1114:	BYTE (5) 1,0,14,0,0,6,1,6,6,0,8,6
T1115:	BYTE (5) 1,0,14,1,3,11,1,6,14,1,6,6,0,8,6
T1116:	BYTE (5) 1,0,14,1,6,6,1,6,14,0,8,6
T1117:	BYTE (5) 0,0,8,1,0,12,1,2,14,1,4,14,1,6,12,1,6,8,1,4,6
	BYTE (5) 1,2,6,1,0,8,0,8,6
T1120:	BYTE (5) 1,0,14,1,5,14,1,6,13,1,6,11,1,5,10,1,0,10,0,8,6

T1121:	BYTE (5) 0,0,8,1,0,12,1,2,14,1,4,14,1,6,12,1,6,8,1,4,6
	BYTE (5) 1,2,6,1,0,8,0,4,8,1,6,6,0,8,6
T1122:	BYTE (5) 1,0,14,1,5,14,1,6,13,1,6,11,1,5,10,1,0,10,0,2,10
	BYTE (5) 1,6,6,0,8,6
T1123:	BYTE (5) 0,0,8,1,2,6,1,4,6,1,6,8,1,4,10,1,2,10,1,0,12
	BYTE (5) 1,2,14,1,4,14,1,6,12,0,8,6
T1124:	BYTE (5) 0,3,6,1,3,14,0,0,14,1,6,14,0,8,6
T1125:	BYTE (5) 0,0,14,1,0,7,1,1,6,1,5,6,1,6,7,1,6,14,0,8,6
T1126:	BYTE (5) 0,0,14,1,3,6,1,6,14,0,8,6
T1127:	BYTE (5) 0,0,14,1,0,6,1,3,9,1,6,6,1,6,14,0,8,6
T1130:	BYTE (5) 1,6,14,0,0,14,1,6,6,0,8,6
T1131:	BYTE (5) 0,0,14,1,3,11,1,6,14,0,3,11,1,3,6,0,8,6
T1132:	BYTE (5) 0,0,14,1,6,14,1,0,6,1,6,6,0,8,6
T1133:	BYTE (5) 0,3,4,1,0,4,1,0,14,1,3,14,0,8,6
T1134:	BYTE (5) 0,0,12,1,6,6,0,8,6
T1135:	BYTE (5) 0,0,4,1,3,4,1,3,14,1,0,14,0,8,6
T1136:	BYTE (5) 0,0,11,1,3,14,1,6,11,0,3,14,1,3,6,0,8,6
T1137:	BYTE (5) 0,3,7,1,0,10,1,3,13,0,0,10,1,6,10,0,8,6
T1140:	BYTE (5) 0,2,14,1,4,12,0,8,6
T1141:	BYTE (5) 0,0,9,1,1,10,1,3,10,1,4,9,1,4,6,0,4,8,1,3,9
	BYTE (5) 1,1,9,1,0,8,1,0,7,1,1,6,1,3,6,1,4,7,0,8,6
T1142:	BYTE (5) 1,0,13,0,0,9,1,1,10,1,3,10,1,4,9,1,4,7,1,3,6
	BYTE (5) 1,1,6,1,0,7,0,8,6
T1143:	BYTE (5) 0,4,9,1,3,10,1,1,10,1,0,9,1,0,7,1,1,6,1,3,6
	BYTE (5) 1,4,7,0,8,6
T1144:	BYTE (5) 0,0,7,1,0,9,1,1,10,1,3,10,1,4,9,1,4,7,1,3,6
	BYTE (5) 1,1,6,1,0,7,0,4,6,1,4,13,0,8,6
T1145:	BYTE (5) 0,4,7,1,3,6,1,1,6,1,0,7,1,0,9,1,1,10,1,3,10
	BYTE (5) 1,4,9,1,4,8,1,0,8,0,8,6
T1146:	BYTE (5) 0,2,6,1,2,12,1,3,13,1,4,13,1,5,12,0,0,11,1,4,11
	BYTE (5) 0,8,6
T1147:	BYTE (5) 0,4,9,1,3,10,1,1,10,1,0,9,1,0,7,1,1,6,1,3,6
	BYTE (5) 1,4,7,0,4,10,1,4,5,1,3,4,1,1,4,1,0,5,0,8,6
T1150:	BYTE (5) 1,0,13,0,0,9,1,1,10,1,3,10,1,4,9,1,4,6,0,8,6
T1151:	BYTE (5) 0,3,12,1,3,11,0,3,10,1,3,7,1,4,6,1,5,6,0,8,6
T1152:	BYTE (5) 0,3,12,1,3,11,0,3,10,1,3,5,1,2,4,1,1,4,0,8,6
T1153:	BYTE (5) 1,0,13,0,0,8,1,2,10,0,0,8,1,2,6,0,8,6
T1154:	BYTE (5) 0,2,6,1,2,13,0,8,6
T1155:	BYTE (5) 1,0,10,0,0,9,1,1,10,1,2,10,1,3,9,1,3,6,0,3,9
	BYTE (5) 1,4,10,1,5,10,1,6,9,1,6,6,0,8,6
T1156:	BYTE (5) 1,0,10,0,0,9,1,1,10,1,2,10,1,3,9,1,3,6,0,8,6
T1157:	BYTE (5) 0,0,7,1,0,9,1,1,10,1,3,10,1,4,9,1,4,7,1,3,6
	BYTE (5) 1,1,6,1,0,7,0,8,6
T1160:	BYTE (5) 0,0,4,1,0,10,0,0,9,1,1,10,1,3,10,1,4,9,1,4,7
	BYTE (5) 1,3,6,1,1,6,1,0,7,0,8,6
T1161:	BYTE (5) 0,4,9,1,3,10,1,1,10,1,0,9,1,0,7,1,1,6,1,3,6
	BYTE (5) 1,4,7,0,4,10,1,4,4,0,8,6
T1162:	BYTE (5) 1,0,10,0,0,9,1,1,10,1,3,10,1,4,9,0,8,6
T1163:	BYTE (5) 0,0,7,1,1,6,1,3,6,1,4,7,1,3,8,1,1,8,1,0,9
	BYTE (5) 1,1,10,1,3,10,1,4,9,0,8,6
T1164:	BYTE (5) 0,2,13,1,2,7,1,3,6,1,4,6,1,5,7,0,1,11,1,3,11
	BYTE (5) 0,8,6
T1165:	BYTE (5) 0,0,10,1,0,7,1,1,6,1,3,6,1,4,7,1,4,10,1,4,6
	BYTE (5) 0,8,6
T1166:	BYTE (5) 0,0,10,1,2,6,1,4,10,0,8,6
T1167:	BYTE (5) 0,0,10,1,0,6,1,2,8,1,4,6,1,4,10,0,8,6
T1170:	BYTE (5) 1,4,10,0,0,10,1,4,6,0,8,6
T1171:	BYTE (5) 0,0,10,1,2,6,0,4,10,1,1,4,1,0,4,0,8,6
T1172:	BYTE (5) 0,0,10,1,4,10,1,0,6,1,4,6,0,8,6
T1173:	BYTE (5) 0,3,14,1,2,13,1,2,11,1,0,9,1,2,7,1,2,5,1,3,4
	BYTE (5) 0,8,6
T1174:	BYTE (5) 0,2,4,1,2,14,0,8,6
T1175:	BYTE (5) 0,0,14,1,1,13,1,1,11,1,3,9,1,1,7,1,1,5,1,0,4
	BYTE (5) 0,8,6
T1176:	BYTE (5) 0,2,16,1,3,17,1,4,16,1,5,17,0,0,6
T1177:	BYTE (5) 0,1,16,1,4,16,1,4,15,0,0,6
RADIX 8
LIST
	;END OF BYTE TABLES
		;ROUTINE TO ALLOW USE OF DIFFERENT CHARACTER
		;TABLE
	ENTRY SETABL

	HELLO	(SETABL)
	MOVEM 17,SV17	;GET NUMBER OF DESIRED TABLE
	MOVE 17,@(Q)
	SETZM @1(Q)
	JUMPLE 17,NOGO
	CAILE 17,12
	JRST NOGO
	MOVE 17,CTBL-1(17)
	JUMPE 17,NOGO	;NO SUCH TABLE
	HRRM 17,T1M	;RESET PARAMETERS IN SYMBOL
	HRRM 17,T2M
	SKIPA
NOGO:	SETOM @1(Q)
	MOVE 17,SV17	;GIVE ERROR INDICATION
	GOODBY	(2)
EXTERNAL PLOTC,PLOTF
CTBL:	EXP TBL1	;LINE PRINTER CHARACTER SET
	EXP PLOTC	;RUSSIAN OR 0 IF NOT LOADED
	EXP PLOTF	;FAENORIAN OR 0 IF NOT LOADED
	EXP 0,0,0,0,0,0,0
		;ROUTINE TO ALLOW NEW TABLE TO BE CREATED
		;GIVEN NUMBER AND POINTER TO NEW TABLE
	ENTRY MKTBL

	HELLO	(MKTBL)
	MOVEM 17,SV17
	MOVE 17,@(Q)
	CAIG 17,12
	SKIPG 17
	JRST FOOT
	MOVEM 17,SVTB
;**; [562] CHANGE @ MKTBL+10	CLRH	12-JUL-76
	MOVEI	17,@1(Q)	;[562] GET TABLE ADDRESS
	EXCH 1,SVTB
	MOVEM 17,CTBL-1(1)	;PUT IN POINTER
	SKIPA 1,SVTB
FOOT:	SETZM @0(Q)
	MOVE 17,SV17
	GOODBY	(2)
		;ROUTINE TO GIVE BACK CURRENT X,Y POSITION
	ENTRY WHERE

	HELLO	(WHERE)
	MOVEM 17,SV17	;SAVE AC'S
	MOVEI 17,SV0
	BLT 17,SV0+16
	MOVEI	1,@0(Q)		;[221] LOAD ARGUMENT ADDRESS
	MOVE 2,X
	CAIG 1,17	;IF ONE OF AC'S SPECIFIED
			;PUT IT IN THE TEMP STORAGE LOCATION
	ADDI 1,SV0
	MOVEM 2,(1)
	MOVEI	1,@1(Q)		;[221] LOAD ARGUMENT ADDRESS
	MOVE 2,Y
	CAIG 1,17
	ADDI 1,SV0
	MOVEM 2,(1)
	HRLZI 17,SV0
	BLT 17,17
	GOODBY	(2)
;**; [623] BEFORE NUMBER ENTRY POINT IN PLOT	CLRH	18-NOV-76
	EXTERN IFIX.,FLOAT.,EXP2..	;[623] [516]
	ENTRY NUMBER

	HELLO	(NUMBER)
	MOVEM 17,SV17N
	MOVEI 17,NARGS-1
	PUSH 17,@0(Q)	;SVXN
	PUSH 17,@1(Q)	;SVYN
	PUSH 17,@2(Q)	;SVSZN
	PUSH 17,@3(Q)	;SVFN
	PUSH 17,@4(Q)	;SVORN
	PUSH 17,@5(Q)	;SVNN
	MOVEI 17,SV0N
	BLT 17,SV0N+2	;SAVE AC'S
	MOVE P,PNPDP
	FUNCT	PLOT,<SVXN,SVYN,[3]>
	MOVSI 1,264000
	SKIPGE SVFN
	PUSHJ P,DECP2
	MOVMS SVFN
	SKIPGE 1,SVNN
	MOVEI 1,0
	MOVNS 1
	MOVSI 0,(10.0)
;**; [623] CHANGE @ NUMBER+21(10)L	CLRH	18-NOV-76
	PUSHJ P,EXP2..##	;[623] DO NOT USE F40 CALL
	MOVEM 0,T2T
	FSC 0,-1
	FADRB 0,SVFN	;ROUND IN FIRST INSIGNIFICANT DIGIT
	FDVR 0,T2T	;SCALE TO AN INTEGER
	MOVEM 0,TEMP
	FUNCT IFIX.,<TEMP>	; [516]
	MOVEM 0,UNITS
	PUSHJ P,DECPLT
	MOVSI 1,270000
	SKIPN SVNN	;NEED A DEC. PT. IN ONE CASE
	PUSHJ P,DECP2
ENDNUM:	MOVSI 17,SV0N
	BLT 17,2
	MOVE 17,SV17N
	GOODBY	(6)
DECPLT:	MOVM 1,UNITS
	SETZM DIGITS
DECP3:	IDIVI 1,12
	HRLM 2,0(P)
	AOS DIGITS
	SKIPE 1
	PUSHJ P,DECP3
	MOVE 0,DIGITS
	CAMLE 0,SVNN
	JRST DECP4
	MOVSI 1,270000
	PUSHJ P,DECP2	;PLOT A "."
	CAML 0,SVNN
	JRST DECP4A
DECP5:	MOVSI 1,300000	;A ZERO
	PUSHJ P,DECP2
	AOS 1,DIGITS
	CAMGE 1,SVNN
	JRST DECP5
DECP4A:	SETOM SVNN	;FAKE OUT TEST NEXT TIME AROUND
DECP4:	SOS DIGITS
	HLRZ 1,0(P)
	TRO 1,60
	ROT 1,-7
DECP2:	MOVEM 1,TEMP
	FUNCT SYMBOL,<X,Y,SVSZN,TEMP,SVORN,[1]>
	POPJ P,0
;ALL SORTS TEMPS AND STUFF

POB:	BLOCK 3
PPDP:	XWD -PDPSIZ,.
	BLOCK PDPSIZ
PNPDP:	XWD -15,.
	BLOCK 15
ARGS:	;ARGUMENT STORAGE - DO NOT REARRANGE
SVX:	0
SVY:	0
SVPEN:	0
SVSZ:	0
SVTXT:	0
SVOR:	0
SVNTXT:	0
SV0:	BLOCK 17
SV17:	0
SV0N:	BLOCK 3
SV17N:	0
NARGS:
SVXN:	0
SVYN:	0
SVSZN:	0
SVFN:	0
SVORN:	0
SVNN:	0
X:	0
Y:	0
PEN:	0
STEP:	0
UNITS:	0
DIGITS:	0
TEMP:	0
T2T:	0
SVTB:	0
COSOR:	0
SINOR:	0
ISX:	0
ISY:	0
IX:	0
IY:	0

INTERN STPSIZ
;**;[640] ADD AT STPSIZ-1 AND STPSIZ+1	SWG	18-JAN-77
IFE F20LIB <		;[640] DEFAULT FOR -10 IS 100
STPSIZ:	DEC 100.0	;STEPS PER INCH
>			;[640]
IFN F20LIB <		;[640] DEFAULT FOR -20 IS 254
STPSIZ:	DEC 254.0	;[640] STEPS PER INCH
>			;[640]

	PRGEND
TITLE	PLOTCD	%4.(243) (DUMMY PLOTC)
SUBTTL	D. TODD/DRT/HPW		14-DEC-73



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.

;COPYRIGHT (C) 1972,1977 BY DIGITAL EQUIPMENT CORPORATION
SUBTTL	REVISION HISTORY

;243	(12167)	DEFINE PLOTC AS 0

SEARCH	FORPRM
ENTRY PLOTC
PLOTC==0
PRGEND
TITLE	PLOTFD	%4.(243) (DUMMY PLOTF)
SUBTTL	D. TODD/DRT/HPW	14-DEC-73



;THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED
;  OR COPIED IN ACCORDANCE WITH THE TERMS OF SUCH LICENSE.

;COPYRIGHT (C) 1972,1977 BY DIGITAL EQUIPMENT CORPORATION

SUBTTL	REVISION HISTORY

;243	(12167)	DEFINE PLOTF AS 0

SEARCH FORPRM
ENTRY PLOTF
PLOTF==0
END