Project Icon

Endia

面向科学计算的高性能动态数组库

Endia是一个专为科学计算设计的动态数组库,提供类似PyTorch、Numpy和JAX的功能。它支持自动微分、复数运算、双重API接口和JIT编译。Endia可进行命令式和函数式编程,计算任意阶导数,适用于高级科学应用。该项目注重代码清晰度和教育价值,致力于推动AI和科学计算领域的进步。

Endia Stack概念图

Endia是一个用于科学计算的动态数组库,类似于PyTorch、Numpy和JAX。它提供:

  • 自动微分:计算任意阶导数。
  • 复数支持:用Endia进行高级科学应用。
  • 双重API:可选择类似PyTorch的命令式或类似JAX的函数式接口。
  • JIT编译:利用MAX加速训练和推理。

安装

  1. 安装Mojo和MAX 🔥 (v24.4)

  2. 克隆仓库:选择以下选项之一克隆仓库:

    git clone https://github.com/endia-org/Endia.git
    cd Endia
    

    如果您想使用每日(开发)版本,请切换到nightly分支:

    git checkout nightly
    
  3. 设置环境

    chmod +x setup.sh
    ./setup.sh
    

    所需依赖项:torchnumpygraphviz。这些将由安装脚本自动安装。

一个小例子

在本指南中,我们将展示如何计算一个简单函数的梯度黑塞矩阵(即二阶导数)。首先使用Endia的类PyTorch API,然后使用更类似JAX的函数式API。在两个示例中,我们首先定义一个函数foo,它接受一个数组并返回其元素平方和。

PyTorch方式

Endia Logo

使用Endia的命令式(类PyTorch)接口时,我们通过在函数输出上调用backward方法来计算函数的梯度。这种命令式风格需要显式管理计算图,包括为输入数组(即叶节点)设置requires_grad=True,并在计算高阶导数时在backward方法中使用create_graph=True

from endia import Tensor, sum, arange
import endia.autograd.functional as F


# 定义函数
def foo(x: Tensor) -> Tensor:
    return sum(x ** 2)

def main():
    # 初始化变量 - 需要requires_grad=True!
    x = arange(1.0, 4.0, requires_grad=True) # [1.0, 2.0, 3.0]

    # 计算结果、一阶和二阶导数
    y = foo(x)
    y.backward(create_graph=True)            
    dy_dx = x.grad()
    d2y_dx2 = F.grad(outs=sum(dy_dx), inputs=x)[0]

    # 打印结果
    print(y)        # 14.0
    print(dy_dx)    # [2.0, 4.0, 6.0]
    print(d2y_dx2)  # [2.0, 2.0, 2.0]

JAX方式

Endia Logo

使用Endia的函数式(类JAX)接口时,计算图是隐式处理的。通过在foo上调用gradjacobian函数,我们创建一个计算完整雅可比矩阵的Callable。这个Callable可以再次传递给gradjacobian函数以计算高阶导数。

from endia import grad, jacobian
from endia.numpy import sum, arange, ndarray


def foo(x: ndarray) -> ndarray:
    return sum(x**2)


def main():
    # 创建一阶和二阶导数的Callable
    foo_jac = grad(foo)
    foo_hes = jacobian(foo_jac)

    x = arange(1.0, 4.0)       # [1.0, 2.0, 3.0]

    print(foo(x))              # 14.0
    print(foo_jac(x)[ndarray]) # [2.0, 4.0, 6.0]
    print(foo_hes(x)[ndarray]) # [[2.0, 0.0, 0.0], [0.0, 2.0, 0.0], [0.0, 0.0, 2.0]]

还有更多功能!Endia可以处理复值函数,可以执行前向和反向自动微分,甚至内置了JIT编译器来加速运算。在文档中探索完整的功能列表

为什么要另一个ML框架?

  • 🧠 推进AI和科学计算:通过清晰易懂的算法突破界限
  • 🚀 Mojo驱动的清晰性:高性能开源代码始终保持可读性和Python风格
  • 📐 可解释性:优先考虑清晰度和教育价值,而不是exhaustive功能

"生活中没有什么需要害怕,只有需要理解。现在是时候去理解更多,这样我们就能减少恐惧。" - 玛丽·居里

贡献

欢迎对Endia做出贡献!如果您想贡献,请遵循仓库中CONTRIBUTING.md文件中的贡献指南。

引用

如果您在研究或项目中使用Endia,请按以下方式引用:

@software{Fehrenbach_Endia_2024,
  author = {Fehrenbach, Tillmann},
  license = {Apache-2.0 with LLVM Exceptions},
  doi = {10.5281/zenodo.12810766},
  month = jul,
  title = {{Endia}},
  url = {https://github.com/endia-org/Endia},
  version = {24.4.2},
  year = {2024}
}

许可证

Endia根据Apache-2.0 license with LLVM Exeptions许可。

项目侧边栏1项目侧边栏2
推荐项目
Project Cover

豆包MarsCode

豆包 MarsCode 是一款革命性的编程助手,通过AI技术提供代码补全、单测生成、代码解释和智能问答等功能,支持100+编程语言,与主流编辑器无缝集成,显著提升开发效率和代码质量。

Project Cover

AI写歌

Suno AI是一个革命性的AI音乐创作平台,能在短短30秒内帮助用户创作出一首完整的歌曲。无论是寻找创作灵感还是需要快速制作音乐,Suno AI都是音乐爱好者和专业人士的理想选择。

Project Cover

白日梦AI

白日梦AI提供专注于AI视频生成的多样化功能,包括文生视频、动态画面和形象生成等,帮助用户快速上手,创造专业级内容。

Project Cover

Kimi

Kimi AI助手提供多语言对话支持,能够阅读和理解用户上传的文件内容,解析网页信息,并结合搜索结果为用户提供详尽的答案。无论是日常咨询还是专业问题,Kimi都能以友好、专业的方式提供帮助。

Project Cover

有言AI

有言平台提供一站式AIGC视频创作解决方案,通过智能技术简化视频制作流程。无论是企业宣传还是个人分享,有言都能帮助用户快速、轻松地制作出专业级别的视频内容。

Project Cover

讯飞绘镜

讯飞绘镜是一个支持从创意到完整视频创作的智能平台,用户可以快速生成视频素材并创作独特的音乐视频和故事。平台提供多样化的主题和精选作品,帮助用户探索创意灵感。

Project Cover

讯飞文书

讯飞文书依托讯飞星火大模型,为文书写作者提供从素材筹备到稿件撰写及审稿的全程支持。通过录音智记和以稿写稿等功能,满足事务性工作的高频需求,帮助撰稿人节省精力,提高效率,优化工作与生活。

Project Cover

阿里绘蛙

绘蛙是阿里巴巴集团推出的革命性AI电商营销平台。利用尖端人工智能技术,为商家提供一键生成商品图和营销文案的服务,显著提升内容创作效率和营销效果。适用于淘宝、天猫等电商平台,让商品第一时间被种草。

Project Cover

AIWritePaper论文写作

AIWritePaper论文写作是一站式AI论文写作辅助工具,简化了选题、文献检索至论文撰写的整个过程。通过简单设定,平台可快速生成高质量论文大纲和全文,配合图表、参考文献等一应俱全,同时提供开题报告和答辩PPT等增值服务,保障数据安全,有效提升写作效率和论文质量。

投诉举报邮箱: service@vectorlightyear.com
@2024 懂AI·鲁ICP备2024100362号-6·鲁公网安备37021002001498号