ichier


Nameichier JSON
Version 0.2.0 PyPI version JSON
download
home_pagehttps://github.com/yeungchie/ichier
SummaryIntegrated Circuit Hierarchy
upload_time2025-01-14 15:58:54
maintainerNone
docs_urlNone
authorYEUNGCHIE
requires_python>=3.8
licenseNone
keywords ichier verilog spice cdl ic hierarchy linux
VCS
bugtrack_url
requirements icutk ply
Travis-CI No Travis.
coveralls test coverage No coveralls.
            <h1 align="center"><span style="color:red"><u>I</u></span>ntegrated <span style="color:red"><u>C</u></span>ircuit <span style="color:red"><u>Hier</u></span>archy</h1>

## 做什么用?

> 懒得写,AI 帮我总结了一下。

`ichier` 是一个用于创建和处理电路设计的 Python 库。它允许用户定义设计、模块、端口和实例,并生成对应的代码。这个库可以用于以下几个方面:

1. **设计创建**:通过 `Design` 和 `Module` 等类,可以构建电路设计,并添加多个模块来实现抽象的对应关系。
2. **终端和网络定义**:可以轻松定义模块之间的连接,通过设置输入输出端口 `Terminal` 和内部网络 `net` 来描述电路的交互。
3. **实例化模块**:允许将模块实例化多次,以便在设计中复用特定的功能,比如在一个电路中多次使用同一个逻辑门。

4. **代码解析**:支持解析 Spice 和 Verilog 格式的电路文件,生成 `Design` 对象,方便分析电路结构和参数,提取设计信息。
5. **命令行交互**:支持在 Python 中启动交互式 shell,方便对电路的信息进行查询。

## 安装

```bash
pip install ichier -U
```

## 描述一个电路

> buffer.py

```python
from ichier import *

design = Design(
    modules=[
        Module(
            name="inv",
            terminals=[
                Terminal(name="A", direction="input"),
                Terminal(name="Z", direction="output"),
            ],
        ),
        Module(
            name="buf",
            terminals=[
                Terminal(
                    name="A",
                    direction="input",
                ),
                Terminal(
                    name="Z",
                    direction="output",
                ),
            ],
            nets=[
                Net(name="A"),
                Net(name="Z"),
                Net(name="inter"),
            ],
            instances=[
                Instance(
                    reference="inv",
                    name="i1",
                    connection={
                        "A": "A",
                        "Z": "inter",
                    },
                    parameters={"size": "x2"},
                ),
                Instance(
                    reference="inv",
                    name="i2",
                    connection={
                        "A": "inter",
                        "Z": "Z",
                    },
                    parameters={"size": "x4"},
                ),
            ],
        ),
    ],
)
```

+ 查询信息

```python
design.modules.figs
# => (Module('inv'), Module('buf'))

buf = design.modules["buf"]

buf.terminals.figs
# => (Terminal('A', 'input'), Terminal('Z', 'output'))

buf.instances.figs
# => (Instance('i1'), Instance('i2'))

buf.nets.figs
# => (Net('A'), Net('Z'), Net('inter'))
```

+ 导出为 Spice

```python
print(design.dumpToSpice())
# .SUBCKT inv A Z
# *.PININFO A:I Z:O
# .ENDS


# .SUBCKT buf A Z
# *.PININFO A:I Z:O
# i1 / inv $PINS A=A Z=inter
# i2 / inv $PINS A=inter Z=Z
# .ENDS
```

## 从网表读入设计

```spice
* top.cdl

.SUBCKT inv A Z
*.PININFO A:I Z:O
.ENDS

.SUBCKT buf A Z
*.PININFO A:I Z:O
i1 / inv $PINS A=A Z=inter
i2 / inv $PINS A=inter Z=Z
.ENDS
```

+ 解析 Spice 文件

```python
from ichier.parser import fromSpice
design = fromSpice("top.cdl")
```

+ 解析 Verilog 文件

```verilog
// top.v

module inv ( input A, output Z );
endmodule

module buf ( input A, output Z );
wire inter;
inv i1 (.A(A), .Z(inter));
inv i2 (.A(inter), .Z(Z));
endmodule
```

```python
from ichier.parser import fromVerilog
design = fromVerilog("top.v")
```

+ 也可以直接使用 CLI 工具

```shell
ichier parse top.v
ichier parse top.cdl
```

> 建议预先安装 `ipython` 和 `rich` 库,会有更好的交互体验。

![parse](./img/parse.gif "Parse")

## LICENSE

GNU Affero General Public License v3

            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/yeungchie/ichier",
    "name": "ichier",
    "maintainer": null,
    "docs_url": null,
    "requires_python": ">=3.8",
    "maintainer_email": null,
    "keywords": "ichier, verilog, spice, cdl, ic, hierarchy, linux",
    "author": "YEUNGCHIE",
    "author_email": "im.yeung.chie@outlook.com",
    "download_url": null,
    "platform": null,
    "description": "<h1 align=\"center\"><span style=\"color:red\"><u>I</u></span>ntegrated <span style=\"color:red\"><u>C</u></span>ircuit <span style=\"color:red\"><u>Hier</u></span>archy</h1>\r\n\r\n## \u505a\u4ec0\u4e48\u7528\uff1f\r\n\r\n> \u61d2\u5f97\u5199\uff0cAI \u5e2e\u6211\u603b\u7ed3\u4e86\u4e00\u4e0b\u3002\r\n\r\n`ichier` \u662f\u4e00\u4e2a\u7528\u4e8e\u521b\u5efa\u548c\u5904\u7406\u7535\u8def\u8bbe\u8ba1\u7684 Python \u5e93\u3002\u5b83\u5141\u8bb8\u7528\u6237\u5b9a\u4e49\u8bbe\u8ba1\u3001\u6a21\u5757\u3001\u7aef\u53e3\u548c\u5b9e\u4f8b\uff0c\u5e76\u751f\u6210\u5bf9\u5e94\u7684\u4ee3\u7801\u3002\u8fd9\u4e2a\u5e93\u53ef\u4ee5\u7528\u4e8e\u4ee5\u4e0b\u51e0\u4e2a\u65b9\u9762\uff1a\r\n\r\n1. **\u8bbe\u8ba1\u521b\u5efa**\uff1a\u901a\u8fc7 `Design` \u548c `Module` \u7b49\u7c7b\uff0c\u53ef\u4ee5\u6784\u5efa\u7535\u8def\u8bbe\u8ba1\uff0c\u5e76\u6dfb\u52a0\u591a\u4e2a\u6a21\u5757\u6765\u5b9e\u73b0\u62bd\u8c61\u7684\u5bf9\u5e94\u5173\u7cfb\u3002\r\n2. **\u7ec8\u7aef\u548c\u7f51\u7edc\u5b9a\u4e49**\uff1a\u53ef\u4ee5\u8f7b\u677e\u5b9a\u4e49\u6a21\u5757\u4e4b\u95f4\u7684\u8fde\u63a5\uff0c\u901a\u8fc7\u8bbe\u7f6e\u8f93\u5165\u8f93\u51fa\u7aef\u53e3 `Terminal` \u548c\u5185\u90e8\u7f51\u7edc `net` \u6765\u63cf\u8ff0\u7535\u8def\u7684\u4ea4\u4e92\u3002\r\n3. **\u5b9e\u4f8b\u5316\u6a21\u5757**\uff1a\u5141\u8bb8\u5c06\u6a21\u5757\u5b9e\u4f8b\u5316\u591a\u6b21\uff0c\u4ee5\u4fbf\u5728\u8bbe\u8ba1\u4e2d\u590d\u7528\u7279\u5b9a\u7684\u529f\u80fd\uff0c\u6bd4\u5982\u5728\u4e00\u4e2a\u7535\u8def\u4e2d\u591a\u6b21\u4f7f\u7528\u540c\u4e00\u4e2a\u903b\u8f91\u95e8\u3002\r\n\r\n4. **\u4ee3\u7801\u89e3\u6790**\uff1a\u652f\u6301\u89e3\u6790 Spice \u548c Verilog \u683c\u5f0f\u7684\u7535\u8def\u6587\u4ef6\uff0c\u751f\u6210 `Design` \u5bf9\u8c61\uff0c\u65b9\u4fbf\u5206\u6790\u7535\u8def\u7ed3\u6784\u548c\u53c2\u6570\uff0c\u63d0\u53d6\u8bbe\u8ba1\u4fe1\u606f\u3002\r\n5. **\u547d\u4ee4\u884c\u4ea4\u4e92**\uff1a\u652f\u6301\u5728 Python \u4e2d\u542f\u52a8\u4ea4\u4e92\u5f0f shell\uff0c\u65b9\u4fbf\u5bf9\u7535\u8def\u7684\u4fe1\u606f\u8fdb\u884c\u67e5\u8be2\u3002\r\n\r\n## \u5b89\u88c5\r\n\r\n```bash\r\npip install ichier -U\r\n```\r\n\r\n## \u63cf\u8ff0\u4e00\u4e2a\u7535\u8def\r\n\r\n> buffer.py\r\n\r\n```python\r\nfrom ichier import *\r\n\r\ndesign = Design(\r\n    modules=[\r\n        Module(\r\n            name=\"inv\",\r\n            terminals=[\r\n                Terminal(name=\"A\", direction=\"input\"),\r\n                Terminal(name=\"Z\", direction=\"output\"),\r\n            ],\r\n        ),\r\n        Module(\r\n            name=\"buf\",\r\n            terminals=[\r\n                Terminal(\r\n                    name=\"A\",\r\n                    direction=\"input\",\r\n                ),\r\n                Terminal(\r\n                    name=\"Z\",\r\n                    direction=\"output\",\r\n                ),\r\n            ],\r\n            nets=[\r\n                Net(name=\"A\"),\r\n                Net(name=\"Z\"),\r\n                Net(name=\"inter\"),\r\n            ],\r\n            instances=[\r\n                Instance(\r\n                    reference=\"inv\",\r\n                    name=\"i1\",\r\n                    connection={\r\n                        \"A\": \"A\",\r\n                        \"Z\": \"inter\",\r\n                    },\r\n                    parameters={\"size\": \"x2\"},\r\n                ),\r\n                Instance(\r\n                    reference=\"inv\",\r\n                    name=\"i2\",\r\n                    connection={\r\n                        \"A\": \"inter\",\r\n                        \"Z\": \"Z\",\r\n                    },\r\n                    parameters={\"size\": \"x4\"},\r\n                ),\r\n            ],\r\n        ),\r\n    ],\r\n)\r\n```\r\n\r\n+ \u67e5\u8be2\u4fe1\u606f\r\n\r\n```python\r\ndesign.modules.figs\r\n# => (Module('inv'), Module('buf'))\r\n\r\nbuf = design.modules[\"buf\"]\r\n\r\nbuf.terminals.figs\r\n# => (Terminal('A', 'input'), Terminal('Z', 'output'))\r\n\r\nbuf.instances.figs\r\n# => (Instance('i1'), Instance('i2'))\r\n\r\nbuf.nets.figs\r\n# => (Net('A'), Net('Z'), Net('inter'))\r\n```\r\n\r\n+ \u5bfc\u51fa\u4e3a Spice\r\n\r\n```python\r\nprint(design.dumpToSpice())\r\n# .SUBCKT inv A Z\r\n# *.PININFO A:I Z:O\r\n# .ENDS\r\n\r\n\r\n# .SUBCKT buf A Z\r\n# *.PININFO A:I Z:O\r\n# i1 / inv $PINS A=A Z=inter\r\n# i2 / inv $PINS A=inter Z=Z\r\n# .ENDS\r\n```\r\n\r\n## \u4ece\u7f51\u8868\u8bfb\u5165\u8bbe\u8ba1\r\n\r\n```spice\r\n* top.cdl\r\n\r\n.SUBCKT inv A Z\r\n*.PININFO A:I Z:O\r\n.ENDS\r\n\r\n.SUBCKT buf A Z\r\n*.PININFO A:I Z:O\r\ni1 / inv $PINS A=A Z=inter\r\ni2 / inv $PINS A=inter Z=Z\r\n.ENDS\r\n```\r\n\r\n+ \u89e3\u6790 Spice \u6587\u4ef6\r\n\r\n```python\r\nfrom ichier.parser import fromSpice\r\ndesign = fromSpice(\"top.cdl\")\r\n```\r\n\r\n+ \u89e3\u6790 Verilog \u6587\u4ef6\r\n\r\n```verilog\r\n// top.v\r\n\r\nmodule inv ( input A, output Z );\r\nendmodule\r\n\r\nmodule buf ( input A, output Z );\r\nwire inter;\r\ninv i1 (.A(A), .Z(inter));\r\ninv i2 (.A(inter), .Z(Z));\r\nendmodule\r\n```\r\n\r\n```python\r\nfrom ichier.parser import fromVerilog\r\ndesign = fromVerilog(\"top.v\")\r\n```\r\n\r\n+ \u4e5f\u53ef\u4ee5\u76f4\u63a5\u4f7f\u7528 CLI \u5de5\u5177\r\n\r\n```shell\r\nichier parse top.v\r\nichier parse top.cdl\r\n```\r\n\r\n> \u5efa\u8bae\u9884\u5148\u5b89\u88c5 `ipython` \u548c `rich` \u5e93\uff0c\u4f1a\u6709\u66f4\u597d\u7684\u4ea4\u4e92\u4f53\u9a8c\u3002\r\n\r\n![parse](./img/parse.gif \"Parse\")\r\n\r\n## LICENSE\r\n\r\nGNU Affero General Public License v3\r\n",
    "bugtrack_url": null,
    "license": null,
    "summary": "Integrated Circuit Hierarchy",
    "version": "0.2.0",
    "project_urls": {
        "Homepage": "https://github.com/yeungchie/ichier"
    },
    "split_keywords": [
        "ichier",
        " verilog",
        " spice",
        " cdl",
        " ic",
        " hierarchy",
        " linux"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "4fcc1e882d81518cc8243f9d8405afaea96f0c7166bc484dc6b95b4c432b324b",
                "md5": "28c12183f4feb7af3effaef9f5c26881",
                "sha256": "e7ccc927b5bc5ea2063f287cfc1855706c5d924e340655dc9903b58a9e7a909b"
            },
            "downloads": -1,
            "filename": "ichier-0.2.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "28c12183f4feb7af3effaef9f5c26881",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.8",
            "size": 45684,
            "upload_time": "2025-01-14T15:58:54",
            "upload_time_iso_8601": "2025-01-14T15:58:54.367397Z",
            "url": "https://files.pythonhosted.org/packages/4f/cc/1e882d81518cc8243f9d8405afaea96f0c7166bc484dc6b95b4c432b324b/ichier-0.2.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2025-01-14 15:58:54",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "yeungchie",
    "github_project": "ichier",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [
        {
            "name": "icutk",
            "specs": [
                [
                    ">=",
                    "0.3.7"
                ]
            ]
        },
        {
            "name": "ply",
            "specs": [
                [
                    ">=",
                    "3.11"
                ]
            ]
        }
    ],
    "lcname": "ichier"
}
        
Elapsed time: 1.99936s