本文整理汇总了Python中field.Field.add_block方法的典型用法代码示例。如果您正苦于以下问题:Python Field.add_block方法的具体用法?Python Field.add_block怎么用?Python Field.add_block使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类field.Field
的用法示例。
在下文中一共展示了Field.add_block方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: Regression
# 需要导入模块: from field import Field [as 别名]
# 或者: from field.Field import add_block [as 别名]
class Regression(unittest.TestCase):
"""High-lvl tests, involving as much as possible"""
def setUp(self):
self.raw_data = [
{'conns': ['net2', 'inp1', 'net1'], 'type': 'pmos', 'name': 'm1',
'groups': [0, 0], 'pos': (4,4), 'rot': 2, 'mir': False},
{'conns': ['outp', 'inp2', 'net1'], 'type': 'pmos', 'name': 'm2',
'groups': [0, 0], 'pos': (6,4), 'rot': 2, 'mir': True},
{'conns': ['vdd', 'vbias1', 'net1'], 'type': 'pmos', 'name': 'm3',
'groups': [0, 0], 'pos': (4,0), 'rot': 0, 'mir': True},
{'conns': ['net2', 'net2', 'gnd'], 'type': 'nmos', 'name': 'm4',
'groups': [0, 1], 'pos': (4,8), 'rot': 0, 'mir': False},
{'conns': ['outp', 'net2', 'gnd'], 'type': 'nmos', 'name': 'm5',
'groups': [0, 1], 'pos': (6,8), 'rot': 0, 'mir': True},
{'conns': ['vbias1', 'vbias1', 'vdd'], 'type': 'pmos', 'name': 'm6',
'groups': [1, 0], 'pos': (2,0), 'rot': 2, 'mir': False},
{'conns': ['vbias2', 'vbias2', 'vbias1'], 'type': 'pmos', 'name': 'm7',
'groups': [1, 0], 'pos': (2,2), 'rot': 2, 'mir': False},
{'conns': ['vdd', 'vbias3'], 'type': 'idc', 'name': 'i2',
'groups': [1, 0], 'pos': (0,0), 'rot': 0, 'mir': False},
{'conns': ['vbias3', 'vbias3', 'vbias4'], 'type': 'nmos', 'name': 'm8',
'groups': [1, 0], 'pos': (0,6), 'rot': 0, 'mir': False},
{'conns': ['vbias2', 'vbias3', 'net3'], 'type': 'nmos', 'name': 'm9',
'groups': [1, 0], 'pos': (2,6), 'rot': 0, 'mir': True},
{'conns': ['vbias4', 'vbias4', 'gnd'], 'type': 'nmos', 'name': 'm10',
'groups': [1, 0], 'pos': (0,8), 'rot': 0, 'mir': False},
{'conns': ['net3', 'vbias4', 'gnd'], 'type': 'nmos', 'name': 'm11',
'groups': [1, 0], 'pos': (2,8), 'rot': 0, 'mir': True},
]
self.field = None
self.maxDiff = None
self.pdf_path = "circuit_draw_test_file.pdf"
self.tempfiles = []
#print "cleaning up old test-pdfs:"
#os.system("rm " + self.pdf_path[:-4] + "*")
def tearDown(self):
#for fn in self.tempfiles:
# if os.path.exists(fn):
# os.unlink(fn)
pass
def get_tempfile(self, num=None):
suffix = num or self.tempfiles
fn_parts = self.pdf_path.split(".")
self.assertTrue(len(fn_parts) == 2)
out = "{}_{}.{}".format(fn_parts[0], suffix, fn_parts[1])
self.tempfiles.append(out)
return out
def test_init_field(self):
self.field = Field("test_circ", 40, 40)
self.assertEqual(self.field.nx, 40)
self.assertEqual(self.field.ny, 40)
def test_add_blocks(self):
self.test_init_field()
for i, b_data in enumerate(self.raw_data):
b = Block(b_data["type"], b_data["conns"], b_data["name"], b_data["groups"])
b.rotate(b_data["rot"])
b.mirror(set_to=b_data["mir"])
self.field.add_block(b, b_data["pos"])
self.assertEqual(len(self.field), len(self.raw_data))
def test_block_move(self):
self.test_add_blocks()
blk = filter(lambda a: a.name == "m3", self.field.get_blocks())
self.assertEqual(len(blk), 1)
blk = blk[0]
pos = (6, 0)
self.assertTrue(self.field.move(blk, pos))
self.assertEqual(self.field.get_block_pos(blk), pos)
def test_block_swap(self):
self.test_add_blocks()
name2blk = dict((b.name, b) for b in self.field.get_blocks())
self.assertTrue(
self.field.swap(name2blk["m1"], name2blk["m2"])
)
#.........这里部分代码省略.........