-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathVirtual_Memory.py
More file actions
90 lines (81 loc) · 2.36 KB
/
Virtual_Memory.py
File metadata and controls
90 lines (81 loc) · 2.36 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
def fifo(pages, capacity):
memory = []
page_faults = 0
for p in pages:
if p not in memory:
page_faults += 1
if len(memory) < capacity:
memory.append(p)
else:
memory.pop(0)
memory.append(p)
return page_faults
def lru(pages, capacity):
memory = []
page_faults = 0
for p in pages:
if p not in memory:
page_faults += 1
if len(memory) < capacity:
memory.append(p)
else:
memory.pop(0)
memory.append(p)
else:
memory.remove(p)
memory.append(p)
return page_faults
def lfu(pages, capacity):
memory = []
freq = {}
page_faults = 0
for p in pages:
freq[p] = freq.get(p, 0) + 1
if p not in memory:
page_faults += 1
if len(memory) < capacity:
memory.append(p)
else:
least_frequent_page = min(memory, key=lambda x: freq[x])
memory.remove(least_frequent_page)
memory.append(p)
return page_faults
def mfu(pages, capacity):
memory = []
freq = {}
page_faults = 0
for p in pages:
freq[p] = freq.get(p, 0) + 1
if p not in memory:
page_faults += 1
if len(memory) < capacity:
memory.append(p)
else:
most_frequent_page = max(memory, key=lambda x: freq[x])
memory.remove(most_frequent_page)
memory.append(p)
return page_faults
def clock(pages, capacity):
memory = [None] * capacity
use_bit = [0] * capacity
pointer = 0
page_faults = 0
for p in pages:
if p in memory:
use_bit[memory.index(p)] = 1
else:
page_faults += 1
while use_bit[pointer] == 1:
use_bit[pointer] = 0
pointer = (pointer + 1) % capacity
memory[pointer] = p
use_bit[pointer] = 1
pointer = (pointer + 1) % capacity
return page_faults
pages = [7, 0, 1, 2, 0, 3, 0, 4, 0, 3, 2, 1, 0, 4, 5]
capacity = 3
print("FIFO:", fifo(pages, capacity))
print("LRU:", lru(pages, capacity))
print("LFU:", lfu(pages, capacity))
print("MFU:", mfu(pages, capacity))
print("Clock:", clock(pages, capacity))