Mid3 Revision 3 - PowerPoint PPT Presentation

1 / 88
About This Presentation
Title:

Mid3 Revision 3

Description:

Title: PowerPoint Presentation Author: Lee Last modified by: Computer Science Department Created Date: 5/5/2005 7:33:34 PM Document presentation format – PowerPoint PPT presentation

Number of Views:71
Avg rating:3.0/5.0
Slides: 89
Provided by: Lee
Category:

less

Transcript and Presenter's Notes

Title: Mid3 Revision 3


1
Mid3 Revision 3
Lecture 22
  • Prof. Sin-Min Lee
  • Department of Computer Science

2
(No Transcript)
3
(No Transcript)
4
(No Transcript)
5
(No Transcript)
6
(No Transcript)
7
(No Transcript)
8
(No Transcript)
9
(No Transcript)
10
(No Transcript)
11
(No Transcript)
12
(No Transcript)
13
(No Transcript)
14
(No Transcript)
15
(No Transcript)
16
Flip Flops and Characteristic Tables
Q(t1) D
Q(t1) KQ(t) JQ(t)
Q(t1) TQ(t) TQ(t) T ? Q(t)
17
(No Transcript)
18
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
19
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
20
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.









21
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
J K Q Q D
0 0 0
0 0 1
0 1 0
0 1 1
1 0 0
1 0 1
1 1 0
1 1 1
22
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
J K Q Q D
0 0 0 0
0 0 1 1
0 1 0 0
0 1 1 0
1 0 0 1
1 0 1 1
1 1 0 1
1 1 1 0
23
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
J K Q Q D
0 0 0 0 0
0 0 1 1 1
0 1 0 0 0
0 1 1 0 0
1 0 0 1 1
1 0 1 1 1
1 1 0 1 1
1 1 1 0 0
24
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
J K Q Q D
0 0 0 0 0
0 0 1 1 1
0 1 0 0 0
0 1 1 0 0
1 0 0 1 1
1 0 1 1 1
1 1 0 1 1
1 1 1 0 0
25
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
J K Q Q D
0 0 0 0 0
0 0 1 1 1
0 1 0 0 0
0 1 1 0 0
1 0 0 1 1
1 0 1 1 1
1 1 0 1 1
1 1 1 0 0
K
0 1 0 0
1 1 0 1
J
Q
26
Example
Implement a JK flip-flop using a D flip-flop and
primitive gates.
J K Q Q D
0 0 0 0 0
0 0 1 1 1
0 1 0 0 0
0 1 1 0 0
1 0 0 1 1
1 0 1 1 1
1 1 0 1 1
1 1 1 0 0
K
0 1 0 0
1 1 0 1
J
Q
D Q K Q J
27
(No Transcript)
28
(No Transcript)
29
Y
D Q¹ Q
I
T Q
Clock
30
Start
0
1
0
0
0
0
1
1
0
0
Start
I Q¹ Q Y
31
Clock Cycle 1
0
1
1
1
0
0
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
1
0
1
1
I Q¹ Q Y
32
Clock Cycle 2
0
1
1
1
0
0
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
1
0
1
1
I Q¹ Q Y
33
Clock Cycle 3
1
0
1
1
1
1
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
0
0
1
1
I Q¹ Q Y
34
Clock Cycle 4
1
0
1
1
1
1
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
0
0
1
1
I Q¹ Q Y
35
Clock Cycle 5
0
1
0
1
0
0
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
1
1
0
0
I Q¹ Q Y
36
Clock Cycle 6
0
1
1
1
1
0
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
1
0
0
0
I Q¹ Q Y
37
Clock Cycle 7
0
1
0
1
0
0
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
1
1
0
0
I Q¹ Q Y
38
Clock Cycle 8
0
1
1
1
0
0
Note Q outputs are dependant on the state
of inputs present on the previous cycle.
1
0
1
1
I Q¹ Q Y
39
Some commonly used components
  • Decoders n inputs, 2n outputs.
  • the inputs are used to select which output is
    turned on. At any time exactly one output is on.
  • Multiplexors 2n inputs, n selection bits, 1
    output.
  • the selection bits determine which input will
    become the output.
  • Adder 2n inputs, 2n outputs.
  • Computer Arithmetic.

40
Multiplexer
  • Selects binary information from one of many
    input lines and directs it to a single output
    line.
  • Also known as the selector circuit,
  • Selection is controlled by a particular set of
    inputs lines whose depends on the of the data
    input lines.
  • For a 2n-to-1 multiplexer, there are 2n data
    input lines and n selection lines whose bit
    combination determines which input is selected.

41
MUX
Enable
2n Data Inputs
Data Output
n
Input Select
42
Remember the 2 4 Decoder?
Sel(3)
S1
Sel(2)
Sel(1)
S0
Sel(0)
Mutually Exclusive (Only one O/P asserted at any
time
43
4 to 1 MUX
DataFlow
D3D0
Dout
4
Control
4
2 - 4 Decoder
Sel(30)
2
S1S0
44
4-to-1 MUX (Gate level)
Control Section
Three of these signal inputs will always be 0.
The other will depend on the data value selected
45
Multiplexer (cont.)
  • Until now, we have examined single-bit data
    selected by a MUX. What if we want to select
    m-bit data/words?? Combine MUX blocks in
    parallel with common select and enable signals
  • Example Construct a logic circuit that selects
    between 2 sets of 4-bit inputs (see next slide
    for solution).

46
Example Quad 2-to-1 MUX
  • Uses four 4-to-1 MUXs with common select (S) and
    enable (E).
  • Select line chooses between Ais and Bis. The
    selected four-wire digital signal is sent to the
    Yis
  • Enable line turns MUX on and off (E1 is on).

47
Implementing Boolean functions with Multiplexers
  • Any Boolean function of n variables can be
    implemented using a 2n-1-to-1 multiplexer. A MUX
    is basically a decoder with outputs ORed
    together, hence this isnt surprising.
  • The SELECT signals generate the minterms of the
    function.
  • The data inputs identify which minterms are to be
    combined with an OR.

48
Example
  • F(X,Y,Z) XYZ XYZ XYZ XYZ
    Sm(1,2,6,7)
  • There are n3 inputs, thus we need a 22-to-1 MUX
  • The first n-1 (2) inputs serve as the selection
    lines

49
Efficient Method for implementing Boolean
functions
  • For an n-variable function (e.g., f(A,B,C,D))
  • Need a 2n-1 line MUX with n-1 select lines.
  • Enumerate function as a truth table with
    consistent ordering of variables (e.g., A,B,C,D)
  • Attach the most significant n-1 variables to the
    n-1 select lines (e.g., A,B,C)
  • Examine pairs of adjacent rows (only the least
    significant variable differs, e.g., D0 and D1).
  • Determine whether the function output for the
    (A,B,C,0) and (A,B,C,1) combination is (0,0),
    (0,1), (1,0), or (1,1).
  • Attach 0, D, D, or 1 to the data input
    corresponding to (A,B,C) respectively.

50
Another Example
  • Consider F(A,B,C) ?m(1,3,5,6). We can implement
    this function using a 4-to-1 MUX as follows.
  • The index is ABC. Apply A and B to the S1 and S0
    selection inputs of the MUX (A is most sig, S1 is
    most sig.)
  • Enumerate function in a truth table.

51
MUX Example (cont.)
A B C F
0 0 0 0
0 0 1 1
0 1 0 0
0 1 1 1
1 0 0 0
1 0 1 1
1 1 0 1
1 1 1 0
When AB0, FC
When A0, B1, FC
When A1, B0, FC
When AB1, FC
52
MUX implementation of F(A,B,C) ?m(1,3,5,6)
A
B
C
C
F
C
C
53
2 Input Multiplexor
Inputs I0 and I1 Selector S Output O If S is
a 0 OI0 If S is a 1 OI1
Mux
I0
O
I1
S
54
2-Mux Logic Design
I1
I0
S
I0 !S
O
I1 S
55
4 Input Multiplexor
Inputs I0 I1 I2 I3 Selectors S0 S1 Output O
Mux
I0
I1
O
I2
S0 S1 O
0 0 I0
0 1 I1
1 0 I2
1 1 I3
I3
S0
S1
56
One Possible 4-Mux
2-Decoder
S0
I0
I1
S1
O
I2
I3
57
Adder
  • We want to build a box that can add two 32 bit
    numbers.
  • Assume 2s complement representation
  • We can start by building a 1 bit adder.

58
Addition
  • We need to build a 1 bit adder
  • compute binary addition of 2 bits.
  • We already know that the result is 2 bits.

A B O0 O1
0 0 0 0
0 1 0 1
1 0 0 1
1 1 1 0
This is addition!
A B O0 O1
59
One Implementation
A B
A
O0
B
!A
(!A B) (A !B)
B
O1
A
!B
60
Binary addition and our adder
1
1
Carry
01001 01101
10110
  • What we really want is something that can be used
    to implement the binary addition algorithm.
  • O0 is the carry
  • O1 is the sum

61
What about the second column?
1
1
Carry
01001 01101
10110
  • We are adding 3 bits
  • new bit is the carry from the first column.
  • The output is still 2 bits, a sum and a carry

62
Truth Table for Addition
A B Carry In Carry Out Sum
0 0 0 0 0
0 0 1 0 1
0 1 0 0 1
0 1 1 1 0
1 0 0 0 1
1 0 1 1 0
1 1 0 1 0
1 1 1 1 1
63
Steps in Handling a Page Fault
64
Multiprogramming with Fixed Partitions
0k
  • Divide memory into n (possible unequal)
    partitions.
  • Problem
  • Fragmentation

4k
16k
64k
Free Space
128k
65
Fixed Partitions
Legend
0k
Free Space
4k
16k
Internalfragmentation (cannot be reallocated)
64k
128k
66
Storage Placement Strategies
  • Every placement strategy has its own problem
  • Best fit
  • Creates small holes that cant be used
  • Worst Fit
  • Gets rid of large holes making it difficult to
    run large programs
  • First Fit
  • Creates average size holes

67
Locality of Reference
  • Most memory references confined to small region
  • Well-written program in small loop, procedure or
    function
  • Data likely in array and variables stored
    together
  • Working set
  • Number of pages sufficient to run program
    normally, i.e., satisfy locality of a particular
    program

68
Page Replacement Algorithms
  • Page fault - page is not in memory and must be
    loaded from disk
  • Algorithms to manage swapping
  • First-In, First-Out FIFO Beladys Anomaly
  • Least Recently Used LRU
  • Least Frequently Used LFU
  • Not Used Recently NUR
  • Referenced bit, Modified (dirty) bit
  • Second Chance Replacement algorithms
  • Thrashing
  • too many page faults affect system performance

69
How Bad Is Fragmentation?
  • Statistical arguments - Random sizes
  • First-fit
  • Given N allocated blocks
  • 0.5?N blocks will be lost because of
    fragmentation
  • Known as 50 RULE

70
Solve Fragmentation w. Compaction
Free
Monitor
Job 3
Job 5
Job 6
Job 7
Job 8
5
Free
Monitor
Job 3
Job 5
Job 6
Job 7
Job 8
6
Free
Monitor
Job 3
Job 5
Job 6
Job 7
Job 8
7
Free
Monitor
Job 3
Job 5
Job 6
Job 7
Job 8
8
Free
Monitor
Job 3
Job 5
Job 6
Job 7
Job 8
9
71
Placement Policy
  • Determines where in real memory a process piece
    is to reside
  • Important in a segmentation system
  • Paging or combined paging with segmentation
    hardware performs address translation

72
Replacement Policy
  • Placement Policy
  • Which page is replaced?
  • Page removed should be the page least likely to
    be referenced in the near future
  • Most policies predict the future behavior on the
    basis of past behavior

73
Replacement Policy
  • Frame Locking
  • If frame is locked, it may not be replaced
  • Kernel of the operating system
  • Control structures
  • I/O buffers
  • Associate a lock bit with each frame

74
Basic Replacement Algorithms
  • Optimal policy
  • Selects for replacement that page for which the
    time to the next reference is the longest
  • Impossible to have perfect knowledge of future
    events

75
Basic Replacement Algorithms
  • Least Recently Used (LRU)
  • Replaces the page that has not been referenced
    for the longest time
  • By the principle of locality, this should be the
    page least likely to be referenced in the near
    future
  • Each page could be tagged with the time of last
    reference. This would require a great deal of
    overhead.

76
Basic Replacement Algorithms
  • First-in, first-out (FIFO)
  • Treats page frames allocated to a process as a
    circular buffer
  • Pages are removed in round-robin style
  • Simplest replacement policy to implement
  • Page that has been in memory the longest is
    replaced
  • These pages may be needed again very soon

77
Basic Replacement Algorithms
  • Clock Policy
  • Additional bit called a use bit
  • When a page is first loaded in memory, the use
    bit is set to 1
  • When the page is referenced, the use bit is set
    to 1
  • When it is time to replace a page, the first
    frame encountered with the use bit set to 0 is
    replaced.
  • During the search for replacement, each use bit
    set to 1 is changed to 0

78
(No Transcript)
79
Parallel Organizations - SISD
80
Parallel Organizations - SIMD
81
Parallel Organizations - MIMD Shared Memory
82
Parallel Organizations - MIMDDistributed Memory
83
(No Transcript)
84
Block Diagram of Tightly Coupled Multiprocessor
85
History
  • Cray Research founded in 1972.
  • Cray Computer founded in 1988.
  • 1976 First product Cray-1 (240,000,000 OpS).
    Seymour Cray personally invented vector register
    technology.
  • 1985 Cray-2 (1,200,000,000 OpS, a 5-fold increase
    from Cray 1). Seymour is credited with
    immersion-cooling technology
  • Cray-3 used revolutionary new gallium arsenide
    integrated circuits for the traditional silicon
    ones
  • 1996 Cray was bought by SGI
  • In March 2000 the Cray Research name and business
    was sold by SGI to Tera Inc.

86
(No Transcript)
87
Menu
Explanation
Weather station
Radiosonde
Overview picture
Satellites
Data collection
Radar
Weather ships
Sensors
Supercomputers
Data logging
Parallel Processing
The Grid System
Software
Pressing Weather forecasting on any slide will
bring you back to this menu
Weather forecasting
88
During the last two decades the Met Office
has used state-of-the-art supercomputers for
numerical weather prediction and more recently,
also for predictions of global climate.
This is a picture of a supercomputer
Weather forecasting
Write a Comment
User Comments (0)
About PowerShow.com