Exemplo n.º 1
0
    def logic_sim(self, input_val_list):
        """
        Logic simulation:
        Reads a given pattern and perform the logic simulation
        """
        node_dict = dict(zip(self.input_num_list, input_val_list))
        self.nodes_sim = self.nodes_lev.copy()
        for i in self.nodes_sim:

            i.D1 = False
            i.D2 = False

            if (i.gtype == 'IPT'):
                if i.num in self.input_num_list:
                    i.value = node_dict[i.num]
            elif (i.gtype == 'BRCH'):
                i.value = i.unodes[0].value
            elif (i.gtype == 'XOR'):
                for j in range(0, i.fin):
                    if j == 0:
                        temp_value = i.unodes[j].value
                    else:
                        temp_value = GXOR(temp_value, i.unodes[j].value)
                i.value = temp_value
            elif (i.gtype == 'OR'):
                for j in range(0, i.fin):
                    if j == 0:
                        temp_value = i.unodes[j].value
                    else:
                        temp_value = GOR(temp_value, i.unodes[j].value)
                i.value = temp_value
            elif (i.gtype == 'NOR'):
                for j in range(0, i.fin):
                    if j == 0:
                        temp_value = i.unodes[j].value
                    else:
                        temp_value = GOR(temp_value, i.unodes[j].value)
                i.value = GNOT(temp_value)
            elif (i.gtype == 'NOT'):
                i.value = GNOT(i.unodes[0].value)
            elif (i.gtype == 'NAND'):
                for j in range(0, i.fin):
                    if j == 0:
                        temp_value = i.unodes[j].value
                    else:
                        temp_value = GAND(temp_value, i.unodes[j].value)
                i.value = GNOT(temp_value)
            elif (i.gtype == 'AND'):
                for j in range(0, i.fin):
                    if j == 0:
                        temp_value = i.unodes[j].value
                    else:
                        temp_value = GAND(temp_value, i.unodes[j].value)
                i.value = temp_value
Exemplo n.º 2
0
def delay_sim(nodelist_order):

    sstalib = read_sstalib("tech10nm.sstalib")
    for i in nodelist_order:
        if (i.gtype == 'IPT'):
            if i.num in node_num:
                i.value = node_dict[i.num]
                # print(node_dict[i.num], i.value)
        elif (i.gtype == 'BRCH'):
            i.value = i.unodes[0].value
            # print("test",i.num,i.value)
        elif (i.gtype == 'XOR'):
            for j in range(0, i.fin):
                if j == 0:
                    temp_value = i.unodes[j].value
                else:
                    temp_value = GXOR(temp_value, i.unodes[j].value)
            i.value = temp_value
        elif (i.gtype == 'OR'):
            for j in range(0, i.fin):
                if j == 0:
                    temp_value = i.unodes[j].value
                else:
                    temp_value = GOR(temp_value, i.unodes[j].value)
            i.value = temp_value
        elif (i.gtype == 'NOR'):
            for j in range(0, i.fin):
                if j == 0:
                    temp_value = i.unodes[j].value
                else:
                    temp_value = GOR(temp_value, i.unodes[j].value)
            i.value = GNOT(temp_value)
        elif (i.gtype == 'NOT'):
            i.value = GNOT(i.unodes[0].value)
        elif (i.gtype == 'NAND'):
            for j in range(0, i.fin):
                if j == 0:
                    temp_value = i.unodes[j].value
                else:
                    temp_value = GAND(temp_value, i.unodes[j].value)
            i.value = GNOT(temp_value)
        elif (i.gtype == 'AND'):
            for j in range(0, i.fin):
                if j == 0:
                    temp_value = i.unodes[j].value
                else:
                    temp_value = GAND(temp_value, i.unodes[j].value)
            i.value = temp_value
Exemplo n.º 3
0
    def logic_sim(self, input_val_list):
        """
        Logic simulation:
        Reads a given pattern and perform the logic simulation
        For now, this is just for binary logic
        """
        node_dict = dict(zip(self.input_num_list, input_val_list))
        # TODO Emergency: why did they make a copy
        # self.nodes_sim = self.nodes_lev.copy()

        for i in self.nodes_lev:

            i.D1 = False
            i.D2 = False

            unodes_val = []
            for unode in i.unodes:
                unodes_val.append(unode.value)

            if (i.gtype == 'IPT'):
                i.value = node_dict[i.num]

            elif (i.gtype == 'BRCH'):
                i.value = i.unodes[0].value

            elif (i.gtype == 'XOR'):
                i.value = GXOR_m(unodes_val)

            elif (i.gtype == 'OR'):
                i.value = GOR_m(unodes_val)

            elif (i.gtype == 'NOR'):
                i.value = GNOR_m(unodes_val)

            elif (i.gtype == 'NOT'):
                i.value = GNOT(i.unodes[0].value)

            elif (i.gtype == 'NAND'):
                i.value = GNAND_m(unodes_val)

            elif (i.gtype == 'AND'):
                i.value = GAND_m(unodes_val)
Exemplo n.º 4
0
    def dfs(self):
        """
        Deductive fault simulation:
        For a given test pattern,
        DFS simulates a set of faults detected by the test pattern.
        Validate the test pattern return by D or Podem
        """
        control = {'AND': 0, 'NAND': 0, 'OR': 1, 'NOR': 1}
        c_list = []
        nc_list = []
        fault_list = set()
        for item in self.nodes_sim:
            if item.gtype == 'IPT':
                item.add_faultlist((item.num, GNOT(item.value)))
                # print(item.num, item.faultlist_dfs)
            elif item.gtype == 'BRCH':
                item.faultlist_dfs = item.unodes[0].faultlist_dfs.copy()
                item.add_faultlist((item.num, GNOT(item.value)))
            elif item.gtype == 'XOR':
                s = set()
                for i in item.unodes:
                    s = s.symmetric_difference(set(i.faultlist_dfs))
                s.add((item.num, GNOT(item.value)))
                item.faultlist_dfs = list(s)
                if item.ntype == 'PO':
                    fault_list = fault_list.union(set(item.faultlist_dfs))
            elif item.gtype == 'NOT':
                item.faultlist_dfs = item.unodes[0].faultlist_dfs.copy()
                item.add_faultlist((item.num, GNOT(item.value)))
                if item.ntype == 'PO':
                    fault_list = fault_list.union(set(item.faultlist_dfs))
            else:  #gtype = gate beside xor
                flag = 0
                # find if input has control value
                for i in item.unodes:
                    c = control[item.gtype]
                    # print(item.num,i.num)
                    if i.value == c:
                        flag = 1
                        c_list.append(i)
                    else:
                        nc_list.append(i)
                # all input is no controlling value
                if flag == 0:
                    s = set()
                    for j in nc_list:
                        s = s.union(set(j.faultlist_dfs))
                    item.faultlist_dfs.clear()
                    item.faultlist_dfs = list(s)
                    item.add_faultlist((item.num, GNOT(item.value)))
                # input has control value
                else:
                    s_control = set(c_list[0].faultlist_dfs)
                    for j in c_list:
                        s_control = s_control.intersection(set(
                            j.faultlist_dfs))
                    if nc_list == []:
                        s_ncontrol = set()
                    else:
                        s_ncontrol = set(nc_list[0].faultlist_dfs)
                        for j in nc_list:
                            s_ncontrol = s_ncontrol.union(set(j.faultlist_dfs))
                    s_control.difference(s_ncontrol)
                    item.faultlist_dfs.clear()
                    item.faultlist_dfs = list(s_control)
                    item.add_faultlist((item.num, GNOT(item.value)))
                c_list.clear()
                nc_list.clear()
                if item.ntype == 'PO':
                    fault_list = fault_list.union(set(item.faultlist_dfs))

        return fault_list