src/ZF/ex/NatSum.thy
author bulwahn
Mon, 18 Jul 2011 10:34:21 +0200
changeset 43879 c8308a8faf9f
parent 41777 1f7cbe39d425
child 65449 c82e63b11b8b
permissions -rw-r--r--
enabling parallel execution of testers but removing more informative quickcheck output
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
41777
1f7cbe39d425 more precise headers;
wenzelm
parents: 35762
diff changeset
     1
(*  Title:      ZF/ex/NatSum.thy
9647
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
     2
    Author:     Tobias Nipkow & Lawrence C Paulson
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
     3
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
     4
A summation operator. sum(f,n+1) is the sum of all f(i), i=0...n.
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
     5
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
     6
Note: n is a natural number but the sum is an integer,
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
     7
                            and f maps integers to integers
12867
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
     8
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
     9
Summing natural numbers, squares, cubes, etc.
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    10
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    11
Originally demonstrated permutative rewriting, but add_ac is no longer needed
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    12
  thanks to new simprocs.
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    13
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    14
Thanks to Sloane's On-Line Encyclopedia of Integer Sequences,
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    15
  http://www.research.att.com/~njas/sequences/
9647
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
    16
*)
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
    17
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
    18
16417
9bc16273c2d4 migrated theory headers to new format
haftmann
parents: 12867
diff changeset
    19
theory NatSum imports Main begin
12867
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    20
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    21
consts sum :: "[i=>i, i] => i"
9647
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
    22
primrec 
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
    23
  "sum (f,0) = #0"
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
    24
  "sum (f, succ(n)) = f($#n) $+ sum(f,n)"
e9623f47275b new example ZF/ex/NatSum
paulson
parents:
diff changeset
    25
12867
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    26
declare zadd_zmult_distrib [simp]  zadd_zmult_distrib2 [simp]
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    27
declare zdiff_zmult_distrib [simp] zdiff_zmult_distrib2 [simp]
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    28
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    29
(*The sum of the first n odd numbers equals n squared.*)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    30
lemma sum_of_odds: "n \<in> nat ==> sum (%i. i $+ i $+ #1, n) = $#n $* $#n"
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    31
by (induct_tac "n", auto)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    32
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    33
(*The sum of the first n odd squares*)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    34
lemma sum_of_odd_squares:
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    35
     "n \<in> nat ==> #3 $* sum (%i. (i $+ i $+ #1) $* (i $+ i $+ #1), n) =  
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    36
      $#n $* (#4 $* $#n $* $#n $- #1)"
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    37
by (induct_tac "n", auto)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    38
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    39
(*The sum of the first n odd cubes*)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    40
lemma sum_of_odd_cubes:
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    41
     "n \<in> nat  
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    42
      ==> sum (%i. (i $+ i $+ #1) $* (i $+ i $+ #1) $* (i $+ i $+ #1), n) =  
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    43
          $#n $* $#n $* (#2 $* $#n $* $#n $- #1)"
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    44
by (induct_tac "n", auto)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    45
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    46
(*The sum of the first n positive integers equals n(n+1)/2.*)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    47
lemma sum_of_naturals:
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    48
     "n \<in> nat ==> #2 $* sum(%i. i, succ(n)) = $#n $* $#succ(n)"
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    49
by (induct_tac "n", auto)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    50
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    51
lemma sum_of_squares:
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    52
     "n \<in> nat ==> #6 $* sum (%i. i$*i, succ(n)) =  
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    53
                  $#n $* ($#n $+ #1) $* (#2 $* $#n $+ #1)"
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    54
by (induct_tac "n", auto)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    55
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    56
lemma sum_of_cubes:
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    57
     "n \<in> nat ==> #4 $* sum (%i. i$*i$*i, succ(n)) =  
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    58
                  $#n $* $#n $* ($#n $+ #1) $* ($#n $+ #1)"
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    59
by (induct_tac "n", auto)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    60
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    61
(** Sum of fourth powers **)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    62
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    63
lemma sum_of_fourth_powers:
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    64
     "n \<in> nat ==> #30 $* sum (%i. i$*i$*i$*i, succ(n)) =  
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    65
                    $#n $* ($#n $+ #1) $* (#2 $* $#n $+ #1) $*  
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    66
                    (#3 $* $#n $* $#n $+ #3 $* $#n $- #1)"
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    67
by (induct_tac "n", auto)
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    68
5c900a821a7c New-style versions of these old examples
paulson
parents: 9647
diff changeset
    69
end