(************************************************************************) (* * The Rocq Prover / The Rocq Development Team *) (* v * Copyright INRIA, CNRS and contributors *) (* <O___,, * (see version control and CREDITS file for authors & dates) *) (* \VV/ **************************************************************) (* // * This file is distributed under the terms of the *) (* * GNU Lesser General Public License Version 2.1 *) (* * (see LICENSE file for the text of the license) *) (************************************************************************)
(* (c) Copyright 2006-2016 Microsoft Corporation and Inria. *)
RequireImport ssreflect.
Parameters P G : Prop.
Lemma test1 : (P -> G) -> P -> G. Proof.
move=> pg p.
have suff {pg} H : P. matchgoalwith |- P -> G => move=> _; exact: pg p | _ => fail end. matchgoalwith H : P -> G |- G => exact: H p | _ => fail end. Qed.
Lemma test2 : (P -> G) -> P -> G. Proof.
move=> pg p.
have suffices {pg} H : P. matchgoalwith |- P -> G => move=> _; exact: pg p | _ => fail end. matchgoalwith H : P -> G |- G => exact: H p | _ => fail end. Qed.
Lemma test3 : (P -> G) -> P -> G. Proof.
move=> pg p.
suff have {pg} H : P. matchgoalwith H : P |- G => exact: pg H | _ => fail end. matchgoalwith |- (P -> G) -> G => move=> H; exact: H p | _ => fail end. Qed.
Lemma test4 : (P -> G) -> P -> G. Proof.
move=> pg p.
suffices have {pg} H: P. matchgoalwith H : P |- G => exact: pg H | _ => fail end. matchgoalwith |- (P -> G) -> G => move=> H; exact: H p | _ => fail end. Qed.
(* Lemma test5 : (P -> G) -> P -> G. Proof. move=> pg p. suff have {pg} H : P := pg H. match goal with |- (P -> G) -> G => move=> H; exact: H p | _ => fail end. Qed.
*)
(* Lemma test6 : (P -> G) -> P -> G. Proof. move=> pg p. suff have {pg} H := pg H. match goal with |- (P -> G) -> G => move=> H; exact: H p | _ => fail end. Qed.
*)
Lemma test7 : (P -> G) -> P -> G. Proof.
move=> pg p.
have suff {pg} H : P := pg. matchgoalwith H : P -> G |- G => exact: H p | _ => fail end. Qed.
Lemma test8 : (P -> G) -> P -> G. Proof.
move=> pg p.
have suff {pg} H := pg. matchgoalwith H : P -> G |- G => exact: H p | _ => fail end. Qed.
Goalforall x y : bool, x = y -> x = y.
move=> x y E. by have {x E} -> : x = y by []. Qed.
Messung V0.5
¤ Dauer der Verarbeitung: 0.9 Sekunden
(vorverarbeitet)
¤
Die Informationen auf dieser Webseite wurden
nach bestem Wissen sorgfältig zusammengestellt. Es wird jedoch weder Vollständigkeit, noch Richtigkeit,
noch Qualität der bereit gestellten Informationen zugesichert.
Bemerkung:
Die farbliche Syntaxdarstellung und die Messung sind noch experimentell.