首页
/ 探秘红色立方体:redtt - 实现卡特尔立方型类型理论的创新之作

探秘红色立方体:redtt - 实现卡特尔立方型类型理论的创新之作

2024-05-29 22:08:47作者:董灵辛Dennis

项目介绍

redtt 是一种核心语言,专为卡特尔立方型类型理论(Cartesian Cubical Type Theory)设计,并加入了扩展类型的概念。其目标是构建一个可扩展的交互式证明助手,借鉴了RedPRL、Epigram 和 Idris 等著名证明助手的思想。与之相关的项目包括yaccttRedPRLcubicaltt

项目技术分析

redtt 提供了一系列引人注目的特性:

  • 路径类型:通过更通用的扩展类型来定义,可以一次性指定 n 维立方体的所有边界。

  • 带有隐含参数的源语言:基于立方体版本的高阶统一性。

  • 累积的、统一的宇宙层次:这是一种预判性的层次结构。

  • McBride 的“粗糙但有效分类法”:用于实现水平多态性定义。

  • 两层类型理论:目前只有先行类型和(Kan)类型。未来计划添加精确相等类型的解释,这些将与路径类型并存,就像 RedPRL 中那样。

  • 用户自定义的(参数化的)高归纳类型:基于Evan Cavallo和Bob Harper的工作,不支持索引HITs。

  • 红ML,一个初级战术语言

未来的开发计划还包括命名空间、索引高归纳类型以及红ML的类型系统和代数效果处理器。

技术应用场景

redtt 可广泛应用于数学形式化验证、高级编程和逻辑领域。它提供的高维度类型理论工具,对于研究和实现复杂的数学定理和程序结构极具价值。此外,它的两层类型理论和扩展类型等功能也适用于编写高效、强类型、安全的代码。

项目特点

  • 易扩展:该项目致力于构建一个互动式的证明助手,允许用户自定义高归纳类型和战术语言,提供了广泛的拓展可能性。

  • 理论基础扎实:基于卡特尔立方型类型理论,结合了多个现有系统的优点。

  • 清晰的开发路线图:项目维护者列出了详细的贡献指南和待完成任务,为社区参与提供了明确的方向。

  • 强大的库支持redtt 包括一个单独的数学库,为用户提供了一个丰富的起点。

  • 兼容性:尽管依赖于特定的 OCaml 版本,但 redtt 在安装和升级方面尽量保持简单明了,便于新手上手。

要开始体验这个项目,只需按照文中的安装步骤进行操作,然后利用提供的编译工具和交互式环境开始你的探索之旅。

总的来说,无论你是研究理论计算机科学,还是寻找新的编程范式,redtt 都是一个值得尝试的开源项目,等待着你的发掘和贡献。

项目优选

收起
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
33
24
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
831
0
redis-sdkredis-sdk
仓颉语言实现的Redis客户端SDK。已适配仓颉0.53.4 Beta版本。接口设计兼容jedis接口语义,支持RESP2和RESP3协议,支持发布订阅模式,支持哨兵模式和集群模式。
Cangjie
376
32
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
75.92 K
19.09 K
RuoYi-VueRuoYi-Vue
🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
147
26
Yi-CoderYi-Coder
Yi Coder 编程模型,小而强大的编程助手
HTML
57
7
easy-eseasy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
19
2
杨帆测试平台杨帆测试平台
扬帆测试平台是一款高效、可靠的自动化测试平台,旨在帮助团队提升测试效率、降低测试成本。该平台包括用例管理、定时任务、执行记录等功能模块,支持多种类型的测试用例,目前支持API(http和grpc协议)、性能、CI调用等功能,并且可定制化,灵活满足不同场景的需求。 其中,支持批量执行、并发执行等高级功能。通过用例设置,可以设置用例的基本信息、运行配置、环境变量等,灵活控制用例的执行。
JavaScript
9
1
qwerty-learnerqwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
15.63 K
1.45 K
anqicmsanqicms
AnQiCMS 是一款基于Go语言开发,具备高安全性、高性能和易扩展性的企业级内容管理系统。它支持多站点、多语言管理,能够满足全球化跨境运营需求。AnQiCMS 提供灵活的内容发布和模板管理功能,同时,系统内置丰富的利于SEO操作的功能,帮助企业简化运营和内容管理流程。AnQiCMS 将成为您建站的理想选择,在不断变化的市场中保持竞争力。
Go
78
5