「型別理論與形式證明筆記」修訂間的差異
跳至導覽
跳至搜尋
Tankianting(討論 | 貢獻) |
Tankianting(討論 | 貢獻) |
||
行 40: | 行 40: | ||
若<math display="inline">\exists\sigma\text{ such that }M:\sigma</math>,則<math display="inline">M</math>是可賦予型別的(typable)。 | 若<math display="inline">\exists\sigma\text{ such that }M:\sigma</math>,則<math display="inline">M</math>是可賦予型別的(typable)。 | ||
=== 2.3 Church-typing (explicit typing) 和 Curry-typing (implicit typing) === | |||
# typing à la Church(explicit typing,外顯型別):先給定型別予變數,再推出其他表達式的型別。 | |||
# typing à la Curry(implicit typing,隱藏型別):先給定一個表達式,再推論其內變數可能的型別。 | |||
explicit typing的案例: | |||
設<math display="inline">M \equiv \left( \left( \lambda x.\lambda y.x \right)(u\ v) \right)</math>,如果<math display="inline">v:\alpha \rightarrow \alpha</math>,<math display="inline">u:(\alpha \rightarrow \alpha) \rightarrow \beta</math>,<math display="inline">x:\beta</math>,<math display="inline">y:\gamma</math>,則<math display="inline">M:\gamma \rightarrow \beta</math> | |||
implicit typing的案例(需要用推理和類似合一 (unification) 的方法): <math display="inline">M \equiv \left( \left( \lambda x.\lambda y.x \right)(u\ v) \right)</math>,可以推論: | |||
<math display="inline">v:\alpha</math> | |||
<math display="inline">u:\alpha \rightarrow \beta</math> | |||
<math display="inline">\lambda x.\lambda y.x:\gamma \rightarrow \delta</math> | |||
<math display="inline">x:\gamma</math> | |||
<math display="inline">\lambda y.x:\delta = \varepsilon \rightarrow \zeta</math> | |||
<math display="inline">y:\varepsilon</math> | |||
<math display="inline">x:\gamma = \zeta</math> | |||
<math display="inline">\lambda y.x:\delta = \varepsilon \rightarrow \gamma</math> | |||
<math display="inline">\lambda x.\lambda y.x:\gamma \rightarrow \varepsilon \rightarrow \gamma</math> | |||
<math display="inline">(u\ v):\beta = \gamma</math> | |||
<math display="inline">u:\alpha \rightarrow \gamma</math> | |||
<math display="inline">M:\varepsilon \rightarrow \gamma</math> | |||
但是implicit typing的型別變數,只是一種示例,可以把β用「ω→ω」這種形式取代。 | |||
但是本書常用explicit typing。 | |||
[[category:資訊]] | [[category:資訊]] |
於 2024年7月8日 (一) 22:35 的修訂
ISBN 9781107036505
原標題:Type Theory and Formal Proof: An Introduction
作者:Rob Nederpelt, Herman Geuvers
編輯格式注意
- 章節內文太多的時候,拆成新頁面。
- typst 撰寫 + pandoc 產生貼上於個人維基的內容。
第1章:無型別lambda運算(untyped lambda calculus)
第2章:簡單型別lambda運算(simple typed lambda calculus)
2.2 simple type 簡單型別
型別變數 type variable:用希臘字母表示。
:所有簡單型別,定義如下:
- 型別變數:,表達基本型別,比如list, nat等
- 箭頭型別:
箭頭是右結合的,和函數的apply代入不同。比較和。
註:在本書中, 和 指數學世界的自然數和列表,而nat和list指電腦程式世界的同樣的型別。
「term 有類型(type、型別)」寫成
type有唯一性。比如:若且,則
簡單型別lambda演算的出現的推演規則:
- application(代入):若 且 ,則
- abstration(抽象):若 且 ,則
在這種情況下,因為不可能既是且這種型別存在,所以這種式子不會被構造到。
若,則是可賦予型別的(typable)。
2.3 Church-typing (explicit typing) 和 Curry-typing (implicit typing)
- typing à la Church(explicit typing,外顯型別):先給定型別予變數,再推出其他表達式的型別。
- typing à la Curry(implicit typing,隱藏型別):先給定一個表達式,再推論其內變數可能的型別。
explicit typing的案例:
設,如果,,,,則
implicit typing的案例(需要用推理和類似合一 (unification) 的方法): ,可以推論:
但是implicit typing的型別變數,只是一種示例,可以把β用「ω→ω」這種形式取代。
但是本書常用explicit typing。