Final Report

advertisement
Expression Evaluating
Calculator
Jagadish Rath(2003cs10164)
Dhanshree Nimje(2003cs10160)
Group 4
Instructor: Prof. M.Balakrishnan
Specifications:
KeyBoard
Interface
Input data
sequence
Restart
evaluation
Digital
Output Data
corresponding to the
input expression and
evaluated value
Calculator
LCD
Display
Reset
Block Diagram of the model
The Digital Calculator takes as input an expression containing
constants(Integer and boolean) ,variables and operators,and evaluates the
expression.While evaluating the expression if it finds a variable which is not
assigned a value, it asks for the value and then gives as output the evaluated
value of the expression.
User Interface:
The user can give the input expression as a sequence of pre-decided
characters from the FPGA keyboard and can see the input expression,the
variable assignment prompt and the evaluated value of the expression on the
LCD Display in FPGA board.
The concrete syntax for the language is given in the next page.
All the expressions involving operators has to be given in postfix notation with
the operands represented as tuples followed by the operator
e.g.
The concrete syntax for 123+ 45 is (123,45)+;
And input sequence is
#*0*1*2*3#*2*4*5#*1#*#0#*3
There will be two inputs from the pushbutton
1.evaluate or re-evaluate an already input expression
2.reset the whole calculator
Syntax
Meaning
Displayformat
*a*b*c*d
number abcd (0<= a,b,c,d <= 9)
abcd
#N
variable numberd N(maximum 10
variables are allowed
the nth in the set {a to j}
#*#N
an operator depending on
N=
*#N
#*N
0 integer addition
+
1 Integersubtraction
-
2 integer multiplication
*
3mod
%
4 integer division
/
5 greaterthan
>
6 boolean and
^
7 boolean not
!
8 boolean or
V
9 equality
=
Boolean value
N= 0 false
N=1 true
F
T
N=0 open parentheses
N=1 closedparentheses
N=2 comma
N=3 end of expression
(
)
,
;
Main-Macros of the Digital Calculator:
1.Keyboard Interface
2.Writer: State Machine which writes into a RAM
3.RAM : It stores the data of the expression
4.Interpreter: State Machine which reads the RAM and generates
corresponding opcodes (for operators),binary number (for integers which are
stored in BCD format in RAM),binary digit(1,0 for boolean constants true,false
respectively).While reading the RAM if it finds a variable it looks for its value
in the TABLE. If it does not find a value for the variable,then it asks for it(which
is displayed on the LCD screen) and then takes the input through Writer and
updates the TABLE.If it finds a value then it generates the binary of the value.
5.TABLE:it is a RAM which stores the value corresponding to the
variable(numbered n) in the nth row.
6.STACK: It is a RAM which has the values corresponding to the expression
evaluated till now.
What ever value is generated by the Interpreter is stored in the stack.When an
opcode is produced by the Interpreter,according to the arity of the operator
corresponding to the opcode those many values are taken from the STACK and
passed on to the MINI-PROCESSOR .
7.MINI-PROCESSOR:It evaluates the values and operator given to it and returns
back the result to the STACK which is then pushed into the STACK.
8.OUTPUT UNIT: uptill the evaluation continues it outputs the data
corresponding to the Input expression to the LCD Display.After completion of
evaluation the result from top of STACK is output to the LCD display.
Data Part:
Give variable value
Value of variable
Input
from
keyboard
interface
Writer
Data to
be
written
RAM
Interpreter
Data to
be
written
Write
opcode
value
Variable to be read
value1
MINIPROCESSOR
value2
Evaluated
value
Wr
TABLE
STACK
OUTPUT
UNIT
Value of
variable
Writer: state diagram
Inputs:star,hash,clk,clear outputs:clstar,clhash,write,ds(6)
States:s0(intial),s1,s2,s3,s4,s5 DefaultOutputs:clstar=1,ds=000001,clhash=0,write=0
s0
*All the transitions
are at rising clk
edge
star
hash
clear
S1
ds=000010,
clstar, write
clear
clear
S3
clear
ds=001000,
clhash, write
clear
star
hash
S5
S2
ds=000100,
clhash, write
ds=100000,
clstar, write
S4
ds=010000,
clhash, write
hash
Simulation Results:
RAM:
The RAM has a word length of 6 and depth 256.Hence the maximum
number of characters that can be stored or evaluated is 256.
Format of storing data:
The 1st two columns say either the data stored is a digit,boolean ,
operator,variable,or special characters
Nature of data
R5 R4 R(3-0)
Digit
0 0
Variable
0 1
value of digit
no of the variable
Operators
10
value of the input key
(
10
1010
)
10
1011
,
10
1100
;
10
1101
Boolean
11
value of the input key
Interpreter:
MINI-PROCESSOR:
The opcodes of any operator is same as the value stored in the
RAM at locations R(3-0) .any other value of the operator is
considered as a nop. When the opcode corresponds to
multiplication or division or mod the complete signal becomes 1
after the operation is complete. Else the complete is always 1.
Components of the MINI PROCESSOR:
1.
DECODER decodes the opcodes
---loader-loads the argument values into the input regesters of
Multiplier and divider
1.
ADDER/SUBTRACTOR does the addition and subtraction
2.
MULTIPLIER does the multiplication
3.
DIVIDER/MOD does the division and mod operation
4.
COMPARATER does the equality and greaterthan check
5.
AND ,OR,NOT
6.
Output multiplexer:outputs the output of appropriate block to output depending
on the opcode
7.
Complete generator : generates the complete signal
Components in the MINI-PROCESSOR:
Add/sub
decoder
multiplier
Divider/mod
loader
comparator
completegenerator
Output multiplexer
Select signal for output mux
possible extensions:
Possible extension:
1.The model can be extended to operate for sequencing of
expressions.
2.The current model is for fixed no of variables it can be
extended for any number of variables.
3. conditional operations like ifthenelse,while,case
operations like exponentiaton,logarithm,trigonometric
functions,real number operations can be included in the
language.
4.The model can be made more user friendly by taking input
from the keyboard of PC.
Download