【教程】将Python转为C语言并编译生成二进制文件

news/2024/10/17 20:33:37/

转载请注明出处:小锋学长生活大爆炸[xfxuezhang.cn]

本教程以DGL版本的GCN为例,其他也相似。

1、安装cython、gcc:

sudo apt install cython  gcc -y

2、安装DGL、PyTorch:

pip3 install torch torchvision torchaudio
pip install dgl -f https://data.dgl.ai/wheels/cu117/repo.html
pip install dglgo -f https://data.dgl.ai/wheels-test/repo.html

3、编写gcn.py。注意添加# cython: language_level=3,不然默认用的是python2:

# cython: language_level=3import torch
import torch.nn as nn
import torch.nn.functional as F
import dgl
from dgl.data import CoraGraphDataset
from dgl.nn import GraphConv# 定义 GCN 模型
class GCN(nn.Module):def __init__(self, in_feats, h_feats, num_classes):super(GCN, self).__init__()self.conv1 = GraphConv(in_feats, h_feats)self.conv2 = GraphConv(h_feats, num_classes)def forward(self, g, in_feat):h = self.conv1(g, in_feat)h = F.relu(h)h = self.conv2(g, h)return hif __name__ == "__main__":# 加载数据集dataset = CoraGraphDataset()g = dataset[0]# 创建模型实例model = GCN(g.ndata['feat'].shape[1], 16, dataset.num_classes)# 定义损失函数和优化器optimizer = torch.optim.Adam(model.parameters(), lr=0.01)criterion = nn.CrossEntropyLoss()# 训练模型for epoch in range(200):logits = model(g, g.ndata['feat'])loss = criterion(logits[g.ndata['train_mask']], g.ndata['label'][g.ndata['train_mask']])optimizer.zero_grad()loss.backward()optimizer.step()if epoch % 10 == 0:print(f'Epoch {epoch}, Loss: {loss.item()}')# 测试模型model.eval()with torch.no_grad():logits = model(g, g.ndata['feat'])_, predicted = torch.max(logits[g.ndata['test_mask']], 1)correct = (predicted == g.ndata['label'][g.ndata['test_mask']]).sum().item()acc = correct / len(predicted)print(f'Accuracy: {acc:.4f}')

4、使用cython将Python转为C语言,此时会生成一个gcn.c文件。注意要加--embed

cython gcn.py --embed

5、然后使用 C 编译器来编译gcn.c文件,此时会生成一个gcn.o文件:

gcc -c gcn.c `python3-config --includes` `python3-config --ldflags` -o gcn.o

6、链接生成可执行文件,此时会生成一个gcn可执行文件。注意这里-L后面改成你的路径:

gcc gcn.o -L/home/sxf/anaconda3/envs/dgl/lib  -lpython3.9 -o gcn

7、运行二进制可执行文件:

./gcn

8、如果报错:error while loading shared libraries: libpython3.9.so.1.0: cannot open shared object file: No such file or directory。就把这个so文件的路径包含进来,再重新执行步骤7。注意这里后面改成你的路径:

export LD_LIBRARY_PATH=/home/sxf/anaconda3/envs/dgl/lib/:$LD_LIBRARY_PATH 

9、最终效果:

注意:如果你有多个自定义的py文件要import进来,那么自定义的几个py文件需要转为so库文件,来被主文件调用。而如果只有一个py文件,就没有这个问题了。


http://www.ppmy.cn/news/1283234.html

相关文章

Objectiv-C设计模式笔记

文章目录 通用知识点对象创建原型模式定义适用场景示例 工厂方法定义适用场景示例 抽象工厂定义适用场景示例 生成器模式定义适用场景示例 单例模式定义适用场景示例 接口适配适配器定义适用场景示例 桥接定义适用场景示例 外观模式定义适用场景示例 对象去耦中介者定义适用场景…

momentum2靶机

文章妙语 遇事不决,可问春风; 春风不语,遵循己心。 文章目录 文章妙语前言一、信息收集1.IP地址扫描2.端口扫描3.目录扫描 二,漏洞发现分析代码bp爆破1.生成字典2.生成恶意shell.php2.抓包 三,漏洞利用1.反弹shell 四…

CAN协议FPGA篇

一.引言 CAN(Controller Area Network)总线,即控制器局域网总线,是一种功能丰富的车用总线标准。该协议最初是由德国博世(Bosch)公司在1983年制定的,之后在美国密歇根州底特律举行的汽车工程师协…

python产生任意位数随机密码的示例代码

import string rdmstrstring.ascii_lettersstring.digitsstring.punctuation; #依次是26*2个字母,0-9数字,标点符号 import random print(.join([random.choice(rdmstr) for i in range(15)])) #其中把15改为任意整数就可以设置密码长度

Volume Control 2

为游戏添加音乐和音效总是需要一些编码来设置一个系统来控制、显示和保存应用程序的音量设置。 音量控制的设计是为了立即为您设置这些内容,让您有更多时间专注于最重要的事情——制作出色的游戏! 在版本2中,我们对系统进行了重新设计,使其更加模块化、灵活,甚至更易于使用…

Java 面试题集锦记录

Java 面试题集锦记录 一1. SpringBoot、SpringCloud区别2. SpringCloud怎么保证服务间通信?3. Spring怎么保持高可用性、稳定性?4. 负载均衡5. [Rabbitmq](https://blog.csdn.net/qq_40985985/article/details/128013229) 怎么避免重复消费,[…

嵌入式开发——DMA外设到内存

学习目标 加强理解DMA数据传输过程加强掌握DMA的初始化流程掌握DMA数据表查询理解源和目标的配置理解数据传输特点能够动态配置源数据学习内容 需求 uint8_t data; 串口接收(&data);data有数据了 实现串口的数据接收,要求采用dma的方式。 数据交互流程 CPU配置好DMA外…

数模学习02-Matlab基础知识入门

先把matlab下载好。然后你就会发现电脑有少了几十个GB。服啦~ 修改字体 字体真的是太小了,其实我无论是使用什么编辑器我一般都会先改字体,字体在开始中有一个预设,可以修改字体,这样眼睛看着也会舒服一点 命令行窗口的使用 这…