mirror of
https://github.com/logos-storage/das-research.git
synced 2026-01-02 21:23:09 +00:00
SparseBlock stores only selected rows and columns. Initial implementation without checks and asserts Signed-off-by: Csaba Kiraly <csaba.kiraly@gmail.com>
109 lines
3.0 KiB
Python
109 lines
3.0 KiB
Python
#!/bin/python3
|
|
|
|
import random
|
|
from bitarray import bitarray
|
|
from bitarray.util import zeros
|
|
|
|
class Block:
|
|
|
|
blockSize = 0
|
|
data = bitarray()
|
|
|
|
def __init__(self, size):
|
|
self.blockSize = size
|
|
self.data = zeros(self.blockSize*self.blockSize)
|
|
|
|
def fill(self):
|
|
self.data.setall(1)
|
|
|
|
def merge(self, merged):
|
|
self.data |= merged.data
|
|
|
|
def getColumn(self, columnID):
|
|
return self.data[columnID::self.blockSize]
|
|
|
|
def mergeColumn(self, columnID, column):
|
|
self.data[columnID::self.blockSize] |= column
|
|
|
|
def repairColumn(self, id):
|
|
success = self.data[id::self.blockSize].count(1)
|
|
if success >= self.blockSize/2:
|
|
self.data[id::self.blockSize] = 1
|
|
|
|
def getRow(self, rowID):
|
|
return self.data[rowID*self.blockSize:(rowID+1)*self.blockSize]
|
|
|
|
def mergeRow(self, rowID, row):
|
|
self.data[rowID*self.blockSize:(rowID+1)*self.blockSize] |= row
|
|
|
|
def repairRow(self, id):
|
|
success = self.data[id*self.blockSize:(id+1)*self.blockSize].count(1)
|
|
if success >= self.blockSize/2:
|
|
self.data[id*self.blockSize:(id+1)*self.blockSize] = 1
|
|
|
|
def print(self):
|
|
dash = "-" * (self.blockSize+2)
|
|
print(dash)
|
|
for i in range(self.blockSize):
|
|
line = "|"
|
|
for j in range(self.blockSize):
|
|
line += "%i" % self.data[(i*self.blockSize)+j]
|
|
print(line+"|")
|
|
print(dash)
|
|
|
|
class SparseBlock:
|
|
|
|
def __init__(self, size, rows, columns):
|
|
self.blockSize = size
|
|
self.rows = {r: zeros(self.blockSize) for r in rows}
|
|
self.columns = {r: zeros(self.blockSize) for r in columns}
|
|
|
|
def fill(self):
|
|
for line in self.rows:
|
|
line.setall(1)
|
|
for line in self.columns:
|
|
line.setall(1)
|
|
|
|
def merge(self, merged):
|
|
for id in self.rows:
|
|
self.mergeRow(id, merged.getRow(id))
|
|
for id in self.columns:
|
|
self.mergeColumn(id, merged.getColumn(id))
|
|
|
|
def getColumn(self, id):
|
|
return self.columns[id]
|
|
|
|
def mergeColumn(self, id, column):
|
|
self.columns[id] |= column
|
|
for xid, line in self.rows.items():
|
|
line[id] |= self.columns[id][xid]
|
|
|
|
def repairColumn(self, id):
|
|
success = self.columns[id].count(1)
|
|
if success >= self.blockSize/2:
|
|
self.columns[id].setall(1)
|
|
|
|
def getRow(self, id):
|
|
return self.rows[id]
|
|
|
|
def mergeRow(self, id, row):
|
|
self.rows[id] |= row
|
|
for xid, line in self.columns.items():
|
|
line[id] |= self.rows[id][xid]
|
|
|
|
def repairRow(self, id):
|
|
success = self.rows[id].count(1)
|
|
if success >= self.blockSize/2:
|
|
self.rows[id].setall(1)
|
|
|
|
# def print(self):
|
|
# dash = "-" * (self.blockSize+2)
|
|
# print(dash)
|
|
# for i in range(self.blockSize):
|
|
# line = "|"
|
|
# for j in range(self.blockSize):
|
|
# line += "%i" % self.data[(i*self.blockSize)+j]
|
|
# print(line+"|")
|
|
# print(dash)
|
|
|