Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Choose hom(B,C) = C ⊗ B^v instead of B^v ⊗ C #1501

Draft
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

zickgraf
Copy link
Member

@zickgraf zickgraf commented Nov 7, 2023

Currently, CAP derives the closed structure from the rigid structure by setting hom(B,C) = B^v ⊗ C. nLab chooses hom(B,C) = C ⊗ B^v instead: https://ncatlab.org/nlab/show/compact+closed+category. This PR implement the nLab convention. This greatly simplifies the definition of the evaluation and coevaluation morphisms, which can now be defined without braidings. This in turn simplifies string diagrams and the proof that we indeed get a closed structure. On the other hand, some braidings have to be added at other places. However, those are maybe expected or could be avoided. For example, a derivation of the trace map now needs a braiding, but that already seems to be part of the definition: https://ncatlab.org/nlab/show/trace. Moreover, some derivations using TensorProductInternalHomCompatibilityMorphism now need a braiding, but maybe TensorProductInternalHomCompatibilityMorphism could be adjusted, too to avoid this.

For my applications, choosing hom(B,C) = C ⊗ B^v is much simpler, so I will use this in my thesis. Maybe that would also make sense for CAP in general?

ping @mohamed-barakat @sebastianpos @TKuh

@zickgraf zickgraf force-pushed the rigid_implies_closed branch from 7d38af5 to b7c7d4e Compare November 7, 2023 14:33
@zickgraf zickgraf force-pushed the rigid_implies_closed branch from b7c7d4e to 6632eef Compare November 9, 2023 15:19
@sebastianpos
Copy link
Member

Good point. If we assume that we have no braiding in a monoidal category, then we have to be careful with directions. Here are the details:

  • CAP provides an interface for left duals
  • CAP provides an interface for right internal homs

By left duals, I mean the following convention:
$$\mathrm{evaluation}: A^{\ast} \otimes A \rightarrow 1$$
and
$$\mathrm{coevaluation}: 1 \rightarrow A \otimes A^{\ast}$$
From left duals you can build

  • a right adjoint of $(- \otimes A)$, i.e., a right internal hom, by $(- \otimes A^{\ast})$
  • a left adjoint of $(A \otimes -)$, i.e., a left internal cohom, by $(A^{\ast} \otimes -)$

but you cannot build the other 2 missing combinations. In particular, setting the right internal hom as you suggest is the natural choice.

@zickgraf
Copy link
Member Author

Thanks for the analysis and confirmation @sebastianpos! I will talk to @mohamed-barakat about how we shall proceed.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants