/- Copyright (c) Luke Nelson and Jared Roesch. All rights reserved. Released under Apache 2.0 license as described in the file LICENSE. Authors: Luke Nelson, Jared Roesch, Sebastian Ullrich, Leonardo de Moura -/ prelude import init.core init.function init.meta.name open function universes u v section set_option auto_param.check_exists false class has_map (f : Type u → Type v) : Type (max (u+1) v) := (map : Π {α β : Type u}, (α → β) → f α → f β) (map_const : Π {α β : Type u}, α → f β → f α := λ α β, map ∘ const β) infixr ` <$> `:100 := has_map.map infixr ` <$ `:100 := has_map.map_const infixr ` $> `:100 := λ α a b, b <$ a class functor (f : Type u → Type v) extends has_map f : Type (max (u+1) v) := (map_const_eq : ∀ {α β : Type u}, @map_const α β = map ∘ const β . control_laws_tac) -- `functor` is indeed a categorical functor (id_map : Π {α : Type u} (x : f α), id <$> x = x) (map_comp : Π {α β γ : Type u} (g : α → β) (h : β → γ) (x : f α), (h ∘ g) <$> x = h <$> g <$> x) end