Complex Embeddings 开源项目教程
1. 项目介绍
本项目是基于论文《Complex Embeddings for Simple Link Prediction》和《Knowledge Graph Completion via Complex Tensor Factorization》的开源实现。项目通过复数嵌入技术,对知识图谱中的链接预测和完整性补全任务提供了一种新的解决方案。它包含了多种嵌入模型,如ComplEx、DistMult、TransE、RESCAL和CP模型,并在多个数据集上进行了验证。
2. 项目快速启动
首先,您需要克隆项目仓库:
git clone https://github.com/ttrouill/complex.git
接着,安装项目依赖:
pip install -r requirements.txt
项目兼容Python 2和3。为了运行实验,您需要解压数据集:
unzip datasets/fb15k.zip -d datasets/
unzip datasets/wn18.zip -d datasets/
然后,运行相应的Python脚本来执行实验。以下是运行FB15K数据集的ComplEx模型的示例:
python fb15k_run.py
如果要在GPU上运行以加快速度,可以在Python调用前添加Theano标志:
THEANO_FLAGS='device=gpu' python fb15k_run.py
3. 应用案例和最佳实践
3.1 保存模型生成的嵌入
如果您想保存模型生成的嵌入,只需取消注释fb15k_run.py和wn18_run.py中的最后几行代码,并确保导入了scipy.io模块。这将把ComplEx模型的嵌入保存为MATLAB的.mat格式。
3.2 在自己的数据上运行
要将自己的数据用于模型,需在datasets文件夹中创建一个子文件夹,并将数据分为三个文件:train.txt、valid.txt和test.txt。每行包含一个三元组,格式为:
subject_entity_id relation_id object_entity_id
之后,修改fb15k_run.py文件中的build_data函数调用,以使用您的数据集:
fb15kexp = build_data(name='your_dataset_folder_name', path=tools.cur_path + '/datasets/')
3.3 实现自己的模型
如果需要实现自己的模型,可以在models.py中定义新的类,继承Abstract_Model。需要重写get_init_params(self)和define_loss(self)方法来定义模型的参数初始化和损失函数。
4. 典型生态项目
目前,此项目是独立的,没有特别提到与其他开源项目的集成。但是,它可以使用Theano等深度学习库,并且可以与其他知识图谱处理工具结合使用,以构建更完整的应用生态系统。
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0151- DDeepSeek-V4-ProDeepSeek-V4-Pro(总参数 1.6 万亿,激活 49B)面向复杂推理和高级编程任务,在代码竞赛、数学推理、Agent 工作流等场景表现优异,性能接近国际前沿闭源模型。Python00
LongCat-Video-Avatar-1.5最新开源LongCat-Video-Avatar 1.5 版本,这是一款经过升级的开源框架,专注于音频驱动人物视频生成的极致实证优化与生产级就绪能力。该版本在 LongCat-Video 基础模型之上构建,可生成高度稳定的商用级虚拟人视频,支持音频-文本转视频(AT2V)、音频-文本-图像转视频(ATI2V)以及视频续播等原生任务,并能无缝兼容单流与多流音频输入。00
auto-devAutoDev 是一个 AI 驱动的辅助编程插件。AutoDev 支持一键生成测试、代码、提交信息等,还能够与您的需求管理系统(例如Jira、Trello、Github Issue 等)直接对接。 在IDE 中,您只需简单点击,AutoDev 会根据您的需求自动为您生成代码。Kotlin03
Intern-S2-PreviewIntern-S2-Preview,这是一款高效的350亿参数科学多模态基础模型。除了常规的参数与数据规模扩展外,Intern-S2-Preview探索了任务扩展:通过提升科学任务的难度、多样性与覆盖范围,进一步释放模型能力。Python00
skillhubopenJiuwen 生态的 Skill 托管与分发开源方案,支持自建与可选 ClawHub 兼容。Python0112