123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566(**************************************************************************)(* This file is part of the Codex semantics library. *)(* *)(* Copyright (C) 2013-2025 *)(* CEA (Commissariat à l'énergie atomique et aux énergies *)(* alternatives) *)(* *)(* you can redistribute it and/or modify it under the terms of the GNU *)(* Lesser General Public License as published by the Free Software *)(* Foundation, version 2.1. *)(* *)(* It is distributed in the hope that it will be useful, *)(* but WITHOUT ANY WARRANTY; without even the implied warranty of *)(* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *)(* GNU Lesser General Public License for more details. *)(* *)(* See the GNU Lesser General Public License version 2.1 *)(* for more details (enclosed in the file LICENSE). *)(* *)(**************************************************************************)openLattice_sigmoduletypeS=sigincludeSet.SincludeJOIN_SEMI_LATTICEwithtypet:=tincludeWITH_BOTTOMwithtypet:=tvalis_bottom:t->boolincludeWITH_INTERwithtypet:=tvaleq:t->t->Quadrivalent_Lattice.tvalintersects:t->t->boolendmoduleMake(E:Datatype_sig.S)=structincludeDatatype_sig.Set(E)(* let inter = E.Set.inter *)letis_bottom=is_emptyletbottom()=emptyletjoin=union(* let is_included = subset *)letincludesab=subsetbaletwiden~previousx=joinpreviousxletincludes_or_widen~previousnext=ifincludespreviousnextthen(true,previous)else(false,widen~previousnext)(* let join_and_is_included a b = *)(* let ab = join a b in *)(* (ab,E.Set.equal ab b) *)leteqab=(* let open Lattice_sig in *)ifis_empty(interab)thenQuadrivalent_Lattice.Falseelseletca=chooseaandcb=choosebinifE.equalcacb&&is_empty(removecaa)&&is_empty(removecbb)thenQuadrivalent_Lattice.TrueelseQuadrivalent_Lattice.Top(* Could be made more efficient if we add access to the underlying
implementation. *)letintersectsab=not(is_empty(interab));;end