2014-12-12 13:19:23 -05:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
|
|
|
|
|
|
General operations on functions.
|
|
|
|
|
-/
|
2015-02-26 13:19:54 -05:00
|
|
|
|
|
2014-12-12 13:19:23 -05:00
|
|
|
|
prelude
|
2015-04-30 23:14:00 -04:00
|
|
|
|
import init.reserved_notation .types
|
|
|
|
|
|
|
|
|
|
open prod
|
2014-12-12 13:19:23 -05:00
|
|
|
|
|
|
|
|
|
namespace function
|
|
|
|
|
|
2015-04-24 18:51:16 -04:00
|
|
|
|
variables {A B C D E : Type}
|
2014-12-12 13:19:23 -05:00
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition compose [reducible] [unfold_full] (f : B → C) (g : A → B) : A → C :=
|
2014-12-12 13:19:23 -05:00
|
|
|
|
λx, f (g x)
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition compose_right [reducible] [unfold_full] (f : B → B → B) (g : A → B) : B → A → B :=
|
2015-04-30 23:14:00 -04:00
|
|
|
|
λ b a, f b (g a)
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition compose_left [reducible] [unfold_full] (f : B → B → B) (g : A → B) : A → B → B :=
|
2015-04-30 23:14:00 -04:00
|
|
|
|
λ a b, f (g a) b
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition id [reducible] [unfold_full] (a : A) : A :=
|
2014-12-12 13:19:23 -05:00
|
|
|
|
a
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition on_fun [reducible] [unfold_full] (f : B → B → C) (g : A → B) : A → A → C :=
|
2014-12-12 13:19:23 -05:00
|
|
|
|
λx y, f (g x) (g y)
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition combine [reducible] [unfold_full] (f : A → B → C) (op : C → D → E) (g : A → B → D)
|
2015-05-07 01:23:39 -04:00
|
|
|
|
: A → B → E :=
|
2014-12-12 13:19:23 -05:00
|
|
|
|
λx y, op (f x y) (g x y)
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition const [reducible] [unfold_full] (B : Type) (a : A) : B → A :=
|
2014-12-12 13:19:23 -05:00
|
|
|
|
λx, a
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition dcompose [reducible] [unfold_full] {B : A → Type} {C : Π {x : A}, B x → Type}
|
2014-12-12 13:19:23 -05:00
|
|
|
|
(f : Π {x : A} (y : B x), C y) (g : Πx, B x) : Πx, C (g x) :=
|
|
|
|
|
λx, f (g x)
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition flip [reducible] [unfold_full] {C : A → B → Type} (f : Πx y, C x y) : Πy x, C x y :=
|
2014-12-12 13:19:23 -05:00
|
|
|
|
λy x, f x y
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition app [reducible] [unfold_full] {B : A → Type} (f : Πx, B x) (x : A) : B x :=
|
2014-12-12 13:19:23 -05:00
|
|
|
|
f x
|
|
|
|
|
|
2015-10-09 13:21:03 -07:00
|
|
|
|
definition curry [reducible] [unfold_full] : (A × B → C) → A → B → C :=
|
2015-04-30 23:14:00 -04:00
|
|
|
|
λ f a b, f (a, b)
|
|
|
|
|
|
2015-07-07 16:37:06 -07:00
|
|
|
|
definition uncurry [reducible] [unfold 5] : (A → B → C) → (A × B → C) :=
|
2015-04-30 23:14:00 -04:00
|
|
|
|
λ f p, match p with (a, b) := f a b end
|
|
|
|
|
|
2014-12-12 13:19:23 -05:00
|
|
|
|
|
2015-10-01 15:52:28 -04:00
|
|
|
|
infixr ` ∘ ` := compose
|
|
|
|
|
infixr ` ∘' `:60 := dcompose
|
|
|
|
|
infixl ` on `:1 := on_fun
|
|
|
|
|
infixr ` $ `:1 := app
|
2015-09-30 16:52:34 -07:00
|
|
|
|
notation f ` -[` op `]- ` g := combine f op g
|
2014-12-12 13:19:23 -05:00
|
|
|
|
|
|
|
|
|
end function
|
2015-02-16 18:52:41 -08:00
|
|
|
|
|
|
|
|
|
-- copy reducible annotations to top-level
|
2015-10-09 13:21:03 -07:00
|
|
|
|
export [reduce_hints] [unfold_hints] function
|