src/HOL/Library/Diagonal_Subsequence.thy
author blanchet
Wed, 24 Sep 2014 15:45:55 +0200
changeset 58425 246985c6b20b
parent 57862 8f074e6e22fc
child 58881 b9556a055632
permissions -rw-r--r--
simpler proof
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     1
(* Author: Fabian Immler, TUM *)
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     2
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     3
header {* Sequence of Properties on Subsequences *}
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     4
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     5
theory Diagonal_Subsequence
51526
155263089e7b move SEQ.thy and Lim.thy to Limits.thy
hoelzl
parents: 50087
diff changeset
     6
imports Complex_Main
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     7
begin
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     8
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
     9
locale subseqs =
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    10
  fixes P::"nat\<Rightarrow>(nat\<Rightarrow>nat)\<Rightarrow>bool"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    11
  assumes ex_subseq: "\<And>n s. subseq s \<Longrightarrow> \<exists>r'. subseq r' \<and> P n (s o r')"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    12
begin
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    13
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    14
definition reduce where "reduce s n = (SOME r'. subseq r' \<and> P n (s o r'))"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    15
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    16
lemma subseq_reduce[intro, simp]:
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    17
  "subseq s \<Longrightarrow> subseq (reduce s n)"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    18
  unfolding reduce_def by (rule someI2_ex[OF ex_subseq]) auto
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    19
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    20
lemma reduce_holds:
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    21
  "subseq s \<Longrightarrow> P n (s o reduce s n)"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    22
  unfolding reduce_def by (rule someI2_ex[OF ex_subseq]) (auto simp: o_def)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    23
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    24
primrec seqseq where
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    25
  "seqseq 0 = id"
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    26
| "seqseq (Suc n) = seqseq n o reduce (seqseq n) n"
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    27
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    28
lemma subseq_seqseq[intro, simp]: "subseq (seqseq n)"
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    29
proof (induct n)
57862
8f074e6e22fc tuned proofs;
wenzelm
parents: 52681
diff changeset
    30
  case 0 thus ?case by (simp add: subseq_def)
8f074e6e22fc tuned proofs;
wenzelm
parents: 52681
diff changeset
    31
next
8f074e6e22fc tuned proofs;
wenzelm
parents: 52681
diff changeset
    32
  case (Suc n) thus ?case by (subst seqseq.simps) (auto intro!: subseq_o)
8f074e6e22fc tuned proofs;
wenzelm
parents: 52681
diff changeset
    33
qed
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    34
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    35
lemma seqseq_holds:
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    36
  "P n (seqseq (Suc n))"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    37
proof -
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    38
  have "P n (seqseq n o reduce (seqseq n) n)"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    39
    by (intro reduce_holds subseq_seqseq)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    40
  thus ?thesis by simp
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    41
qed
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    42
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    43
definition diagseq where "diagseq i = seqseq i i"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    44
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    45
lemma subseq_mono: "subseq f \<Longrightarrow> a \<le> b \<Longrightarrow> f a \<le> f b"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    46
  by (metis le_eq_less_or_eq subseq_mono)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    47
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    48
lemma subseq_strict_mono: "subseq f \<Longrightarrow> a < b \<Longrightarrow> f a < f b"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    49
  by (simp add: subseq_def)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    50
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    51
lemma diagseq_mono: "diagseq n < diagseq (Suc n)"
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    52
proof -
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    53
  have "diagseq n < seqseq n (Suc n)"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    54
    using subseq_seqseq[of n] by (simp add: diagseq_def subseq_def)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    55
  also have "\<dots> \<le> seqseq n (reduce (seqseq n) n (Suc n))"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    56
    by (auto intro: subseq_mono seq_suble)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    57
  also have "\<dots> = diagseq (Suc n)" by (simp add: diagseq_def)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    58
  finally show ?thesis .
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    59
qed
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    60
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    61
lemma subseq_diagseq: "subseq diagseq"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    62
  using diagseq_mono by (simp add: subseq_Suc_iff diagseq_def)
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    63
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    64
primrec fold_reduce where
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    65
  "fold_reduce n 0 = id"
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    66
| "fold_reduce n (Suc k) = fold_reduce n k o reduce (seqseq (n + k)) (n + k)"
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    67
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    68
lemma subseq_fold_reduce[intro, simp]: "subseq (fold_reduce n k)"
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    69
proof (induct k)
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
    70
  case (Suc k) from subseq_o[OF this subseq_reduce] show ?case by (simp add: o_def)
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    71
qed (simp add: subseq_def)
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    72
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    73
lemma ex_subseq_reduce_index: "seqseq (n + k) = seqseq n o fold_reduce n k"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    74
  by (induct k) simp_all
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    75
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    76
lemma seqseq_fold_reduce: "seqseq n = fold_reduce 0 n"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    77
  by (induct n) (simp_all)
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    78
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    79
lemma diagseq_fold_reduce: "diagseq n = fold_reduce 0 n n"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    80
  using seqseq_fold_reduce by (simp add: diagseq_def)
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    81
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    82
lemma fold_reduce_add: "fold_reduce 0 (m + n) = fold_reduce 0 m o fold_reduce m n"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    83
  by (induct n) simp_all
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    84
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    85
lemma diagseq_add: "diagseq (k + n) = (seqseq k o (fold_reduce k n)) (k + n)"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    86
proof -
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    87
  have "diagseq (k + n) = fold_reduce 0 (k + n) (k + n)"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    88
    by (simp add: diagseq_fold_reduce)
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    89
  also have "\<dots> = (seqseq k o fold_reduce k n) (k + n)"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    90
    unfolding fold_reduce_add seqseq_fold_reduce ..
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    91
  finally show ?thesis .
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    92
qed
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    93
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    94
lemma diagseq_sub:
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    95
  assumes "m \<le> n" shows "diagseq n = (seqseq m o (fold_reduce m (n - m))) n"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    96
  using diagseq_add[of m "n - m"] assms by simp
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    97
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    98
lemma subseq_diagonal_rest: "subseq (\<lambda>x. fold_reduce k x (k + x))"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
    99
  unfolding subseq_Suc_iff fold_reduce.simps o_def
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   100
proof
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   101
  fix n
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   102
  have "fold_reduce k n (k + n) < fold_reduce k n (k + Suc n)" (is "?lhs < _")
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   103
    by (auto intro: subseq_strict_mono)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   104
  also have "\<dots> \<le> fold_reduce k n (reduce (seqseq (k + n)) (k + n) (k + Suc n))"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   105
    by (rule subseq_mono) (auto intro!: seq_suble subseq_mono)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   106
  finally show "?lhs < \<dots>" .
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   107
qed
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
   108
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
   109
lemma diagseq_seqseq: "diagseq o (op + k) = (seqseq k o (\<lambda>x. fold_reduce k x (k + x)))"
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
   110
  by (auto simp: o_def diagseq_add)
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
   111
52681
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   112
lemma diagseq_holds:
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   113
  assumes subseq_stable: "\<And>r s n. subseq r \<Longrightarrow> P n s \<Longrightarrow> P n (s o r)"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   114
  shows "P k (diagseq o (op + (Suc k)))"
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   115
  unfolding diagseq_seqseq by (intro subseq_stable subseq_diagonal_rest seqseq_holds)
8cc7f76b827a tuned definition of seqseq; clarified usage of diagseq via diagseq_holds
immler
parents: 51526
diff changeset
   116
50087
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
   117
end
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
   118
635d73673b5e regularity of measures, therefore:
immler
parents:
diff changeset
   119
end