src/HOL/ex/HarmonicSeries.thy
author paulson <lp15@cam.ac.uk>
Thu, 27 Aug 2020 16:48:21 +0100
changeset 72221 98ef41a82b73
parent 70113 c8deb8ba6d05
permissions -rw-r--r--
just a bit of streamlining
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     1
(*  Title:      HOL/ex/HarmonicSeries.thy
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     2
    Author:     Benjamin Porter, 2006
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     3
*)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     4
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
     5
section \<open>Divergence of the Harmonic Series\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     6
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     7
theory HarmonicSeries
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     8
imports Complex_Main
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
     9
begin
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    10
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
    11
subsection \<open>Abstract\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    12
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
    13
text \<open>The following document presents a proof of the Divergence of
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    14
Harmonic Series theorem formalised in the Isabelle/Isar theorem
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    15
proving system.
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    16
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    17
{\em Theorem:} The series $\sum_{n=1}^{\infty} \frac{1}{n}$ does not
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    18
converge to any number.
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    19
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    20
{\em Informal Proof:}
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    21
  The informal proof is based on the following auxillary lemmas:
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    22
  \begin{itemize}
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    23
  \item{aux: $\sum_{n=2^m-1}^{2^m} \frac{1}{n} \geq \frac{1}{2}$}
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    24
  \item{aux2: $\sum_{n=1}^{2^M} \frac{1}{n} = 1 + \sum_{m=1}^{M} \sum_{n=2^m-1}^{2^m} \frac{1}{n}$}
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    25
  \end{itemize}
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    26
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    27
  From {\em aux} and {\em aux2} we can deduce that $\sum_{n=1}^{2^M}
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    28
  \frac{1}{n} \geq 1 + \frac{M}{2}$ for all $M$.
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    29
  Now for contradiction, assume that $\sum_{n=1}^{\infty} \frac{1}{n}
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    30
  = s$ for some $s$. Because $\forall n. \frac{1}{n} > 0$ all the
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    31
  partial sums in the series must be less than $s$. However with our
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    32
  deduction above we can choose $N > 2*s - 2$ and thus
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    33
  $\sum_{n=1}^{2^N} \frac{1}{n} > s$. This leads to a contradiction
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    34
  and hence $\sum_{n=1}^{\infty} \frac{1}{n}$ is not summable.
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    35
  QED.
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
    36
\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    37
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
    38
subsection \<open>Formal Proof\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    39
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    40
lemma two_pow_sub:
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    41
  "0 < m \<Longrightarrow> (2::nat)^m - 2^(m - 1) = 2^(m - 1)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    42
  by (induct m) auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    43
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
    44
text \<open>We first prove the following auxillary lemma. This lemma
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    45
simply states that the finite sums: $\frac{1}{2}$, $\frac{1}{3} +
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    46
\frac{1}{4}$, $\frac{1}{5} + \frac{1}{6} + \frac{1}{7} + \frac{1}{8}$
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    47
etc. are all greater than or equal to $\frac{1}{2}$. We do this by
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    48
observing that each term in the sum is greater than or equal to the
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    49
last term, e.g. $\frac{1}{3} > \frac{1}{4}$ and thus $\frac{1}{3} +
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
    50
\frac{1}{4} > \frac{1}{4} + \frac{1}{4} = \frac{1}{2}$.\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    51
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    52
lemma harmonic_aux:
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    53
  "\<forall>m>0. (\<Sum>n\<in>{(2::nat)^(m - 1)+1..2^m}. 1/real n) \<ge> 1/2"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    54
  (is "\<forall>m>0. (\<Sum>n\<in>(?S m). 1/real n) \<ge> 1/2")
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    55
proof
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    56
  fix m::nat
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    57
  obtain tm where tmdef: "tm = (2::nat)^m" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    58
  {
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    59
    assume mgt0: "0 < m"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    60
    have "\<And>x. x\<in>(?S m) \<Longrightarrow> 1/(real x) \<ge> 1/(real tm)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    61
    proof -
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    62
      fix x::nat
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    63
      assume xs: "x\<in>(?S m)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    64
      have xgt0: "x>0"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    65
      proof -
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    66
        from xs have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    67
          "x \<ge> 2^(m - 1) + 1" by auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    68
        moreover from mgt0 have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    69
          "2^(m - 1) + 1 \<ge> (1::nat)" by auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    70
        ultimately have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    71
          "x \<ge> 1" by (rule xtrans)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    72
        thus ?thesis by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    73
      qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    74
      moreover from xs have "x \<le> 2^m" by auto
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61343
diff changeset
    75
      ultimately have "inverse (real x) \<ge> inverse (real ((2::nat)^m))" by simp
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    76
      moreover
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    77
      from xgt0 have "real x \<noteq> 0" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    78
      then have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    79
        "inverse (real x) = 1 / (real x)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    80
        by (rule nonzero_inverse_eq_divide)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    81
      moreover from mgt0 have "real tm \<noteq> 0" by (simp add: tmdef)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    82
      then have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    83
        "inverse (real tm) = 1 / (real tm)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    84
        by (rule nonzero_inverse_eq_divide)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    85
      ultimately show
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    86
        "1/(real x) \<ge> 1/(real tm)" by (auto simp add: tmdef)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    87
    qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    88
    then have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    89
      "(\<Sum>n\<in>(?S m). 1 / real n) \<ge> (\<Sum>n\<in>(?S m). 1/(real tm))"
64267
b9a1486e79be setsum -> sum
nipkow
parents: 63040
diff changeset
    90
      by (rule sum_mono)
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    91
    moreover have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    92
      "(\<Sum>n\<in>(?S m). 1/(real tm)) = 1/2"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    93
    proof -
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    94
      have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    95
        "(\<Sum>n\<in>(?S m). 1/(real tm)) =
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    96
         (1/(real tm))*(\<Sum>n\<in>(?S m). 1)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    97
        by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    98
      also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
    99
        "\<dots> = ((1/(real tm)) * real (card (?S m)))"
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61343
diff changeset
   100
        by (simp add: real_of_card)
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   101
      also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   102
        "\<dots> = ((1/(real tm)) * real (tm - (2^(m - 1))))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   103
        by (simp add: tmdef)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   104
      also from mgt0 have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   105
        "\<dots> = ((1/(real tm)) * real ((2::nat)^(m - 1)))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   106
        by (auto simp: tmdef dest: two_pow_sub)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   107
      also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   108
        "\<dots> = (real (2::nat))^(m - 1) / (real (2::nat))^m"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   109
        by (simp add: tmdef)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   110
      also from mgt0 have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   111
        "\<dots> = (real (2::nat))^(m - 1) / (real (2::nat))^((m - 1) + 1)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   112
        by auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   113
      also have "\<dots> = 1/2" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   114
      finally show ?thesis .
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   115
    qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   116
    ultimately have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   117
      "(\<Sum>n\<in>(?S m). 1 / real n) \<ge> 1/2"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   118
      by - (erule subst)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   119
  }
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   120
  thus "0 < m \<longrightarrow> 1 / 2 \<le> (\<Sum>n\<in>(?S m). 1 / real n)" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   121
qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   122
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
   123
text \<open>We then show that the sum of a finite number of terms from the
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   124
harmonic series can be regrouped in increasing powers of 2. For
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   125
example: $1 + \frac{1}{2} + \frac{1}{3} + \frac{1}{4} + \frac{1}{5} +
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   126
\frac{1}{6} + \frac{1}{7} + \frac{1}{8} = 1 + (\frac{1}{2}) +
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   127
(\frac{1}{3} + \frac{1}{4}) + (\frac{1}{5} + \frac{1}{6} + \frac{1}{7}
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
   128
+ \frac{1}{8})$.\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   129
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   130
lemma harmonic_aux2 [rule_format]:
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   131
  "0<M \<Longrightarrow> (\<Sum>n\<in>{1..(2::nat)^M}. 1/real n) =
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   132
   (1 + (\<Sum>m\<in>{1..M}. \<Sum>n\<in>{(2::nat)^(m - 1)+1..2^m}. 1/real n))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   133
  (is "0<M \<Longrightarrow> ?LHS M = ?RHS M")
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   134
proof (induct M)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   135
  case 0 show ?case by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   136
next
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   137
  case (Suc M)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   138
  have ant: "0 < Suc M" by fact
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   139
  {
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   140
    have suc: "?LHS (Suc M) = ?RHS (Suc M)"
67443
3abf6a722518 standardized towards new-style formal comments: isabelle update_comments;
wenzelm
parents: 64267
diff changeset
   141
    proof cases \<comment> \<open>show that LHS = c and RHS = c, and thus LHS = RHS\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   142
      assume mz: "M=0"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   143
      {
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   144
        then have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   145
          "?LHS (Suc M) = ?LHS 1" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   146
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   147
          "\<dots> = (\<Sum>n\<in>{(1::nat)..2}. 1/real n)" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   148
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   149
          "\<dots> = ((\<Sum>n\<in>{Suc 1..2}. 1/real n) + 1/(real (1::nat)))"
70113
c8deb8ba6d05 Fixing the main Homology theory; also moving a lot of sum/prod lemmas into their generic context
paulson <lp15@cam.ac.uk>
parents: 67443
diff changeset
   150
          by (subst sum.head)
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   151
             (auto simp: atLeastSucAtMost_greaterThanAtMost)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   152
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   153
          "\<dots> = ((\<Sum>n\<in>{2..2::nat}. 1/real n) + 1/(real (1::nat)))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   154
          by (simp add: eval_nat_numeral)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   155
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   156
          "\<dots> =  1/(real (2::nat)) + 1/(real (1::nat))" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   157
        finally have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   158
          "?LHS (Suc M) = 1/2 + 1" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   159
      }
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   160
      moreover
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   161
      {
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   162
        from mz have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   163
          "?RHS (Suc M) = ?RHS 1" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   164
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   165
          "\<dots> = (\<Sum>n\<in>{((2::nat)^0)+1..2^1}. 1/real n) + 1"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   166
          by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   167
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   168
          "\<dots> = (\<Sum>n\<in>{2::nat..2}. 1/real n) + 1"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   169
          by (auto simp: atLeastAtMost_singleton')
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   170
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   171
          "\<dots> = 1/2 + 1"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   172
          by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   173
        finally have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   174
          "?RHS (Suc M) = 1/2 + 1" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   175
      }
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   176
      ultimately show "?LHS (Suc M) = ?RHS (Suc M)" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   177
    next
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   178
      assume mnz: "M\<noteq>0"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   179
      then have mgtz: "M>0" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   180
      with Suc have suc:
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   181
        "(?LHS M) = (?RHS M)" by blast
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   182
      have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   183
        "(?LHS (Suc M)) =
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   184
         ((?LHS M) + (\<Sum>n\<in>{(2::nat)^M+1..2^(Suc M)}. 1 / real n))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   185
      proof -
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   186
        have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   187
          "{1..(2::nat)^(Suc M)} =
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   188
           {1..(2::nat)^M}\<union>{(2::nat)^M+1..(2::nat)^(Suc M)}"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   189
          by auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   190
        moreover have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   191
          "{1..(2::nat)^M}\<inter>{(2::nat)^M+1..(2::nat)^(Suc M)} = {}"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   192
          by auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   193
        moreover have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   194
          "finite {1..(2::nat)^M}" and "finite {(2::nat)^M+1..(2::nat)^(Suc M)}"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   195
          by auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   196
        ultimately show ?thesis
64267
b9a1486e79be setsum -> sum
nipkow
parents: 63040
diff changeset
   197
          by (auto intro: sum.union_disjoint)
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   198
      qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   199
      moreover
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   200
      {
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   201
        have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   202
          "(?RHS (Suc M)) =
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   203
           (1 + (\<Sum>m\<in>{1..M}.  \<Sum>n\<in>{(2::nat)^(m - 1)+1..2^m}. 1/real n) +
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   204
           (\<Sum>n\<in>{(2::nat)^(Suc M - 1)+1..2^(Suc M)}. 1/real n))" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   205
        also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   206
          "\<dots> = (?RHS M) + (\<Sum>n\<in>{(2::nat)^M+1..2^(Suc M)}. 1/real n)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   207
          by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   208
        also from suc have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   209
          "\<dots> = (?LHS M) +  (\<Sum>n\<in>{(2::nat)^M+1..2^(Suc M)}. 1/real n)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   210
          by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   211
        finally have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   212
          "(?RHS (Suc M)) = \<dots>" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   213
      }
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   214
      ultimately show "?LHS (Suc M) = ?RHS (Suc M)" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   215
    qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   216
  }
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   217
  thus ?case by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   218
qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   219
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
   220
text \<open>Using @{thm [source] harmonic_aux} and @{thm [source] harmonic_aux2} we now show
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   221
that each group sum is greater than or equal to $\frac{1}{2}$ and thus
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   222
the finite sum is bounded below by a value proportional to the number
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
   223
of elements we choose.\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   224
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   225
lemma harmonic_aux3 [rule_format]:
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   226
  shows "\<forall>(M::nat). (\<Sum>n\<in>{1..(2::nat)^M}. 1 / real n) \<ge> 1 + (real M)/2"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   227
  (is "\<forall>M. ?P M \<ge> _")
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   228
proof (rule allI, cases)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   229
  fix M::nat
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   230
  assume "M=0"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   231
  then show "?P M \<ge> 1 + (real M)/2" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   232
next
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   233
  fix M::nat
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   234
  assume "M\<noteq>0"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   235
  then have "M > 0" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   236
  then have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   237
    "(?P M) =
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   238
     (1 + (\<Sum>m\<in>{1..M}. \<Sum>n\<in>{(2::nat)^(m - 1)+1..2^m}. 1/real n))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   239
    by (rule harmonic_aux2)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   240
  also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   241
    "\<dots> \<ge> (1 + (\<Sum>m\<in>{1..M}. 1/2))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   242
  proof -
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   243
    let ?f = "(\<lambda>x. 1/2)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   244
    let ?g = "(\<lambda>x. (\<Sum>n\<in>{(2::nat)^(x - 1)+1..2^x}. 1/real n))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   245
    from harmonic_aux have "\<And>x. x\<in>{1..M} \<Longrightarrow> ?f x \<le> ?g x" by simp
64267
b9a1486e79be setsum -> sum
nipkow
parents: 63040
diff changeset
   246
    then have "(\<Sum>m\<in>{1..M}. ?g m) \<ge> (\<Sum>m\<in>{1..M}. ?f m)" by (rule sum_mono)
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   247
    thus ?thesis by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   248
  qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   249
  finally have "(?P M) \<ge> (1 + (\<Sum>m\<in>{1..M}. 1/2))" .
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   250
  moreover
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   251
  {
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   252
    have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   253
      "(\<Sum>m\<in>{1..M}. (1::real)/2) = 1/2 * (\<Sum>m\<in>{1..M}. 1)"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   254
      by auto
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   255
    also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   256
      "\<dots> = 1/2*(real (card {1..M}))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   257
      by (simp only: real_of_card[symmetric])
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   258
    also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   259
      "\<dots> = 1/2*(real M)" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   260
    also have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   261
      "\<dots> = (real M)/2" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   262
    finally have "(\<Sum>m\<in>{1..M}. (1::real)/2) = (real M)/2" .
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   263
  }
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   264
  ultimately show "(?P M) \<ge> (1 + (real M)/2)" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   265
qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   266
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
   267
text \<open>The final theorem shows that as we take more and more elements
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   268
(see @{thm [source] harmonic_aux3}) we get an ever increasing sum. By assuming
64267
b9a1486e79be setsum -> sum
nipkow
parents: 63040
diff changeset
   269
the sum converges, the lemma @{thm [source] sum_less_suminf} ( @{thm
b9a1486e79be setsum -> sum
nipkow
parents: 63040
diff changeset
   270
sum_less_suminf} ) states that each sum is bounded above by the
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   271
series' limit. This contradicts our first statement and thus we prove
61343
5b5656a63bd6 isabelle update_cartouches;
wenzelm
parents: 58889
diff changeset
   272
that the harmonic series is divergent.\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   273
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   274
theorem DivergenceOfHarmonicSeries:
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   275
  shows "\<not>summable (\<lambda>n. 1/real (Suc n))"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   276
  (is "\<not>summable ?f")
67443
3abf6a722518 standardized towards new-style formal comments: isabelle update_comments;
wenzelm
parents: 64267
diff changeset
   277
proof \<comment> \<open>by contradiction\<close>
3abf6a722518 standardized towards new-style formal comments: isabelle update_comments;
wenzelm
parents: 64267
diff changeset
   278
  let ?s = "suminf ?f" \<comment> \<open>let ?s equal the sum of the harmonic series\<close>
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   279
  assume sf: "summable ?f"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   280
  then obtain n::nat where ndef: "n = nat \<lceil>2 * ?s\<rceil>" by simp
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61343
diff changeset
   281
  then have ngt: "1 + real n/2 > ?s" by linarith
63040
eb4ddd18d635 eliminated old 'def';
wenzelm
parents: 61933
diff changeset
   282
  define j where "j = (2::nat)^n"
72221
98ef41a82b73 just a bit of streamlining
paulson <lp15@cam.ac.uk>
parents: 70113
diff changeset
   283
  have "(\<Sum>i<j. ?f i) < ?s" 
98ef41a82b73 just a bit of streamlining
paulson <lp15@cam.ac.uk>
parents: 70113
diff changeset
   284
    using sf by (simp add: sum_less_suminf)
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   285
  then have "(\<Sum>i\<in>{Suc 0..<Suc j}. 1/(real i)) < ?s"
70113
c8deb8ba6d05 Fixing the main Homology theory; also moving a lot of sum/prod lemmas into their generic context
paulson <lp15@cam.ac.uk>
parents: 67443
diff changeset
   286
    unfolding sum.shift_bounds_Suc_ivl by (simp add: atLeast0LessThan)
61609
77b453bd616f Coercion "real" now has type nat => real only and is no longer overloaded. Type class "real_of" is gone. Many duplicate theorems removed.
paulson <lp15@cam.ac.uk>
parents: 61343
diff changeset
   287
  with j_def have
56788
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   288
    "(\<Sum>i\<in>{1..< Suc ((2::nat)^n)}. 1 / (real i)) < ?s" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   289
  then have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   290
    "(\<Sum>i\<in>{1..(2::nat)^n}. 1 / (real i)) < ?s"
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   291
    by (simp only: atLeastLessThanSuc_atLeastAtMost)
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   292
  moreover from harmonic_aux3 have
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   293
    "(\<Sum>i\<in>{1..(2::nat)^n}. 1 / (real i)) \<ge> 1 + real n/2" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   294
  moreover from ngt have "1 + real n/2 > ?s" by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   295
  ultimately show False by simp
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   296
qed
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   297
28ff163eefef proper Unix line termination;
wenzelm
parents: 56213
diff changeset
   298
end