{-# 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