当前位置: 首页>>代码示例>>Python>>正文


Python Field.add_block方法代码示例

本文整理汇总了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"])
        )
#.........这里部分代码省略.........
开发者ID:ChristianOAuth,项目名称:schemmaker,代码行数:103,代码来源:regression.py


注:本文中的field.Field.add_block方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。