Documentation

Mathlib.CategoryTheory.Monoidal.Hopf_

The category of Hopf monoids in a braided monoidal category. #

TODO #

A Hopf monoid in a braided category C is a bimonoid object in C equipped with an antipode.

Instances

    The antipode is an endomorphism of the underlying object of the Hopf monoid.

    Equations
    Instances For

      The antipode is an endomorphism of the underlying object of the Hopf monoid.

      Equations
      • One or more equations did not get rendered due to their size.
      Instances For

        A Hopf monoid in a braided category C is a bimonoid object in C equipped with an antipode.

        Instances For

          Morphisms of Hopf monoids are just morphisms of the underlying bimonoids. In fact they automatically intertwine the antipodes, proved below.

          Equations

          Morphisms of Hopf monoids intertwine the antipodes.

          The antipode is an antihomomorphism with respect to both the monoid and comonoid structures. #

          theorem Hopf_.antipode_comulā‚ {C : Type uā‚} [CategoryTheory.Category.{vā‚, uā‚} C] [CategoryTheory.MonoidalCategory C] [CategoryTheory.BraidedCategory C] (A : Hopf_ C) :
          CategoryTheory.CategoryStruct.comp A.X.comul.hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight A.antipode A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight A.X.comul.hom A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X A.X.comul.hom)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).inv) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerRight (Ī²_ A.X.X.X A.X.X.X).hom A.X.X.X)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).hom) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorObj A.X.X.X A.X.X.X)).inv (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.X.mul A.X.X.mul))))))))) = CategoryTheory.CategoryStruct.comp A.X.counit.hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.leftUnitor (šŸ™_ C)).inv (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.X.one A.X.X.one))
          theorem Hopf_.antipode_comulā‚‚ {C : Type uā‚} [CategoryTheory.Category.{vā‚, uā‚} C] [CategoryTheory.MonoidalCategory C] [CategoryTheory.BraidedCategory C] (A : Hopf_ C) :
          CategoryTheory.CategoryStruct.comp A.X.comul.hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight A.X.comul.hom A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X A.X.comul.hom)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (Ī²_ A.X.X.X A.X.X.X).hom)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorHom A.antipode A.antipode))) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).inv) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerRight (Ī²_ A.X.X.X A.X.X.X).hom A.X.X.X)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).hom) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorObj A.X.X.X A.X.X.X)).inv (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.X.mul A.X.X.mul)))))))))) = CategoryTheory.CategoryStruct.comp A.X.counit.hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.leftUnitor (šŸ™_ C)).inv (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.X.one A.X.X.one))

          Auxiliary calculation for antipode_comul. This calculation calls for some ASCII art out of This Week's Finds.

             |   |
             n   n
            | \ / |
            |  /  |
            | / \ |
            | | S S
            | | \ /
            | |  /
            | | / \
            \ / \ /
             v   v
              \ /
               v
               |
          

          We move the left antipode up through the crossing, the right antipode down through the crossing, the right multiplication down across the strand, reassociate the comultiplications, then use antipode_right then antipode_left to simplify.

          theorem Hopf_.mul_antipodeā‚ {C : Type uā‚} [CategoryTheory.Category.{vā‚, uā‚} C] [CategoryTheory.MonoidalCategory C] [CategoryTheory.BraidedCategory C] (A : Hopf_ C) :
          CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.comul.hom A.X.comul.hom) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorObj A.X.X.X A.X.X.X)).hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).inv) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerRight (Ī²_ A.X.X.X A.X.X.X).hom A.X.X.X)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorObj A.X.X.X A.X.X.X) A.X.X.X).inv (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).inv A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight (CategoryTheory.MonoidalCategoryStruct.whiskerRight A.X.X.mul A.X.X.X) A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight (CategoryTheory.MonoidalCategoryStruct.whiskerRight A.antipode A.X.X.X) A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X A.X.X.mul) A.X.X.mul))))))))) = CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.counit.hom A.X.counit.hom) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.leftUnitor (šŸ™_ C)).hom A.X.X.one)
          theorem Hopf_.mul_antipodeā‚‚ {C : Type uā‚} [CategoryTheory.Category.{vā‚, uā‚} C] [CategoryTheory.MonoidalCategory C] [CategoryTheory.BraidedCategory C] (A : Hopf_ C) :
          CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.comul.hom A.X.comul.hom) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorObj A.X.X.X A.X.X.X)).hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).inv) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.whiskerRight (Ī²_ A.X.X.X A.X.X.X).hom A.X.X.X)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorObj A.X.X.X A.X.X.X) A.X.X.X).inv (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).inv A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerRight (CategoryTheory.MonoidalCategoryStruct.whiskerRight A.X.X.mul A.X.X.X) A.X.X.X) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.associator A.X.X.X A.X.X.X A.X.X.X).hom (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (Ī²_ A.X.X.X A.X.X.X).hom) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X (CategoryTheory.MonoidalCategoryStruct.tensorHom A.antipode A.antipode)) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.whiskerLeft A.X.X.X A.X.X.mul) A.X.X.mul)))))))))) = CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.tensorHom A.X.counit.hom A.X.counit.hom) (CategoryTheory.CategoryStruct.comp (CategoryTheory.MonoidalCategoryStruct.leftUnitor (šŸ™_ C)).hom A.X.X.one)

          Auxiliary calculation for mul_antipode.

                 |
                 n
                /  \
               |   n
               |  / \
               |  S S
               |  \ /
               n   /
              / \ / \
              |  /  |
              \ / \ /
               v   v
               |   |
          

          We move the leftmost multiplication up, so we can reassociate. We then move the rightmost comultiplication under the strand, and simplify using antipode_right.

          In a commutative Hopf algebra, the antipode squares to the identity.