package electrod
Formal analysis for the Electrod formal pivot language
Install
Dune Dependency
Authors
Maintainers
Sources
electrod-0.2.3.tbz
sha256=7371c45e28b84a1955d117ef2c798d545febb87c74f596b6efe24965e4b28f31
sha512=e579db68ac05e30b0985f7d90080a82697de18c12e818d48bd7029cea8844571423f08d5881accbf8a0cbeb7df7de9b5b95ff5fe813330a6c92448a0901cdfe7
doc/src/electrod.libelectrod/Simplify2.ml.html
Source file Simplify2.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
(******************************************************************************* * electrod - a model finder for relational first-order linear temporal logic * * Copyright (C) 2016-2019 ONERA * Authors: Julien Brunel (ONERA), David Chemouil (ONERA) * * This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at http://mozilla.org/MPL/2.0/. * * SPDX-License-Identifier: MPL-2.0 * License-Filename: LICENSE.md ******************************************************************************) (** Compared to Simplify1, this version maps qualified relations to formulas relying on cardinality arguments. *) (** EXPECTED TO BE BE DONE AFTER CHECKING ARITIES. *) open Containers open Gen_goal module TS = Tuple_set let fresh_var base exp = Var.fresh ~loc:exp.exp_loc base (* simplify Ast goals *) class simplify = object (self : 'self) inherit Simplify1.simplify (* change relation qualifiers into formulas *) method! visit_Qual env qual exp = Msg.debug (fun m -> m "Simplify2.visit_Qual <-- %a" Ast.pp_prim_fml @@ Gen_goal.qual qual exp) ; let prim_fml = match qual with | ROne -> icomp (iexp exp.exp_loc @@ card exp) ieq (iexp exp.exp_loc @@ num 1) | RLone -> icomp (iexp exp.exp_loc @@ card exp) lte (iexp exp.exp_loc @@ num 1) | RSome -> icomp (iexp exp.exp_loc @@ card exp) gte (iexp exp.exp_loc @@ num 1) | RNo -> icomp (iexp exp.exp_loc @@ card exp) ieq (iexp exp.exp_loc @@ num 0) in self#visit_prim_fml env prim_fml |> Fun.tap @@ fun res -> Msg.debug (fun m -> m "Simplify2.visit_Qual --> %a" Ast.pp_prim_fml res) end let run elo = let open Ast in Msg.debug (fun m -> m "Entering Simplify2.simplify_fml") ; { elo with goal = (new simplify)#visit_t () elo.goal } let transfo = Transfo.make "simplify2" run
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>