Suche senden
Hochladen
証明プログラミング超入門
•
28 gefällt mir
•
11,071 views
Kyoko Kadowaki
Folgen
20150124若手の会@明治大学中野キャンパス
Weniger lesen
Mehr lesen
Wissenschaft
Melden
Teilen
Melden
Teilen
1 von 21
Jetzt herunterladen
Downloaden Sie, um offline zu lesen
Empfohlen
SAT/SMTソルバの仕組み
SAT/SMTソルバの仕組み
Masahiro Sakai
最適輸送の解き方
最適輸送の解き方
joisino
証明プログラミング入門2
証明プログラミング入門2
Kyoko Kadowaki
プログラミングコンテストでの動的計画法
プログラミングコンテストでの動的計画法
Takuya Akiba
プログラミングコンテストでのデータ構造 2 ~動的木編~
プログラミングコンテストでのデータ構造 2 ~動的木編~
Takuya Akiba
明日使えないすごいビット演算
明日使えないすごいビット演算
京大 マイコンクラブ
数学カフェ 確率・統計・機械学習回 「速習 確率・統計」
数学カフェ 確率・統計・機械学習回 「速習 確率・統計」
Ken'ichi Matsui
自動定理証明の紹介
自動定理証明の紹介
Masahiro Sakai
Empfohlen
SAT/SMTソルバの仕組み
SAT/SMTソルバの仕組み
Masahiro Sakai
最適輸送の解き方
最適輸送の解き方
joisino
証明プログラミング入門2
証明プログラミング入門2
Kyoko Kadowaki
プログラミングコンテストでの動的計画法
プログラミングコンテストでの動的計画法
Takuya Akiba
プログラミングコンテストでのデータ構造 2 ~動的木編~
プログラミングコンテストでのデータ構造 2 ~動的木編~
Takuya Akiba
明日使えないすごいビット演算
明日使えないすごいビット演算
京大 マイコンクラブ
数学カフェ 確率・統計・機械学習回 「速習 確率・統計」
数学カフェ 確率・統計・機械学習回 「速習 確率・統計」
Ken'ichi Matsui
自動定理証明の紹介
自動定理証明の紹介
Masahiro Sakai
Python 3.9からの新定番zoneinfoを使いこなそう
Python 3.9からの新定番zoneinfoを使いこなそう
Ryuji Tsutsui
劣モジュラ最適化と機械学習1章
劣モジュラ最適化と機械学習1章
Hakky St
「型の理論」と証明支援システム -- COQの世界
「型の理論」と証明支援システム -- COQの世界
maruyama097
機械学習による統計的実験計画(ベイズ最適化を中心に)
機械学習による統計的実験計画(ベイズ最適化を中心に)
Kota Matsui
圏論のモナドとHaskellのモナド
圏論のモナドとHaskellのモナド
Yoshihiro Mizoguchi
幾何と機械学習: A Short Intro
幾何と機械学習: A Short Intro
Ichigaku Takigawa
最適輸送入門
最適輸送入門
joisino
Chokudai search
Chokudai search
AtCoder Inc.
Word Tour: One-dimensional Word Embeddings via the Traveling Salesman Problem...
Word Tour: One-dimensional Word Embeddings via the Traveling Salesman Problem...
joisino
Marp Tutorial
Marp Tutorial
Rui Watanabe
CuPy解説
CuPy解説
Ryosuke Okuta
Rustに触れて私のPythonはどう変わったか
Rustに触れて私のPythonはどう変わったか
ShunsukeNakamura17
最適輸送の計算アルゴリズムの研究動向
最適輸送の計算アルゴリズムの研究動向
ohken
ウェーブレット木の世界
ウェーブレット木の世界
Preferred Networks
最適化超入門
最適化超入門
Takami Sato
【解説】 一般逆行列
【解説】 一般逆行列
Kenjiro Sugimoto
第10回 配信講義 計算科学技術特論A(2021)
第10回 配信講義 計算科学技術特論A(2021)
RCCSRENKEI
【DL輪読会】Semi-Parametric Neural Image Synthesis
【DL輪読会】Semi-Parametric Neural Image Synthesis
Deep Learning JP
技術者が知るべき Gröbner 基底
技術者が知るべき Gröbner 基底
Hiromi Ishii
平面グラフと交通ネットワークのアルゴリズム
平面グラフと交通ネットワークのアルゴリズム
Takuya Akiba
すごいCoq入門
すごいCoq入門
真一 北原
Anomaly Detector で遊ぼう♪ with Azure Time Series Insights
Anomaly Detector で遊ぼう♪ with Azure Time Series Insights
Kazumi IWANAGA
Weitere ähnliche Inhalte
Was ist angesagt?
Python 3.9からの新定番zoneinfoを使いこなそう
Python 3.9からの新定番zoneinfoを使いこなそう
Ryuji Tsutsui
劣モジュラ最適化と機械学習1章
劣モジュラ最適化と機械学習1章
Hakky St
「型の理論」と証明支援システム -- COQの世界
「型の理論」と証明支援システム -- COQの世界
maruyama097
機械学習による統計的実験計画(ベイズ最適化を中心に)
機械学習による統計的実験計画(ベイズ最適化を中心に)
Kota Matsui
圏論のモナドとHaskellのモナド
圏論のモナドとHaskellのモナド
Yoshihiro Mizoguchi
幾何と機械学習: A Short Intro
幾何と機械学習: A Short Intro
Ichigaku Takigawa
最適輸送入門
最適輸送入門
joisino
Chokudai search
Chokudai search
AtCoder Inc.
Word Tour: One-dimensional Word Embeddings via the Traveling Salesman Problem...
Word Tour: One-dimensional Word Embeddings via the Traveling Salesman Problem...
joisino
Marp Tutorial
Marp Tutorial
Rui Watanabe
CuPy解説
CuPy解説
Ryosuke Okuta
Rustに触れて私のPythonはどう変わったか
Rustに触れて私のPythonはどう変わったか
ShunsukeNakamura17
最適輸送の計算アルゴリズムの研究動向
最適輸送の計算アルゴリズムの研究動向
ohken
ウェーブレット木の世界
ウェーブレット木の世界
Preferred Networks
最適化超入門
最適化超入門
Takami Sato
【解説】 一般逆行列
【解説】 一般逆行列
Kenjiro Sugimoto
第10回 配信講義 計算科学技術特論A(2021)
第10回 配信講義 計算科学技術特論A(2021)
RCCSRENKEI
【DL輪読会】Semi-Parametric Neural Image Synthesis
【DL輪読会】Semi-Parametric Neural Image Synthesis
Deep Learning JP
技術者が知るべき Gröbner 基底
技術者が知るべき Gröbner 基底
Hiromi Ishii
平面グラフと交通ネットワークのアルゴリズム
平面グラフと交通ネットワークのアルゴリズム
Takuya Akiba
Was ist angesagt?
(20)
Python 3.9からの新定番zoneinfoを使いこなそう
Python 3.9からの新定番zoneinfoを使いこなそう
劣モジュラ最適化と機械学習1章
劣モジュラ最適化と機械学習1章
「型の理論」と証明支援システム -- COQの世界
「型の理論」と証明支援システム -- COQの世界
機械学習による統計的実験計画(ベイズ最適化を中心に)
機械学習による統計的実験計画(ベイズ最適化を中心に)
圏論のモナドとHaskellのモナド
圏論のモナドとHaskellのモナド
幾何と機械学習: A Short Intro
幾何と機械学習: A Short Intro
最適輸送入門
最適輸送入門
Chokudai search
Chokudai search
Word Tour: One-dimensional Word Embeddings via the Traveling Salesman Problem...
Word Tour: One-dimensional Word Embeddings via the Traveling Salesman Problem...
Marp Tutorial
Marp Tutorial
CuPy解説
CuPy解説
Rustに触れて私のPythonはどう変わったか
Rustに触れて私のPythonはどう変わったか
最適輸送の計算アルゴリズムの研究動向
最適輸送の計算アルゴリズムの研究動向
ウェーブレット木の世界
ウェーブレット木の世界
最適化超入門
最適化超入門
【解説】 一般逆行列
【解説】 一般逆行列
第10回 配信講義 計算科学技術特論A(2021)
第10回 配信講義 計算科学技術特論A(2021)
【DL輪読会】Semi-Parametric Neural Image Synthesis
【DL輪読会】Semi-Parametric Neural Image Synthesis
技術者が知るべき Gröbner 基底
技術者が知るべき Gröbner 基底
平面グラフと交通ネットワークのアルゴリズム
平面グラフと交通ネットワークのアルゴリズム
Ähnlich wie 証明プログラミング超入門
すごいCoq入門
すごいCoq入門
真一 北原
Anomaly Detector で遊ぼう♪ with Azure Time Series Insights
Anomaly Detector で遊ぼう♪ with Azure Time Series Insights
Kazumi IWANAGA
JaSST'16 Tokyo モバイルセッション
JaSST'16 Tokyo モバイルセッション
mirer
20151021 cookpad talk_test_engineer
20151021 cookpad talk_test_engineer
Kazuaki Matsuo
読書会Vol6
読書会Vol6
Mari Takahashi
20120529 アジャイルサムライ読書会第6回
20120529 アジャイルサムライ読書会第6回
株式会社コネクトスター(ConnectStar Co., Ltd.)
プログラマ人生論
プログラマ人生論
ymmt
Ähnlich wie 証明プログラミング超入門
(7)
すごいCoq入門
すごいCoq入門
Anomaly Detector で遊ぼう♪ with Azure Time Series Insights
Anomaly Detector で遊ぼう♪ with Azure Time Series Insights
JaSST'16 Tokyo モバイルセッション
JaSST'16 Tokyo モバイルセッション
20151021 cookpad talk_test_engineer
20151021 cookpad talk_test_engineer
読書会Vol6
読書会Vol6
20120529 アジャイルサムライ読書会第6回
20120529 アジャイルサムライ読書会第6回
プログラマ人生論
プログラマ人生論
証明プログラミング超入門
1.
証明プログラミング超入門 2015/01/24 情報科学若手の会冬の陣 門脇 香子(@kdxu)
2.
自己紹介 • 門脇 香子
(@kdxu) • お茶の水女子大学 浅井研 M1 • 好きなもの : 型と自転車と音楽 • http://kodoku.tokyo
3.
概要 • 証明プログラミングとは? • Agda
による例(布教) 目標 : 高校数学レベルの簡単な証明 • (時間が余れば)ライブコーディング
4.
証明プログラミングとは? • ある種の性質を保障したプログラムが書ける 数学の定理を証明したり,停止性などの性質が保障された コンパイラなどを実装できる • コードの停止性,正当性などを証明できる 活用例
: OpenSSLの脆弱性の発見 CompCert(安全性が保証されたCコンパイラ) • テストではなく証明で正しさを保証する! • 安全,COOL,AWESOME !
5.
Agda について • もっとも有名な定理証明支援系の1つ •
依存型という型を使用できる • Coq より「プログラミング言語」寄り • Syntax としては Haskell に近い • 証明を項として表し直接操作する
6.
インストール&セットアップ • 要 Haskell-Platform •
$ cabal install agda • $ agda-mode setup • 推奨エディタはAquamacsだそうです
7.
書いてみよう • まずA1.agdaというファイルを作り module A1
agda と先頭に書く.(ファイル名と同じにする) • C-c C-l でloadできます
8.
まずは型定義 • data で新しい型を定義できる •
indent に注意しましょう • Set の部分集合としてのBool型という意味
9.
まずは型定義 • 自然数の型 • ペアノの公理による定義 •
zeroがNat型ということと,xがNat型ならsuc x もNat型だということを示している
10.
関数定義 • 普通の足し算の定義 • (suc
m) + n = (suc (m + n)) • C-c C-n で関数を評価できます
11.
関数定義 • 中値記法もできます
12.
関数定義
13.
何か証明してみよう • Nat 型と
Bool 型の簡単な定義はできた • ここでなにか簡単な定理を証明してみます • 同値性の証明をするならば同値関係のデータ型が必 要(equality) -> どのように定義するのか?
14.
同値性 • 2つのものが同じということは,以下のように定義できる • 例
: zero (suc zero) はダメ x x の形をしていない.型はあるが,値が存在しない なので,reflという型にならない • reflにハマる値が存在するか で定義できる
15.
定理 = 関数 •
例えば 0 + n n を示したい -> 返り値がreflとなるように関数を書ければよい • 関数の型は (n : Nat) -> (0 + n n) となる • ここで suc 関数に対する再帰的処理が必要になる
16.
定理 = 関数 •
これを Agda は 型が等しい と判断してくれない • ここで suc 関数に対する再帰的処理が必要になる • 一般的に定理を再帰的に示す関数 cong を定義
17.
証明完了! • zero と
suc nで場合分けしている (C-c C-c n) zero の場合は zero + zero は zeroなので直ちにrefl suc n の場合は n に関して再帰的に証明をする
18.
Tips : 依存型 •
Agda では依存型(Dependent Types)という型が使えます • 「値に依存する型」を作ることができる型 • 例 Vec N 型 • 型の段階で長さの比較や空リスト判定を保証できる
19.
おすすめ教材 • Ulf Norell
氏の Dependently Typed Programming in Agda (http://www.cse.chalmers.se/ ulfn/darcs/AFP08/ LectureNotes/AgdaIntro.pdf) • Brutal [Meta]Introduction to Dependent Types in Agda (http://oxij.org/note/BrutalDepTypes/) • お茶大製「みんなのAgda wiki」 (http://agda.wiki.fc2.com/)
20.
研究紹介 • 私は今日紹介した Agda
という言語を用いて安全 な型推論器を構成しています • 依存型の性質を用いて型変数の番号をうまく管理す ることで,セルの書き換えを用いずにUnification を行うことにより実装しています • https://github.com/kdxu/InferAgda
21.
おわり 証明ができると世界が開けます. 証明プログラミングを楽しみましょう!
Jetzt herunterladen