# include "stdio.h"
# define U(x) x
# define NLSTATE yyprevious=YYNEWLINE
# define BEGIN yybgin = yysvec + 1 +
# define INITIAL 0
# define YYLERR yysvec
# define YYSTATE (yyestate-yysvec-1)
# define YYOPTIM 1
# define YYLMAX 200
# define output(c) putc(c,yyout)
# define input() (((yytchar=yysptr>yysbuf?U(*--yysptr):getc(yyin))==10?(yylineno++,yytchar):yytchar)==EOF?0:yytchar)
# define unput(c) {yytchar= (c);if(yytchar=='\n')yylineno--;*yysptr++=yytchar;}
# define yymore() (yymorfg=1)
# define ECHO fprintf(yyout, "%s",yytext)
# define REJECT { nstr = yyreject(); goto yyfussy;}
int yyleng; extern char yytext[];
int yymorfg;
extern char *yysptr, yysbuf[];
int yytchar;
FILE *yyin ={stdin}, *yyout ={stdout};
extern int yylineno;
struct yysvf { 
	struct yywork *yystoff;
	struct yysvf *yyother;
	int *yystops;};
struct yysvf *yyestate;
extern struct yysvf yysvec[], *yybgin;
# define YYNEWLINE 10
yylex(){
int nstr; extern int yyprevious;
while((nstr = yylook()) >= 0)
yyfussy: switch(nstr){
case 0:
if(yywrap()) return(0); break;
case 1:
{
			/* character constants go to operand output */
			printf(" %s ", yytext);
			}
break;
case 2:
{
			/* print 2 character symbols to operator output */
			fprintf(stderr,"%s\n", yytext);
			putchar(' ');
		 	}
break;
case 3:
{
			/* print most 1 char symbols to operator output */
			fprintf(stderr,"%s\n", yytext);
			putchar(' ');
			}
break;
case 4:
	{
			/* print indirection operator to operator output */
			fprintf(stderr,"*indirection\n");
			putchar(' ');
			}
break;
case 5:
		{
			/* multiplication operator */
			fprintf(stderr,"%s\n", yytext);
			putchar(' ');
			}
break;
case 6:
	{
			/* delete delimiters */
			/* NOTE - prints to stdout, unlike above */
			putchar(' ');
			}
break;
case 7:
{
			/* sizeof operator to operator output */
			fprintf(stderr, "sizeof\n" );
			putchar(' ');
			}
break;
case 8:
{
			/* preprocessor operators to operator output */
			fprintf(stderr, "%s\n", yytext);
			putchar(' ');
			}
break;
case 9:
{
			/* statements */
			fprintf(stderr, "%s\n", yytext);
			putchar(' ');
			}
break;
case 10:
{
			/* storage class specifiers */
			fprintf(stderr, "%s\n", yytext);
			putchar(' ');
			}
break;
case 11:
{
			/* type specifier */
			fprintf(stderr, "%s\n", yytext);
			putchar(' ');
			}
break;
case 12:
	{
			/* struct or union specifier */
			fprintf(stderr, "%s\n", yytext);
			putchar(' ');
			}
break;
case 13:
{
			/* catch operand names */
			printf(" %s ", yytext);
			}
break;
case 14:
		ECHO;
break;
case -1:
break;
default:
fprintf(yyout,"bad switch yylook %d",nstr);
} return(0); }
/* end of yylex */
int yyvstop[] ={
0,

14,
0,

3,
14,
0,

3,
14,
0,

3,
14,
0,

14,
0,

3,
14,
0,

5,
14,
-4,
0,

3,
14,
0,

3,
14,
0,

6,
14,
0,

3,
14,
0,

3,
14,
0,

3,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

13,
14,
0,

3,
14,
0,

14,
0,

2,
0,

4,
0,

2,
4,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
-9,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
-9,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

-8,
0,

1,
0,

1,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

9,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
-11,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

8,
0,

13,
-10,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

11,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

10,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
-12,
0,

13,
0,

13,
0,

13,
0,

13,
0,

13,
-7,
0,

13,
0,

12,
0,

13,
0,

13,
0,

13,
0,

7,
0,

13,
0,
0};
# define YYTYPE int
struct yywork { YYTYPE verify, advance; } yycrank[] ={
0,0,	0,0,	1,3,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	1,3,	1,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	1,4,	0,0,	
0,0,	0,0,	1,5,	1,6,	
1,7,	1,8,	1,8,	1,9,	
1,10,	1,8,	1,11,	1,8,	
6,33,	1,3,	10,33,	0,0,	
0,0,	11,33,	0,0,	0,0,	
0,0,	0,0,	0,0,	1,12,	
0,0,	1,13,	1,14,	1,15,	
1,8,	4,33,	1,16,	34,63,	
10,33,	11,33,	11,33,	13,33,	
13,33,	15,33,	15,33,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
1,8,	0,0,	1,8,	1,8,	
0,0,	0,0,	1,17,	1,18,	
1,19,	1,20,	1,21,	1,22,	
1,23,	1,16,	1,24,	1,16,	
1,16,	1,25,	1,16,	1,16,	
1,16,	1,16,	1,16,	1,26,	
1,27,	1,28,	1,29,	1,16,	
1,30,	1,16,	1,16,	1,16,	
1,12,	1,31,	2,0,	1,8,	
17,39,	18,40,	19,41,	20,44,	
22,48,	21,46,	23,50,	22,49,	
25,53,	19,42,	24,51,	26,54,	
28,59,	20,45,	29,60,	30,61,	
19,43,	21,47,	24,52,	31,33,	
7,34,	39,67,	40,68,	2,32,	
27,55,	27,56,	2,6,	2,7,	
7,34,	7,0,	41,69,	2,10,	
2,8,	2,11,	2,8,	42,70,	
27,57,	43,71,	44,72,	27,58,	
46,75,	47,76,	48,77,	49,51,	
50,78,	52,79,	53,80,	55,83,	
2,13,	2,14,	2,15,	2,8,	
7,34,	54,81,	56,84,	57,85,	
7,34,	58,87,	59,88,	7,34,	
7,34,	7,34,	61,91,	60,89,	
67,94,	68,95,	54,82,	7,34,	
69,51,	70,79,	71,96,	72,97,	
57,86,	60,90,	74,98,	75,51,	
76,99,	7,34,	77,100,	2,8,	
78,51,	2,8,	2,8,	80,79,	
7,34,	81,102,	2,18,	2,19,	
2,20,	2,21,	2,22,	2,23,	
2,16,	2,24,	2,16,	2,16,	
2,25,	2,16,	2,16,	2,16,	
2,16,	2,16,	2,26,	2,27,	
2,28,	2,29,	2,16,	2,30,	
2,16,	2,16,	2,16,	7,35,	
2,31,	9,36,	2,8,	66,63,	
7,34,	62,92,	62,92,	82,103,	
83,104,	9,0,	9,0,	84,105,	
66,93,	66,93,	66,93,	66,93,	
66,93,	66,93,	66,93,	66,93,	
66,93,	66,93,	85,106,	86,107,	
87,108,	88,109,	89,110,	90,111,	
62,92,	91,112,	7,34,	95,51,	
9,0,	9,36,	96,114,	97,115,	
98,116,	9,36,	99,117,	100,79,	
9,36,	9,36,	9,36,	102,118,	
103,119,	104,79,	105,120,	106,121,	
9,0,	9,0,	9,0,	9,0,	
9,0,	9,0,	9,0,	9,0,	
9,0,	9,0,	9,36,	107,122,	
108,123,	9,37,	109,124,	110,125,	
111,126,	9,36,	32,62,	32,62,	
32,62,	32,62,	32,62,	32,62,	
32,62,	32,62,	32,62,	32,62,	
32,62,	32,62,	32,62,	32,62,	
32,62,	32,62,	32,62,	32,62,	
32,62,	32,62,	32,62,	32,62,	
32,62,	32,62,	32,62,	32,62,	
112,51,	114,127,	115,128,	116,79,	
117,94,	9,36,	118,129,	119,51,	
120,130,	121,94,	122,125,	123,51,	
124,131,	126,133,	127,134,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	128,51,	129,135,	131,94,	
133,137,	134,51,	135,94,	9,36,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	137,79,	0,0,	
0,0,	0,0,	16,38,	0,0,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	16,38,	16,38,	
16,38,	16,38,	35,64,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	35,64,	35,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	35,64,	0,0,	
0,0,	0,0,	35,64,	0,0,	
35,65,	35,64,	35,64,	35,64,	
0,0,	0,0,	0,0,	0,0,	
0,0,	35,66,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	35,64,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	35,64,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	35,64,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
35,64,	45,0,	45,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
45,0,	45,73,	45,73,	45,0,	
45,0,	45,0,	45,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
0,0,	45,0,	45,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
45,73,	45,0,	45,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
45,38,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	45,73,	0,0,	
45,0,	45,0,	45,0,	45,0,	
45,0,	45,38,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	45,0,	
45,0,	45,0,	45,0,	0,0,	
45,0,	45,38,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	45,74,	0,0,	0,0,	
0,0,	0,0,	0,0,	45,0,	
45,0,	45,0,	45,0,	45,0,	
51,0,	51,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	51,0,	
51,73,	51,73,	51,0,	51,0,	
51,0,	51,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	0,0,	
51,0,	51,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	51,73,	
51,0,	51,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	51,38,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	51,73,	0,0,	51,0,	
51,0,	51,0,	51,0,	51,0,	
51,38,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	51,0,	51,0,	
51,0,	51,0,	0,0,	51,0,	
51,38,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	51,0,	51,0,	
51,0,	51,0,	51,0,	79,0,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	79,0,	79,101,	
79,101,	79,0,	79,0,	79,0,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	0,0,	79,0,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	79,101,	79,101,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
79,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	79,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	79,0,	79,0,	79,0,	
79,0,	0,0,	79,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	79,0,	79,0,	79,0,	
79,0,	79,0,	94,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	94,0,	94,113,	94,113,	
94,0,	94,0,	94,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	0,0,	94,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	94,113,	94,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	94,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	94,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
94,0,	94,0,	94,0,	94,0,	
0,0,	94,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
94,0,	94,0,	94,0,	94,0,	
94,0,	125,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
125,0,	125,132,	125,132,	125,0,	
125,0,	125,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
0,0,	125,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
125,132,	125,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	125,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
125,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	125,0,	
125,0,	125,0,	125,0,	0,0,	
125,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	125,0,	
125,0,	125,0,	125,0,	125,0,	
130,0,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	130,0,	
130,136,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	0,0,	
130,0,	130,0,	130,0,	130,136,	
130,0,	130,0,	130,0,	130,136,	
130,0,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	130,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	130,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	130,0,	130,0,	
130,0,	130,0,	0,0,	130,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	0,0,	0,0,	
0,0,	0,0,	130,0,	130,0,	
130,0,	130,0,	130,0,	0,0,	
0,0};
struct yysvf yysvec[] ={
0,	0,	0,
yycrank+-1,	0,		0,	
yycrank+-116,	yysvec+1,	0,	
yycrank+0,	0,		yyvstop+1,
yycrank+4,	0,		yyvstop+3,
yycrank+0,	yysvec+4,	yyvstop+6,
yycrank+10,	0,		yyvstop+9,
yycrank+-147,	0,		yyvstop+12,
yycrank+0,	0,		yyvstop+14,
yycrank+-240,	0,		yyvstop+17,
yycrank+7,	0,		yyvstop+21,
yycrank+8,	0,		yyvstop+24,
yycrank+0,	0,		yyvstop+27,
yycrank+11,	0,		yyvstop+30,
yycrank+0,	yysvec+4,	yyvstop+33,
yycrank+12,	0,		yyvstop+36,
yycrank+299,	0,		yyvstop+39,
yycrank+11,	yysvec+16,	yyvstop+42,
yycrank+15,	yysvec+16,	yyvstop+45,
yycrank+33,	yysvec+16,	yyvstop+48,
yycrank+30,	yysvec+16,	yyvstop+51,
yycrank+25,	yysvec+16,	yyvstop+54,
yycrank+24,	yysvec+16,	yyvstop+57,
yycrank+23,	yysvec+16,	yyvstop+60,
yycrank+36,	yysvec+16,	yyvstop+63,
yycrank+25,	yysvec+16,	yyvstop+66,
yycrank+38,	yysvec+16,	yyvstop+69,
yycrank+48,	yysvec+16,	yyvstop+72,
yycrank+19,	yysvec+16,	yyvstop+75,
yycrank+32,	yysvec+16,	yyvstop+78,
yycrank+39,	yysvec+16,	yyvstop+81,
yycrank+23,	0,		yyvstop+84,
yycrank+209,	0,		yyvstop+87,
yycrank+0,	0,		yyvstop+89,
yycrank+28,	0,		0,	
yycrank+-421,	0,		0,	
yycrank+0,	0,		yyvstop+91,
yycrank+0,	0,		yyvstop+93,
yycrank+0,	yysvec+16,	yyvstop+96,
yycrank+33,	yysvec+16,	yyvstop+98,
yycrank+49,	yysvec+16,	yyvstop+100,
yycrank+43,	yysvec+16,	yyvstop+102,
yycrank+66,	yysvec+16,	yyvstop+104,
yycrank+55,	yysvec+16,	yyvstop+106,
yycrank+64,	yysvec+16,	yyvstop+108,
yycrank+-544,	0,		yyvstop+110,
yycrank+53,	yysvec+16,	yyvstop+113,
yycrank+53,	yysvec+16,	yyvstop+115,
yycrank+59,	yysvec+16,	yyvstop+117,
yycrank+57,	yysvec+16,	yyvstop+119,
yycrank+56,	yysvec+16,	yyvstop+121,
yycrank+-671,	0,		yyvstop+123,
yycrank+57,	yysvec+16,	yyvstop+126,
yycrank+64,	yysvec+16,	yyvstop+128,
yycrank+78,	yysvec+16,	yyvstop+130,
yycrank+64,	yysvec+16,	yyvstop+132,
yycrank+60,	yysvec+16,	yyvstop+134,
yycrank+86,	yysvec+16,	yyvstop+136,
yycrank+80,	yysvec+16,	yyvstop+138,
yycrank+74,	yysvec+16,	yyvstop+140,
yycrank+86,	yysvec+16,	yyvstop+142,
yycrank+85,	yysvec+16,	yyvstop+144,
yycrank+236,	yysvec+32,	yyvstop+146,
yycrank+0,	0,		yyvstop+148,
yycrank+0,	yysvec+34,	0,	
yycrank+0,	yysvec+34,	yyvstop+150,
yycrank+204,	0,		0,	
yycrank+81,	yysvec+16,	yyvstop+152,
yycrank+96,	yysvec+16,	yyvstop+154,
yycrank+95,	yysvec+16,	yyvstop+156,
yycrank+83,	yysvec+16,	yyvstop+158,
yycrank+82,	yysvec+16,	yyvstop+160,
yycrank+102,	yysvec+16,	yyvstop+162,
yycrank+0,	0,		yyvstop+164,
yycrank+104,	yysvec+16,	yyvstop+166,
yycrank+102,	yysvec+16,	yyvstop+168,
yycrank+103,	yysvec+16,	yyvstop+170,
yycrank+109,	yysvec+16,	yyvstop+172,
yycrank+97,	yysvec+16,	yyvstop+174,
yycrank+-798,	yysvec+51,	yyvstop+176,
yycrank+108,	yysvec+16,	yyvstop+179,
yycrank+108,	yysvec+16,	yyvstop+181,
yycrank+130,	yysvec+16,	yyvstop+183,
yycrank+134,	yysvec+16,	yyvstop+185,
yycrank+150,	yysvec+16,	yyvstop+187,
yycrank+146,	yysvec+16,	yyvstop+189,
yycrank+146,	yysvec+16,	yyvstop+191,
yycrank+148,	yysvec+16,	yyvstop+193,
yycrank+164,	yysvec+16,	yyvstop+195,
yycrank+155,	yysvec+16,	yyvstop+197,
yycrank+162,	yysvec+16,	yyvstop+199,
yycrank+161,	yysvec+16,	yyvstop+201,
yycrank+0,	0,		yyvstop+203,
yycrank+0,	yysvec+66,	0,	
yycrank+-925,	yysvec+51,	yyvstop+205,
yycrank+164,	yysvec+16,	yyvstop+208,
yycrank+169,	yysvec+16,	yyvstop+210,
yycrank+158,	yysvec+16,	yyvstop+212,
yycrank+168,	yysvec+16,	yyvstop+214,
yycrank+164,	yysvec+16,	yyvstop+216,
yycrank+163,	yysvec+16,	yyvstop+218,
yycrank+0,	0,		yyvstop+220,
yycrank+168,	yysvec+16,	yyvstop+222,
yycrank+170,	yysvec+16,	yyvstop+224,
yycrank+169,	yysvec+16,	yyvstop+226,
yycrank+175,	yysvec+16,	yyvstop+228,
yycrank+182,	yysvec+16,	yyvstop+230,
yycrank+200,	yysvec+16,	yyvstop+232,
yycrank+201,	yysvec+16,	yyvstop+234,
yycrank+202,	yysvec+16,	yyvstop+236,
yycrank+193,	yysvec+16,	yyvstop+238,
yycrank+201,	yysvec+16,	yyvstop+240,
yycrank+231,	yysvec+16,	yyvstop+242,
yycrank+0,	0,		yyvstop+244,
yycrank+223,	yysvec+16,	yyvstop+246,
yycrank+226,	yysvec+16,	yyvstop+248,
yycrank+234,	yysvec+16,	yyvstop+250,
yycrank+226,	yysvec+16,	yyvstop+252,
yycrank+222,	yysvec+16,	yyvstop+254,
yycrank+229,	yysvec+16,	yyvstop+256,
yycrank+238,	yysvec+16,	yyvstop+258,
yycrank+242,	yysvec+16,	yyvstop+260,
yycrank+226,	yysvec+16,	yyvstop+262,
yycrank+239,	yysvec+16,	yyvstop+264,
yycrank+243,	yysvec+16,	yyvstop+266,
yycrank+-1052,	yysvec+51,	yyvstop+268,
yycrank+235,	yysvec+16,	yyvstop+271,
yycrank+229,	yysvec+16,	yyvstop+273,
yycrank+241,	yysvec+16,	yyvstop+275,
yycrank+257,	yysvec+16,	yyvstop+277,
yycrank+-1179,	yysvec+51,	yyvstop+279,
yycrank+257,	yysvec+16,	yyvstop+282,
yycrank+0,	0,		yyvstop+284,
yycrank+259,	yysvec+16,	yyvstop+286,
yycrank+260,	yysvec+16,	yyvstop+288,
yycrank+248,	yysvec+16,	yyvstop+290,
yycrank+0,	0,		yyvstop+292,
yycrank+290,	yysvec+16,	yyvstop+294,
0,	0,	0};
struct yywork *yytop = yycrank+1306;
struct yysvf *yybgin = yysvec+1;
char yymatch[] ={
00  ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
01  ,011 ,012 ,01  ,01  ,01  ,01  ,01  ,
01  ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
01  ,01  ,01  ,01  ,01  ,01  ,01  ,01  ,
011 ,'!' ,01  ,01  ,01  ,'%' ,'!' ,01  ,
'(' ,')' ,'*' ,'%' ,'!' ,'%' ,'!' ,'%' ,
'0' ,'0' ,'0' ,'0' ,'0' ,'0' ,'0' ,'0' ,
'0' ,'0' ,':' ,':' ,'!' ,'!' ,'!' ,'!' ,
01  ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,'A' ,
'A' ,'A' ,'A' ,'!' ,01  ,'!' ,'!' ,'A' ,
01  ,'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,
'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,
'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,'a' ,
'a' ,'a' ,'a' ,'{' ,'!' ,'{' ,'!' ,01  ,
0};
char yyextra[] ={
0,0,0,0,1,0,0,1,
1,1,1,1,1,0,0,0,
0};
/*	ncform	4.1	83/08/11	*/

int yylineno =1;
# define YYU(x) x
# define NLSTATE yyprevious=YYNEWLINE
char yytext[YYLMAX];
struct yysvf *yylstate [YYLMAX], **yylsp, **yyolsp;
char yysbuf[YYLMAX];
char *yysptr = yysbuf;
int *yyfnd;
extern struct yysvf *yyestate;
int yyprevious = YYNEWLINE;
yylook(){
	register struct yysvf *yystate, **lsp;
	register struct yywork *yyt;
	struct yysvf *yyz;
	int yych;
	struct yywork *yyr;
# ifdef LEXDEBUG
	int debug;
# endif
	char *yylastch;
	/* start off machines */
# ifdef LEXDEBUG
	debug = 0;
# endif
	if (!yymorfg)
		yylastch = yytext;
	else {
		yymorfg=0;
		yylastch = yytext+yyleng;
		}
	for(;;){
		lsp = yylstate;
		yyestate = yystate = yybgin;
		if (yyprevious==YYNEWLINE) yystate++;
		for (;;){
# ifdef LEXDEBUG
			if(debug)fprintf(yyout,"state %d\n",yystate-yysvec-1);
# endif
			yyt = yystate->yystoff;
			if(yyt == yycrank){		/* may not be any transitions */
				yyz = yystate->yyother;
				if(yyz == 0)break;
				if(yyz->yystoff == yycrank)break;
				}
			*yylastch++ = yych = input();
		tryagain:
# ifdef LEXDEBUG
			if(debug){
				fprintf(yyout,"char ");
				allprint(yych);
				putchar('\n');
				}
# endif
			yyr = yyt;
			if ( (int)yyt > (int)yycrank){
				yyt = yyr + yych;
				if (yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transitions */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					goto contin;
					}
				}
# ifdef YYOPTIM
			else if((int)yyt < (int)yycrank) {		/* r < yycrank */
				yyt = yyr = yycrank+(yycrank-yyt);
# ifdef LEXDEBUG
				if(debug)fprintf(yyout,"compressed state\n");
# endif
				yyt = yyt + yych;
				if(yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transitions */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					goto contin;
					}
				yyt = yyr + YYU(yymatch[yych]);
# ifdef LEXDEBUG
				if(debug){
					fprintf(yyout,"try fall back character ");
					allprint(YYU(yymatch[yych]));
					putchar('\n');
					}
# endif
				if(yyt <= yytop && yyt->verify+yysvec == yystate){
					if(yyt->advance+yysvec == YYLERR)	/* error transition */
						{unput(*--yylastch);break;}
					*lsp++ = yystate = yyt->advance+yysvec;
					goto contin;
					}
				}
			if ((yystate = yystate->yyother) && (yyt= yystate->yystoff) != yycrank){
# ifdef LEXDEBUG
				if(debug)fprintf(yyout,"fall back to state %d\n",yystate-yysvec-1);
# endif
				goto tryagain;
				}
# endif
			else
				{unput(*--yylastch);break;}
		contin:
# ifdef LEXDEBUG
			if(debug){
				fprintf(yyout,"state %d char ",yystate-yysvec-1);
				allprint(yych);
				putchar('\n');
				}
# endif
			;
			}
# ifdef LEXDEBUG
		if(debug){
			fprintf(yyout,"stopped at %d with ",*(lsp-1)-yysvec-1);
			allprint(yych);
			putchar('\n');
			}
# endif
		while (lsp-- > yylstate){
			*yylastch-- = 0;
			if (*lsp != 0 && (yyfnd= (*lsp)->yystops) && *yyfnd > 0){
				yyolsp = lsp;
				if(yyextra[*yyfnd]){		/* must backup */
					while(yyback((*lsp)->yystops,-*yyfnd) != 1 && lsp > yylstate){
						lsp--;
						unput(*yylastch--);
						}
					}
				yyprevious = YYU(*yylastch);
				yylsp = lsp;
				yyleng = yylastch-yytext+1;
				yytext[yyleng] = 0;
# ifdef LEXDEBUG
				if(debug){
					fprintf(yyout,"\nmatch ");
					sprint(yytext);
					fprintf(yyout," action %d\n",*yyfnd);
					}
# endif
				return(*yyfnd++);
				}
			unput(*yylastch);
			}
		if (yytext[0] == 0  /* && feof(yyin) */)
			{
			yysptr=yysbuf;
			return(0);
			}
		yyprevious = yytext[0] = input();
		if (yyprevious>0)
			output(yyprevious);
		yylastch=yytext;
# ifdef LEXDEBUG
		if(debug)putchar('\n');
# endif
		}
	}
yyback(p, m)
	int *p;
{
if (p==0) return(0);
while (*p)
	{
	if (*p++ == m)
		return(1);
	}
return(0);
}
	/* the following are only used in the lex library */
yyinput(){
	return(input());
	}
yyoutput(c)
  int c; {
	output(c);
	}
yyunput(c)
   int c; {
	unput(c);
	}
