{-# OPTIONS --type-in-type #-} open import NeilPrelude module SemiRingUnity {A : Set} (_⊕_ : Op A) (⊕assoc : Associative _⊕_) (⊕comm : Commutative _⊕_) (zero : A) (unit⊕ : {a : A} → zero ⊕ a ≡ a) (_⊗_ : Op A) (⊗assoc : Associative _⊗_) (zero⊗ : {a : A} → zero ⊗ a ≡ zero) (⊗zero : {a : A} → a ⊗ zero ≡ zero) (one : A) (unit⊗ : {a : A} -> one ⊗ a ≡ a) (⊗unit : {a : A} -> a ⊗ one ≡ a) (distrL : {a b c : A} -> a ⊗ (b ⊕ c) ≡ (a ⊗ b) ⊕ (a ⊗ c)) (distrR : {a b c : A} -> (a ⊕ b) ⊗ c ≡ (a ⊗ c) ⊕ (b ⊗ c)) where import SemiRing open SemiRing _⊕_ ⊕assoc ⊕comm zero unit⊕ _⊗_ ⊗assoc zero⊗ ⊗zero distrL distrR public import Monoid open Monoid _⊗_ ⊗assoc one