Skip to main content
QUICK REVIEW

[論文レビュー] A Theory of Higher-Order Subtyping with Type Intervals (Extended Version)

Sandro Stucki, Paolo G. Giarrusso|arXiv (Cornell University)|Jul 5, 2021
Logic, programming, and type systems参考文献 43被引用数 3
ひとこと要約

この論文は、スカラの高階型のための型区間を備えた高階型のサブタイプ理論 𝐹𝜔·· を導入する。この理論は、境界付き多相性、型演算子、透過的型定義を統合する。𝐹𝜔<: を区間型の種別に拡張することで、複雑な型レベルの抽象化を一貫的かつ型安全に扱えるフレームワークが得られ、Agda を用いた機械的検証による型安全性、種別安全性、および帰納的置換を用いた弱正規化の証明が行われている。

ABSTRACT

The calculus of Dependent Object Types (DOT) has enabled a more principled and robust implementation of Scala, but its support for type-level computation has proven insufficient. As a remedy, we propose $F^\omega_{..}$, a rigorous theoretical foundation for Scala's higher-kinded types. $F^\omega_{..}$ extends $F^\omega_{<:}$ with interval kinds, which afford a unified treatment of important type- and kind-level abstraction mechanisms found in Scala, such as bounded quantification, bounded operator abstractions, translucent type definitions and first-class subtyping constraints. The result is a flexible and general theory of higher-order subtyping. We prove type and kind safety of $F^\omega_{..}$, as well as weak normalization of types and undecidability of subtyping. All our proofs are mechanized in Agda using a fully syntactic approach based on hereditary substitution.

研究の動機と目的

  • スカラの高階型に理論的基盤が欠如している問題に取り組む。これは標準ライブラリで不可欠であるが、DOT計算ではサポートされていない。
  • 境界付き全称型、境界付き型演算子、透過的型定義といった多様な型レベルの抽象化を、一つの形式的枠組みで統一する。
  • 帰納的置換を用いた機械的検証による、サブタイプの構文的基盤を提供する。
  • 一等級のサブタイプ制約と、区間型の導入による依存的種別のサポートを実現する。
  • スカラ3における長年の実装課題を解消するため、型区間を用いた高階型の意味論を形式化する。

提案手法

  • 型変数が下限と上限で制約づけられ、区間 𝐴..𝐵 を形成する区間型の種別を導入することで、𝐹𝜔<: 計算を拡張する。
  • 型不等式を第一級として扱い、束縛形式 𝑋: 𝐴..𝐵 を導入することで、サブタイプ制約を型システムに直接反映する。
  • 帰納的置換に基づく完全な構文的アプローチを採用し、型および種別の還元を形式化することで、置換と型安全性の精確な制御を実現する。
  • Agda を用いてすべての証明を機械的検証し、型安全性、種別安全性、型の弱正規化、サブタイプの不決定性を含む。
  • 区間ベースの抽象化を通じて、境界付き多相性、第一級サブタイプ制約、再帰的型定義といった高度な機能をサポートする。
  • 抽象型演算子とそのサブタイプ規則を仮定することで、交差型、再帰型といった複雑な型システムを区間制約としてエンコードする。

実験結果

リサーチクエスチョン

  • RQ1境界付き多相性、境界付き型演算子、透過的型定義を、一つの高階サブタイプ枠組み内で一貫して形式化する方法は何か?
  • RQ2区間型が、DOT計算がカバーできないスカラの高階型に原理的基盤を提供できるか?
  • RQ3型安全性を損なわずに、高階型システムに第一級サブタイプ制約を統合する方法は何か?
  • RQ4区間型が型システムのメタ理論に与える影響、特に正規化と決定性に関しては何か?
  • RQ5得られるシステムが、区間ベースのエンコードを通じて、交差型や再帰型といった高度な型レベルの抽象化をサポートできるか?

主な発見

  • 𝐹𝜔·· 計算は、区間型を用いて境界付き全称型、境界付き型演算子、透過的型定義を統合する、スカラの高階型の統一的かつ形式的な基盤を提供する。
  • 本システムは型安全かつ種別安全であることが形式的に証明されており、すべての証明が帰納的置換を用いてAgdaで機械的検証されている。
  • 型の弱正規化が確立されており、すべての型還元列が終了することが保証される。
  • 𝐹𝜔·· におけるサブタイプは不決定的であることが示されており、関連するシステムにおけるサブタイプの不決定性への還元によって証明されている。
  • 抽象型演算子とその関連するサブタイプ規則を仮定することで、交差型や再帰型といった高度な型構成子を、区間制約としてエンコードできる。

より良い研究を、今すぐ始めましょう

論文設計から論文執筆まで、研究時間を劇的に削減しましょう。

クレジットカード登録不要

このレビューはAIが作成し、人間の編集者が確認しました。