[isabelle-dev] Multiset insert
Jasmin Blanchette
jasmin.blanchette at inria.fr
Thu Jul 28 10:40:40 CEST 2016
> On 28.07.2016, at 10:33, Peter Lammich <lammich at in.tum.de> wrote:
>
>>> How about
>>>
>>> definition add_mset :: "'a ⇒ 'a multiset ⇒ 'a multiset" ("add#") where
>>> "add# x M = {#x#} + M"
>
> This, however, may produce confusion with multiset union, which is an
> instance of the plus type classes, i.e., occupying the name
> plus_multiset.
I think that's fair enough, because we operate in a simply typed setting. Logicians and computer scientists frequently use the same symbol for both operations, namely comma, when writing contexts in logical or typing judgments. E.g.
\Gamma, t : \tau
\Gamma, \Delta
t : \tau, \Gamma
Without going quite that far here (nor can we due to the type of +), this shows that two think of "add_mset" and + as "essentially the same thing" is not too far off the mark.
"add1_mset" resp. "add1#" would make things more explicit, but since there's hardly any confusion possible there's also hardly any need to make things explicit.
Jasmin
More information about the isabelle-dev
mailing list