src/HOL/Library/Formal_Power_Series.thy
author wenzelm
Sat, 23 May 2015 17:19:37 +0200
changeset 60299 5ae2a2e74c93
parent 60017 b785d6d06430
child 60162 645058aa9d6f
permissions -rw-r--r--
clarified NEWS: document_files are officially required since Isabelle2014, but the absence was tolerated as legacy feature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
41959
b460124855b8 tuned headers;
wenzelm
parents: 39302
diff changeset
     1
(*  Title:      HOL/Library/Formal_Power_Series.thy
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
     2
    Author:     Amine Chaieb, University of Cambridge
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
     3
*)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
     4
58881
b9556a055632 modernized header;
wenzelm
parents: 58709
diff changeset
     5
section{* A formalization of formal power series *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
     6
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
     7
theory Formal_Power_Series
59667
651ea265d568 Removal of the file HOL/Number_Theory/Binomial!! And class field_char_0 now declared in Int.thy
paulson <lp15@cam.ac.uk>
parents: 58881
diff changeset
     8
imports Complex_Main
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
     9
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    10
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
    11
subsection {* The type of formal power series*}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    12
49834
b27bbb021df1 discontinued obsolete typedef (open) syntax;
wenzelm
parents: 48757
diff changeset
    13
typedef 'a fps = "{f :: nat \<Rightarrow> 'a. True}"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    14
  morphisms fps_nth Abs_fps
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    15
  by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    16
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    17
notation fps_nth (infixl "$" 75)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    18
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    19
lemma expand_fps_eq: "p = q \<longleftrightarrow> (\<forall>n. p $ n = q $ n)"
39302
d7728f65b353 renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents: 39198
diff changeset
    20
  by (simp add: fps_nth_inject [symmetric] fun_eq_iff)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    21
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    22
lemma fps_ext: "(\<And>n. p $ n = q $ n) \<Longrightarrow> p = q"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    23
  by (simp add: expand_fps_eq)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    24
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    25
lemma fps_nth_Abs_fps [simp]: "Abs_fps f $ n = f n"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    26
  by (simp add: Abs_fps_inverse)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    27
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
    28
text{* Definition of the basic elements 0 and 1 and the basic operations of addition,
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
    29
  negation and multiplication *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    30
36409
d323e7773aa8 use new classes (linordered_)field_inverse_zero
haftmann
parents: 36350
diff changeset
    31
instantiation fps :: (zero) zero
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    32
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    33
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    34
definition fps_zero_def:
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    35
  "0 = Abs_fps (\<lambda>n. 0)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    36
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    37
instance ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    38
end
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    39
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    40
lemma fps_zero_nth [simp]: "0 $ n = 0"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    41
  unfolding fps_zero_def by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    42
36409
d323e7773aa8 use new classes (linordered_)field_inverse_zero
haftmann
parents: 36350
diff changeset
    43
instantiation fps :: ("{one, zero}") one
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    44
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    45
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    46
definition fps_one_def:
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    47
  "1 = Abs_fps (\<lambda>n. if n = 0 then 1 else 0)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    48
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    49
instance ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    50
end
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    51
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
    52
lemma fps_one_nth [simp]: "1 $ n = (if n = 0 then 1 else 0)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    53
  unfolding fps_one_def by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    54
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
    55
instantiation fps :: (plus) plus
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    56
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    57
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    58
definition fps_plus_def:
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    59
  "op + = (\<lambda>f g. Abs_fps (\<lambda>n. f $ n + g $ n))"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    60
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    61
instance ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    62
end
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    63
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    64
lemma fps_add_nth [simp]: "(f + g) $ n = f $ n + g $ n"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    65
  unfolding fps_plus_def by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    66
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    67
instantiation fps :: (minus) minus
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    68
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    69
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    70
definition fps_minus_def:
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    71
  "op - = (\<lambda>f g. Abs_fps (\<lambda>n. f $ n - g $ n))"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    72
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    73
instance ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    74
end
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    75
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    76
lemma fps_sub_nth [simp]: "(f - g) $ n = f $ n - g $ n"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    77
  unfolding fps_minus_def by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    78
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    79
instantiation fps :: (uminus) uminus
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    80
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    81
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    82
definition fps_uminus_def:
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    83
  "uminus = (\<lambda>f. Abs_fps (\<lambda>n. - (f $ n)))"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    84
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    85
instance ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    86
end
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    87
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    88
lemma fps_neg_nth [simp]: "(- f) $ n = - (f $ n)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    89
  unfolding fps_uminus_def by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    90
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
    91
instantiation fps :: ("{comm_monoid_add, times}") times
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    92
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    93
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    94
definition fps_times_def:
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    95
  "op * = (\<lambda>f g. Abs_fps (\<lambda>n. \<Sum>i=0..n. f $ i * g $ (n - i)))"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
    96
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    97
instance ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    98
end
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
    99
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   100
lemma fps_mult_nth: "(f * g) $ n = (\<Sum>i=0..n. f$i * g$(n - i))"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   101
  unfolding fps_times_def by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   102
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   103
declare atLeastAtMost_iff [presburger]
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   104
declare Bex_def [presburger]
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   105
declare Ball_def [presburger]
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   106
29913
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   107
lemma mult_delta_left:
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   108
  fixes x y :: "'a::mult_zero"
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   109
  shows "(if b then x else 0) * y = (if b then x * y else 0)"
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   110
  by simp
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   111
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   112
lemma mult_delta_right:
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   113
  fixes x y :: "'a::mult_zero"
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   114
  shows "x * (if b then y else 0) = (if b then x * y else 0)"
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   115
  by simp
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
   116
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   117
lemma cond_value_iff: "f (if b then x else y) = (if b then f x else f y)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   118
  by auto
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   119
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   120
lemma cond_application_beta: "(if b then f else g) x = (if b then f x else g x)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   121
  by auto
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   122
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   123
subsection{* Formal power series form a commutative ring with unity, if the range of sequences
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   124
  they represent is a commutative ring with unity*}
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   125
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   126
instance fps :: (semigroup_add) semigroup_add
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   127
proof
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   128
  fix a b c :: "'a fps"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   129
  show "a + b + c = a + (b + c)"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   130
    by (simp add: fps_ext add.assoc)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   131
qed
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   132
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   133
instance fps :: (ab_semigroup_add) ab_semigroup_add
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   134
proof
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   135
  fix a b :: "'a fps"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   136
  show "a + b = b + a"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   137
    by (simp add: fps_ext add.commute)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   138
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   139
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   140
lemma fps_mult_assoc_lemma:
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   141
  fixes k :: nat
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   142
    and f :: "nat \<Rightarrow> nat \<Rightarrow> nat \<Rightarrow> 'a::comm_monoid_add"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   143
  shows "(\<Sum>j=0..k. \<Sum>i=0..j. f i (j - i) (n - j)) =
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   144
         (\<Sum>j=0..k. \<Sum>i=0..k - j. f j i (n - j - i))"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   145
  by (induct k) (simp_all add: Suc_diff_le setsum.distrib add.assoc)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   146
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   147
instance fps :: (semiring_0) semigroup_mult
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   148
proof
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   149
  fix a b c :: "'a fps"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   150
  show "(a * b) * c = a * (b * c)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   151
  proof (rule fps_ext)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   152
    fix n :: nat
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   153
    have "(\<Sum>j=0..n. \<Sum>i=0..j. a$i * b$(j - i) * c$(n - j)) =
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   154
          (\<Sum>j=0..n. \<Sum>i=0..n - j. a$j * b$i * c$(n - j - i))"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   155
      by (rule fps_mult_assoc_lemma)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   156
    then show "((a * b) * c) $ n = (a * (b * c)) $ n"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   157
      by (simp add: fps_mult_nth setsum_right_distrib setsum_left_distrib mult.assoc)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   158
  qed
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   159
qed
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   160
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   161
lemma fps_mult_commute_lemma:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   162
  fixes n :: nat
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   163
    and f :: "nat \<Rightarrow> nat \<Rightarrow> 'a::comm_monoid_add"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   164
  shows "(\<Sum>i=0..n. f i (n - i)) = (\<Sum>i=0..n. f (n - i) i)"
57129
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
   165
  by (rule setsum.reindex_bij_witness[where i="op - n" and j="op - n"]) auto
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   166
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   167
instance fps :: (comm_semiring_0) ab_semigroup_mult
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   168
proof
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   169
  fix a b :: "'a fps"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   170
  show "a * b = b * a"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   171
  proof (rule fps_ext)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   172
    fix n :: nat
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   173
    have "(\<Sum>i=0..n. a$i * b$(n - i)) = (\<Sum>i=0..n. a$(n - i) * b$i)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   174
      by (rule fps_mult_commute_lemma)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   175
    then show "(a * b) $ n = (b * a) $ n"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   176
      by (simp add: fps_mult_nth mult.commute)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   177
  qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   178
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   179
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   180
instance fps :: (monoid_add) monoid_add
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   181
proof
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   182
  fix a :: "'a fps"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   183
  show "0 + a = a" by (simp add: fps_ext)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   184
  show "a + 0 = a" by (simp add: fps_ext)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   185
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   186
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   187
instance fps :: (comm_monoid_add) comm_monoid_add
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   188
proof
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   189
  fix a :: "'a fps"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   190
  show "0 + a = a" by (simp add: fps_ext)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   191
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   192
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   193
instance fps :: (semiring_1) monoid_mult
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   194
proof
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   195
  fix a :: "'a fps"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   196
  show "1 * a = a" by (simp add: fps_ext fps_mult_nth mult_delta_left setsum.delta)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   197
  show "a * 1 = a" by (simp add: fps_ext fps_mult_nth mult_delta_right setsum.delta')
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   198
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   199
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   200
instance fps :: (cancel_semigroup_add) cancel_semigroup_add
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   201
proof
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   202
  fix a b c :: "'a fps"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   203
  { assume "a + b = a + c" then show "b = c" by (simp add: expand_fps_eq) }
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   204
  { assume "b + a = c + a" then show "b = c" by (simp add: expand_fps_eq) }
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   205
qed
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   206
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   207
instance fps :: (cancel_ab_semigroup_add) cancel_ab_semigroup_add
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   208
proof
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   209
  fix a b c :: "'a fps"
59815
cce82e360c2f explicit commutative additive inverse operation;
haftmann
parents: 59741
diff changeset
   210
  show "a + b - a = b" by (simp add: expand_fps_eq)
cce82e360c2f explicit commutative additive inverse operation;
haftmann
parents: 59741
diff changeset
   211
  show "a - b - c = a - (b + c)" by (simp add: expand_fps_eq diff_diff_eq)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   212
qed
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   213
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   214
instance fps :: (cancel_comm_monoid_add) cancel_comm_monoid_add ..
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   215
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   216
instance fps :: (group_add) group_add
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   217
proof
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   218
  fix a b :: "'a fps"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   219
  show "- a + a = 0" by (simp add: fps_ext)
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53374
diff changeset
   220
  show "a + - b = a - b" by (simp add: fps_ext)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   221
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   222
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   223
instance fps :: (ab_group_add) ab_group_add
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   224
proof
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   225
  fix a b :: "'a fps"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   226
  show "- a + a = 0" by (simp add: fps_ext)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   227
  show "a - b = a + - b" by (simp add: fps_ext)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   228
qed
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   229
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   230
instance fps :: (zero_neq_one) zero_neq_one
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   231
  by default (simp add: expand_fps_eq)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   232
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   233
instance fps :: (semiring_0) semiring
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   234
proof
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   235
  fix a b c :: "'a fps"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   236
  show "(a + b) * c = a * c + b * c"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   237
    by (simp add: expand_fps_eq fps_mult_nth distrib_right setsum.distrib)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   238
  show "a * (b + c) = a * b + a * c"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   239
    by (simp add: expand_fps_eq fps_mult_nth distrib_left setsum.distrib)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   240
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   241
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   242
instance fps :: (semiring_0) semiring_0
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   243
proof
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   244
  fix a :: "'a fps"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   245
  show "0 * a = 0" by (simp add: fps_ext fps_mult_nth)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   246
  show "a * 0 = 0" by (simp add: fps_ext fps_mult_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   247
qed
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   248
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   249
instance fps :: (semiring_0_cancel) semiring_0_cancel ..
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   250
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
   251
subsection {* Selection of the nth power of the implicit variable in the infinite sum*}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   252
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   253
lemma fps_nonzero_nth: "f \<noteq> 0 \<longleftrightarrow> (\<exists> n. f $n \<noteq> 0)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   254
  by (simp add: expand_fps_eq)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   255
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   256
lemma fps_nonzero_nth_minimal: "f \<noteq> 0 \<longleftrightarrow> (\<exists>n. f $ n \<noteq> 0 \<and> (\<forall>m < n. f $ m = 0))"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   257
proof
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   258
  let ?n = "LEAST n. f $ n \<noteq> 0"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   259
  assume "f \<noteq> 0"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   260
  then have "\<exists>n. f $ n \<noteq> 0"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   261
    by (simp add: fps_nonzero_nth)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   262
  then have "f $ ?n \<noteq> 0"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   263
    by (rule LeastI_ex)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   264
  moreover have "\<forall>m<?n. f $ m = 0"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   265
    by (auto dest: not_less_Least)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   266
  ultimately have "f $ ?n \<noteq> 0 \<and> (\<forall>m<?n. f $ m = 0)" ..
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   267
  then show "\<exists>n. f $ n \<noteq> 0 \<and> (\<forall>m<n. f $ m = 0)" ..
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   268
next
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   269
  assume "\<exists>n. f $ n \<noteq> 0 \<and> (\<forall>m<n. f $ m = 0)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   270
  then show "f \<noteq> 0" by (auto simp add: expand_fps_eq)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   271
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   272
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   273
lemma fps_eq_iff: "f = g \<longleftrightarrow> (\<forall>n. f $ n = g $n)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   274
  by (rule expand_fps_eq)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   275
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   276
lemma fps_setsum_nth: "setsum f S $ n = setsum (\<lambda>k. (f k) $ n) S"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   277
proof (cases "finite S")
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   278
  case True
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   279
  then show ?thesis by (induct set: finite) auto
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   280
next
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   281
  case False
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   282
  then show ?thesis by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   283
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   284
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
   285
subsection{* Injection of the basic ring elements and multiplication by scalars *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   286
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   287
definition "fps_const c = Abs_fps (\<lambda>n. if n = 0 then c else 0)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   288
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   289
lemma fps_nth_fps_const [simp]: "fps_const c $ n = (if n = 0 then c else 0)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   290
  unfolding fps_const_def by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   291
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   292
lemma fps_const_0_eq_0 [simp]: "fps_const 0 = 0"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   293
  by (simp add: fps_ext)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   294
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   295
lemma fps_const_1_eq_1 [simp]: "fps_const 1 = 1"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   296
  by (simp add: fps_ext)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   297
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   298
lemma fps_const_neg [simp]: "- (fps_const (c::'a::ring)) = fps_const (- c)"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   299
  by (simp add: fps_ext)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   300
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   301
lemma fps_const_add [simp]: "fps_const (c::'a::monoid_add) + fps_const d = fps_const (c + d)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   302
  by (simp add: fps_ext)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   303
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   304
lemma fps_const_sub [simp]: "fps_const (c::'a::group_add) - fps_const d = fps_const (c - d)"
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
   305
  by (simp add: fps_ext)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   306
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   307
lemma fps_const_mult[simp]: "fps_const (c::'a::ring) * fps_const d = fps_const (c * d)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   308
  by (simp add: fps_eq_iff fps_mult_nth setsum.neutral)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   309
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   310
lemma fps_const_add_left: "fps_const (c::'a::monoid_add) + f =
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   311
    Abs_fps (\<lambda>n. if n = 0 then c + f$0 else f$n)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   312
  by (simp add: fps_ext)
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   313
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   314
lemma fps_const_add_right: "f + fps_const (c::'a::monoid_add) =
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   315
    Abs_fps (\<lambda>n. if n = 0 then f$0 + c else f$n)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   316
  by (simp add: fps_ext)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   317
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   318
lemma fps_const_mult_left: "fps_const (c::'a::semiring_0) * f = Abs_fps (\<lambda>n. c * f$n)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   319
  unfolding fps_eq_iff fps_mult_nth
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   320
  by (simp add: fps_const_def mult_delta_left setsum.delta)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   321
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   322
lemma fps_const_mult_right: "f * fps_const (c::'a::semiring_0) = Abs_fps (\<lambda>n. f$n * c)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   323
  unfolding fps_eq_iff fps_mult_nth
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   324
  by (simp add: fps_const_def mult_delta_right setsum.delta')
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   325
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   326
lemma fps_mult_left_const_nth [simp]: "(fps_const (c::'a::semiring_1) * f)$n = c* f$n"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   327
  by (simp add: fps_mult_nth mult_delta_left setsum.delta)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   328
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   329
lemma fps_mult_right_const_nth [simp]: "(f * fps_const (c::'a::semiring_1))$n = f$n * c"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   330
  by (simp add: fps_mult_nth mult_delta_right setsum.delta')
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   331
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
   332
subsection {* Formal power series form an integral domain*}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   333
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   334
instance fps :: (ring) ring ..
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   335
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   336
instance fps :: (ring_1) ring_1
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53374
diff changeset
   337
  by (intro_classes, auto simp add: distrib_right)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   338
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   339
instance fps :: (comm_ring_1) comm_ring_1
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53374
diff changeset
   340
  by (intro_classes, auto simp add: distrib_right)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   341
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   342
instance fps :: (ring_no_zero_divisors) ring_no_zero_divisors
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   343
proof
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   344
  fix a b :: "'a fps"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   345
  assume a0: "a \<noteq> 0" and b0: "b \<noteq> 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   346
  then obtain i j where i: "a$i\<noteq>0" "\<forall>k<i. a$k=0" and j: "b$j \<noteq>0" "\<forall>k<j. b$k =0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   347
    unfolding fps_nonzero_nth_minimal
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   348
    by blast+
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   349
  have "(a * b) $ (i+j) = (\<Sum>k=0..i+j. a$k * b$(i+j-k))"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   350
    by (rule fps_mult_nth)
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   351
  also have "\<dots> = (a$i * b$(i+j-i)) + (\<Sum>k\<in>{0..i+j}-{i}. a$k * b$(i+j-k))"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   352
    by (rule setsum.remove) simp_all
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   353
  also have "(\<Sum>k\<in>{0..i+j}-{i}. a$k * b$(i+j-k)) = 0"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   354
    proof (rule setsum.neutral [rule_format])
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   355
      fix k assume "k \<in> {0..i+j} - {i}"
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   356
      then have "k < i \<or> i+j-k < j" by auto
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   357
      then show "a$k * b$(i+j-k) = 0" using i j by auto
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   358
    qed
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   359
  also have "a$i * b$(i+j-i) + 0 = a$i * b$j" by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   360
  also have "a$i * b$j \<noteq> 0" using i j by simp
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   361
  finally have "(a*b) $ (i+j) \<noteq> 0" .
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   362
  then show "a*b \<noteq> 0" unfolding fps_nonzero_nth by blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   363
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   364
36311
ed3a87a7f977 epheremal replacement of field_simps by field_eq_simps; dropped old division_by_zero instance
haftmann
parents: 36309
diff changeset
   365
instance fps :: (ring_1_no_zero_divisors) ring_1_no_zero_divisors ..
ed3a87a7f977 epheremal replacement of field_simps by field_eq_simps; dropped old division_by_zero instance
haftmann
parents: 36309
diff changeset
   366
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   367
instance fps :: (idom) idom ..
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   368
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
   369
lemma numeral_fps_const: "numeral k = fps_const (numeral k)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   370
  by (induct k) (simp_all only: numeral.simps fps_const_1_eq_1
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
   371
    fps_const_add [symmetric])
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
   372
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
   373
lemma neg_numeral_fps_const: "- numeral k = fps_const (- numeral k)"
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
   374
  by (simp only: numeral_fps_const fps_const_neg)
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
   375
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   376
subsection{* The eXtractor series X*}
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   377
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   378
lemma minus_one_power_iff: "(- (1::'a::comm_ring_1)) ^ n = (if even n then 1 else - 1)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   379
  by (induct n) auto
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   380
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   381
definition "X = Abs_fps (\<lambda>n. if n = 1 then 1 else 0)"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   382
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   383
lemma X_mult_nth [simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   384
  "(X * (f :: 'a::semiring_1 fps)) $n = (if n = 0 then 0 else f $ (n - 1))"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   385
proof (cases "n = 0")
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   386
  case False
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   387
  have "(X * f) $n = (\<Sum>i = 0..n. X $ i * f $ (n - i))"
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   388
    by (simp add: fps_mult_nth)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   389
  also have "\<dots> = f $ (n - 1)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   390
    using False by (simp add: X_def mult_delta_left setsum.delta)
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   391
  finally show ?thesis using False by simp
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   392
next
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   393
  case True
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   394
  then show ?thesis by (simp add: fps_mult_nth X_def)
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   395
qed
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   396
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   397
lemma X_mult_right_nth[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   398
    "((f :: 'a::comm_semiring_1 fps) * X) $n = (if n = 0 then 0 else f $ (n - 1))"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   399
  by (metis X_mult_nth mult.commute)
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   400
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   401
lemma X_power_iff: "X^k = Abs_fps (\<lambda>n. if n = k then 1::'a::comm_ring_1 else 0)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   402
proof (induct k)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   403
  case 0
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
   404
  then show ?case by (simp add: X_def fps_eq_iff)
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   405
next
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   406
  case (Suc k)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   407
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   408
    fix m
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   409
    have "(X^Suc k) $ m = (if m = 0 then 0::'a else (X^k) $ (m - 1))"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   410
      by (simp del: One_nat_def)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   411
    then have "(X^Suc k) $ m = (if m = Suc k then 1::'a else 0)"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   412
      using Suc.hyps by (auto cong del: if_weak_cong)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   413
  }
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   414
  then show ?case by (simp add: fps_eq_iff)
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   415
qed
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   416
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   417
lemma X_power_mult_nth:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   418
    "(X^k * (f :: 'a::comm_ring_1 fps)) $n = (if n < k then 0 else f $ (n - k))"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   419
  apply (induct k arbitrary: n)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   420
  apply simp
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   421
  unfolding power_Suc mult.assoc
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   422
  apply (case_tac n)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   423
  apply auto
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   424
  done
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   425
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   426
lemma X_power_mult_right_nth:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   427
    "((f :: 'a::comm_ring_1 fps) * X^k) $n = (if n < k then 0 else f $ (n - k))"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   428
  by (metis X_power_mult_nth mult.commute)
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   429
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   430
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   431
subsection{* Formal Power series form a metric space *}
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   432
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   433
definition (in dist) "ball x r = {y. dist y x < r}"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   434
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   435
instantiation fps :: (comm_ring_1) dist
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   436
begin
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   437
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   438
definition
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   439
  dist_fps_def: "dist (a :: 'a fps) b =
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   440
    (if (\<exists>n. a$n \<noteq> b$n) then inverse (2 ^ (LEAST n. a$n \<noteq> b$n)) else 0)"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   441
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   442
lemma dist_fps_ge0: "dist (a :: 'a fps) b \<ge> 0"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   443
  by (simp add: dist_fps_def)
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   444
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   445
lemma dist_fps_sym: "dist (a :: 'a fps) b = dist b a"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   446
  apply (auto simp add: dist_fps_def)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   447
  apply (rule cong[OF refl, where x="(\<lambda>n. a $ n \<noteq> b $ n)"])
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   448
  apply (rule ext)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   449
  apply auto
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   450
  done
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   451
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   452
instance ..
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   453
30746
d6915b738bd9 fps made instance of number_ring
chaieb
parents: 30488
diff changeset
   454
end
d6915b738bd9 fps made instance of number_ring
chaieb
parents: 30488
diff changeset
   455
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   456
instantiation fps :: (comm_ring_1) metric_space
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   457
begin
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   458
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   459
definition open_fps_def: "open (S :: 'a fps set) = (\<forall>a \<in> S. \<exists>r. r >0 \<and> ball a r \<subseteq> S)"
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   460
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   461
instance
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   462
proof
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   463
  fix S :: "'a fps set"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   464
  show "open S = (\<forall>x\<in>S. \<exists>e>0. \<forall>y. dist y x < e \<longrightarrow> y \<in> S)"
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   465
    by (auto simp add: open_fps_def ball_def subset_eq)
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   466
next
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   467
  {
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   468
    fix a b :: "'a fps"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   469
    {
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   470
      assume "a = b"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   471
      then have "\<not> (\<exists>n. a $ n \<noteq> b $ n)" by simp
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   472
      then have "dist a b = 0" by (simp add: dist_fps_def)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   473
    }
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   474
    moreover
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   475
    {
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   476
      assume d: "dist a b = 0"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   477
      then have "\<forall>n. a$n = b$n"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   478
        by - (rule ccontr, simp add: dist_fps_def)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   479
      then have "a = b" by (simp add: fps_eq_iff)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   480
    }
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   481
    ultimately show "dist a b =0 \<longleftrightarrow> a = b" by blast
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   482
  }
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   483
  note th = this
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   484
  from th have th'[simp]: "\<And>a::'a fps. dist a a = 0" by simp
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   485
  fix a b c :: "'a fps"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   486
  {
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   487
    assume "a = b"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   488
    then have "dist a b = 0" unfolding th .
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   489
    then have "dist a b \<le> dist a c + dist b c"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   490
      using dist_fps_ge0 [of a c] dist_fps_ge0 [of b c] by simp
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   491
  }
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   492
  moreover
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   493
  {
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   494
    assume "c = a \<or> c = b"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   495
    then have "dist a b \<le> dist a c + dist b c"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   496
      by (cases "c = a") (simp_all add: th dist_fps_sym)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   497
  }
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   498
  moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   499
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   500
    assume ab: "a \<noteq> b" and ac: "a \<noteq> c" and bc: "b \<noteq> c"
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   501
    def n \<equiv> "\<lambda>a b::'a fps. LEAST n. a$n \<noteq> b$n"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   502
    then have n': "\<And>m a b. m < n a b \<Longrightarrow> a$m = b$m"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   503
      by (auto dest: not_less_Least)
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   504
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   505
    from ab ac bc
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   506
    have dab: "dist a b = inverse (2 ^ n a b)"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   507
      and dac: "dist a c = inverse (2 ^ n a c)"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   508
      and dbc: "dist b c = inverse (2 ^ n b c)"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   509
      by (simp_all add: dist_fps_def n_def fps_eq_iff)
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   510
    from ab ac bc have nz: "dist a b \<noteq> 0" "dist a c \<noteq> 0" "dist b c \<noteq> 0"
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   511
      unfolding th by simp_all
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   512
    from nz have pos: "dist a b > 0" "dist a c > 0" "dist b c > 0"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   513
      using dist_fps_ge0[of a b] dist_fps_ge0[of a c] dist_fps_ge0[of b c]
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   514
      by auto
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   515
    have th1: "\<And>n. (2::real)^n >0" by auto
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   516
    {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   517
      assume h: "dist a b > dist a c + dist b c"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   518
      then have gt: "dist a b > dist a c" "dist a b > dist b c"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
   519
        using pos by auto
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   520
      from gt have gtn: "n a b < n b c" "n a b < n a c"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
   521
        unfolding dab dbc dac by (auto simp add: th1)
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   522
      from n'[OF gtn(2)] n'(1)[OF gtn(1)]
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   523
      have "a $ n a b = b $ n a b" by simp
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   524
      moreover have "a $ n a b \<noteq> b $ n a b"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   525
         unfolding n_def by (rule LeastI_ex) (insert ab, simp add: fps_eq_iff)
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   526
      ultimately have False by contradiction
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   527
    }
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   528
    then have "dist a b \<le> dist a c + dist b c"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   529
      by (auto simp add: not_le[symmetric])
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   530
  }
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   531
  ultimately show "dist a b \<le> dist a c + dist b c" by blast
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   532
qed
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   533
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   534
end
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   535
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   536
text{* The infinite sums and justification of the notation in textbooks*}
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   537
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   538
lemma reals_power_lt_ex:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   539
  fixes x y :: real
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   540
  assumes xp: "x > 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   541
    and y1: "y > 1"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   542
  shows "\<exists>k>0. (1/y)^k < x"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   543
proof -
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   544
  have yp: "y > 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   545
    using y1 by simp
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   546
  from reals_Archimedean2[of "max 0 (- log y x) + 1"]
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   547
  obtain k :: nat where k: "real k > max 0 (- log y x) + 1"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   548
    by blast
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   549
  from k have kp: "k > 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   550
    by simp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   551
  from k have "real k > - log y x"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   552
    by simp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   553
  then have "ln y * real k > - ln x"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   554
    unfolding log_def
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   555
    using ln_gt_zero_iff[OF yp] y1
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   556
    by (simp add: minus_divide_left field_simps del: minus_divide_left[symmetric])
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   557
  then have "ln y * real k + ln x > 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   558
    by simp
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   559
  then have "exp (real k * ln y + ln x) > exp 0"
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
   560
    by (simp add: ac_simps)
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   561
  then have "y ^ k * x > 1"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   562
    unfolding exp_zero exp_add exp_real_of_nat_mult exp_ln [OF xp] exp_ln [OF yp]
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   563
    by simp
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   564
  then have "x > (1 / y)^k" using yp
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
   565
    by (simp add: field_simps nonzero_power_divide)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   566
  then show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   567
    using kp by blast
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   568
qed
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   569
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   570
lemma X_nth[simp]: "X$n = (if n = 1 then 1 else 0)"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   571
  by (simp add: X_def)
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   572
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   573
lemma X_power_nth[simp]: "(X^k) $n = (if n = k then 1 else 0::'a::comm_ring_1)"
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   574
  by (simp add: X_power_iff)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   575
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
   576
lemma fps_sum_rep_nth: "(setsum (\<lambda>i. fps_const(a$i)*X^i) {0..m})$n =
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   577
    (if n \<le> m then a$n else 0::'a::comm_ring_1)"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   578
  apply (auto simp add: fps_setsum_nth cond_value_iff cong del: if_weak_cong)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   579
  apply (simp add: setsum.delta')
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   580
  done
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   581
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
   582
lemma fps_notation: "(\<lambda>n. setsum (\<lambda>i. fps_const(a$i) * X^i) {0..n}) ----> a"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   583
  (is "?s ----> a")
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   584
proof -
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   585
  {
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   586
    fix r :: real
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   587
    assume rp: "r > 0"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   588
    have th0: "(2::real) > 1" by simp
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   589
    from reals_power_lt_ex[OF rp th0]
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   590
    obtain n0 where n0: "(1/2)^n0 < r" "n0 > 0" by blast
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   591
    {
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   592
      fix n :: nat
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   593
      assume nn0: "n \<ge> n0"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
   594
      then have thnn0: "(1/2)^n \<le> (1/2 :: real)^n0"
59741
5b762cd73a8e Lots of new material on complex-valued functions. Modified simplification of (x/n)^k
paulson <lp15@cam.ac.uk>
parents: 59730
diff changeset
   595
        by (simp add: divide_simps)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   596
      {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   597
        assume "?s n = a"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   598
        then have "dist (?s n) a < r"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   599
          unfolding dist_eq_0_iff[of "?s n" a, symmetric]
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   600
          using rp by (simp del: dist_eq_0_iff)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   601
      }
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   602
      moreover
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   603
      {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   604
        assume neq: "?s n \<noteq> a"
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   605
        def k \<equiv> "LEAST i. ?s n $ i \<noteq> a $ i"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   606
        from neq have dth: "dist (?s n) a = (1/2)^k"
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   607
          by (auto simp add: dist_fps_def inverse_eq_divide power_divide k_def fps_eq_iff)
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   608
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
   609
        from neq have kn: "k > n"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   610
          by (auto simp: fps_sum_rep_nth not_le k_def fps_eq_iff
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   611
              split: split_if_asm intro: LeastI2_ex)
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   612
        then have "dist (?s n) a < (1/2)^n"
59741
5b762cd73a8e Lots of new material on complex-valued functions. Modified simplification of (x/n)^k
paulson <lp15@cam.ac.uk>
parents: 59730
diff changeset
   613
          unfolding dth by (simp add: divide_simps)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   614
        also have "\<dots> \<le> (1/2)^n0"
59741
5b762cd73a8e Lots of new material on complex-valued functions. Modified simplification of (x/n)^k
paulson <lp15@cam.ac.uk>
parents: 59730
diff changeset
   615
          using nn0 by (simp add: divide_simps)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   616
        also have "\<dots> < r"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   617
          using n0 by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   618
        finally have "dist (?s n) a < r" .
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   619
      }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   620
      ultimately have "dist (?s n) a < r"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   621
        by blast
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   622
    }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   623
    then have "\<exists>n0. \<forall> n \<ge> n0. dist (?s n) a < r"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   624
      by blast
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   625
  }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   626
  then show ?thesis
60017
b785d6d06430 Overloading of ln and powr, but "approximation" no longer works for powr. Code generation also fails due to type ambiguity in scala.
paulson <lp15@cam.ac.uk>
parents: 59867
diff changeset
   627
    unfolding lim_sequentially by blast
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   628
qed
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   629
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   630
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
   631
subsection{* Inverses of formal power series *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   632
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   633
declare setsum.cong[fundef_cong]
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   634
36311
ed3a87a7f977 epheremal replacement of field_simps by field_eq_simps; dropped old division_by_zero instance
haftmann
parents: 36309
diff changeset
   635
instantiation fps :: ("{comm_monoid_add, inverse, times, uminus}") inverse
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   636
begin
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   637
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   638
fun natfun_inverse:: "'a fps \<Rightarrow> nat \<Rightarrow> 'a"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   639
where
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   640
  "natfun_inverse f 0 = inverse (f$0)"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   641
| "natfun_inverse f n = - inverse (f$0) * setsum (\<lambda>i. f$i * natfun_inverse f (n - i)) {1..n}"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   642
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   643
definition
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   644
  fps_inverse_def: "inverse f = (if f $ 0 = 0 then 0 else Abs_fps (natfun_inverse f))"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   645
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   646
definition
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   647
  fps_divide_def: "divide = (\<lambda>(f::'a fps) g. f * inverse g)"
36311
ed3a87a7f977 epheremal replacement of field_simps by field_eq_simps; dropped old division_by_zero instance
haftmann
parents: 36309
diff changeset
   648
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   649
instance ..
36311
ed3a87a7f977 epheremal replacement of field_simps by field_eq_simps; dropped old division_by_zero instance
haftmann
parents: 36309
diff changeset
   650
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   651
end
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   652
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   653
lemma fps_inverse_zero [simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   654
  "inverse (0 :: 'a::{comm_monoid_add,inverse,times,uminus} fps) = 0"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   655
  by (simp add: fps_ext fps_inverse_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   656
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   657
lemma fps_inverse_one [simp]: "inverse (1 :: 'a::{division_ring,zero_neq_one} fps) = 1"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   658
  apply (auto simp add: expand_fps_eq fps_inverse_def)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   659
  apply (case_tac n)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   660
  apply auto
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   661
  done
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   662
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   663
lemma inverse_mult_eq_1 [intro]:
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   664
  assumes f0: "f$0 \<noteq> (0::'a::field)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   665
  shows "inverse f * f = 1"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   666
proof -
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   667
  have c: "inverse f * f = f * inverse f"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   668
    by (simp add: mult.commute)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   669
  from f0 have ifn: "\<And>n. inverse f $ n = natfun_inverse f n"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   670
    by (simp add: fps_inverse_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   671
  from f0 have th0: "(inverse f * f) $ 0 = 1"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   672
    by (simp add: fps_mult_nth fps_inverse_def)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   673
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   674
    fix n :: nat
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   675
    assume np: "n > 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   676
    from np have eq: "{0..n} = {0} \<union> {1 .. n}"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   677
      by auto
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   678
    have d: "{0} \<inter> {1 .. n} = {}"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   679
      by auto
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   680
    from f0 np have th0: "- (inverse f $ n) =
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   681
      (setsum (\<lambda>i. f$i * natfun_inverse f (n - i)) {1..n}) / (f$0)"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   682
      by (cases n) (simp_all add: divide_inverse fps_inverse_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   683
    from th0[symmetric, unfolded nonzero_divide_eq_eq[OF f0]]
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   684
    have th1: "setsum (\<lambda>i. f$i * natfun_inverse f (n - i)) {1..n} = - (f$0) * (inverse f)$n"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
   685
      by (simp add: field_simps)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   686
    have "(f * inverse f) $ n = (\<Sum>i = 0..n. f $i * natfun_inverse f (n - i))"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   687
      unfolding fps_mult_nth ifn ..
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   688
    also have "\<dots> = f$0 * natfun_inverse f n + (\<Sum>i = 1..n. f$i * natfun_inverse f (n-i))"
46757
ad878aff9c15 removing finiteness goals
bulwahn
parents: 46131
diff changeset
   689
      by (simp add: eq)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   690
    also have "\<dots> = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   691
      unfolding th1 ifn by simp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   692
    finally have "(inverse f * f)$n = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   693
      unfolding c .
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   694
  }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   695
  with th0 show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   696
    by (simp add: fps_eq_iff)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   697
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   698
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   699
lemma fps_inverse_0_iff[simp]: "(inverse f)$0 = (0::'a::division_ring) \<longleftrightarrow> f$0 = 0"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   700
  by (simp add: fps_inverse_def nonzero_imp_inverse_nonzero)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   701
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   702
lemma fps_inverse_eq_0_iff[simp]: "inverse f = (0:: ('a::field) fps) \<longleftrightarrow> f $0 = 0"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   703
proof -
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   704
  {
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   705
    assume "f $ 0 = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   706
    then have "inverse f = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   707
      by (simp add: fps_inverse_def)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   708
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   709
  moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   710
  {
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   711
    assume h: "inverse f = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   712
    assume c: "f $0 \<noteq> 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   713
    from inverse_mult_eq_1[OF c] h have False
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   714
      by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   715
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   716
  ultimately show ?thesis by blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   717
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   718
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   719
lemma fps_inverse_idempotent[intro]:
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   720
  assumes f0: "f$0 \<noteq> (0::'a::field)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   721
  shows "inverse (inverse f) = f"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   722
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   723
  from f0 have if0: "inverse f $ 0 \<noteq> 0" by simp
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   724
  from inverse_mult_eq_1[OF f0] inverse_mult_eq_1[OF if0]
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   725
  have "inverse f * f = inverse f * inverse (inverse f)"
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
   726
    by (simp add: ac_simps)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   727
  then show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   728
    using f0 unfolding mult_cancel_left by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   729
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   730
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   731
lemma fps_inverse_unique:
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   732
  assumes f0: "f$0 \<noteq> (0::'a::field)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   733
    and fg: "f*g = 1"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   734
  shows "inverse f = g"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   735
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   736
  from inverse_mult_eq_1[OF f0] fg
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   737
  have th0: "inverse f * f = g * f"
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
   738
    by (simp add: ac_simps)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   739
  then show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   740
    using f0
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   741
    unfolding mult_cancel_right
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   742
    by (auto simp add: expand_fps_eq)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   743
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   744
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   745
lemma fps_inverse_gp: "inverse (Abs_fps(\<lambda>n. (1::'a::field)))
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   746
    = Abs_fps (\<lambda>n. if n= 0 then 1 else if n=1 then - 1 else 0)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   747
  apply (rule fps_inverse_unique)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   748
  apply simp
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   749
  apply (simp add: fps_eq_iff fps_mult_nth)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   750
  apply clarsimp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   751
proof -
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   752
  fix n :: nat
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   753
  assume n: "n > 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   754
  let ?f = "\<lambda>i. if n = i then (1::'a) else if n - i = 1 then - 1 else 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   755
  let ?g = "\<lambda>i. if i = n then 1 else if i=n - 1 then - 1 else 0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   756
  let ?h = "\<lambda>i. if i=n - 1 then - 1 else 0"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   757
  have th1: "setsum ?f {0..n} = setsum ?g {0..n}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   758
    by (rule setsum.cong) auto
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   759
  have th2: "setsum ?g {0..n - 1} = setsum ?h {0..n - 1}"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   760
    apply (insert n)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   761
    apply (rule setsum.cong)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   762
    apply auto
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   763
    done
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   764
  have eq: "{0 .. n} = {0.. n - 1} \<union> {n}"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   765
    by auto
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   766
  from n have d: "{0.. n - 1} \<inter> {n} = {}"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   767
    by auto
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   768
  have f: "finite {0.. n - 1}" "finite {n}"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   769
    by auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   770
  show "setsum ?f {0..n} = 0"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   771
    unfolding th1
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   772
    apply (simp add: setsum.union_disjoint[OF f d, unfolded eq[symmetric]] del: One_nat_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   773
    unfolding th2
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   774
    apply (simp add: setsum.delta)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   775
    done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   776
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   777
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   778
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   779
subsection {* Formal Derivatives, and the MacLaurin theorem around 0 *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   780
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   781
definition "fps_deriv f = Abs_fps (\<lambda>n. of_nat (n + 1) * f $ (n + 1))"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   782
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   783
lemma fps_deriv_nth[simp]: "fps_deriv f $ n = of_nat (n +1) * f $ (n + 1)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   784
  by (simp add: fps_deriv_def)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   785
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   786
lemma fps_deriv_linear[simp]:
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   787
  "fps_deriv (fps_const (a::'a::comm_semiring_1) * f + fps_const b * g) =
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   788
    fps_const a * fps_deriv f + fps_const b * fps_deriv g"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
   789
  unfolding fps_eq_iff fps_add_nth  fps_const_mult_left fps_deriv_nth by (simp add: field_simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   790
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   791
lemma fps_deriv_mult[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   792
  fixes f :: "'a::comm_ring_1 fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   793
  shows "fps_deriv (f * g) = f * fps_deriv g + fps_deriv f * g"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   794
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   795
  let ?D = "fps_deriv"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   796
  {
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   797
    fix n :: nat
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   798
    let ?Zn = "{0 ..n}"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   799
    let ?Zn1 = "{0 .. n + 1}"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   800
    let ?g = "\<lambda>i. of_nat (i+1) * g $ (i+1) * f $ (n - i) +
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   801
        of_nat (i+1)* f $ (i+1) * g $ (n - i)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   802
    let ?h = "\<lambda>i. of_nat i * g $ i * f $ ((n+1) - i) +
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   803
        of_nat i* f $ i * g $ ((n + 1) - i)"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   804
    have s0: "setsum (\<lambda>i. of_nat i * f $ i * g $ (n + 1 - i)) ?Zn1 =
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   805
      setsum (\<lambda>i. of_nat (n + 1 - i) * f $ (n + 1 - i) * g $ i) ?Zn1"
57129
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
   806
       by (rule setsum.reindex_bij_witness[where i="op - (n + 1)" and j="op - (n + 1)"]) auto
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   807
    have s1: "setsum (\<lambda>i. f $ i * g $ (n + 1 - i)) ?Zn1 =
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   808
      setsum (\<lambda>i. f $ (n + 1 - i) * g $ i) ?Zn1"
57129
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
   809
       by (rule setsum.reindex_bij_witness[where i="op - (n + 1)" and j="op - (n + 1)"]) auto
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   810
    have "(f * ?D g + ?D f * g)$n = (?D g * f + ?D f * g)$n"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   811
      by (simp only: mult.commute)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   812
    also have "\<dots> = (\<Sum>i = 0..n. ?g i)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   813
      by (simp add: fps_mult_nth setsum.distrib[symmetric])
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   814
    also have "\<dots> = setsum ?h {0..n+1}"
57129
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
   815
      by (rule setsum.reindex_bij_witness_not_neutral
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
   816
            [where S'="{}" and T'="{0}" and j="Suc" and i="\<lambda>i. i - 1"]) auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   817
    also have "\<dots> = (fps_deriv (f * g)) $ n"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   818
      apply (simp only: fps_deriv_nth fps_mult_nth setsum.distrib)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   819
      unfolding s0 s1
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   820
      unfolding setsum.distrib[symmetric] setsum_right_distrib
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
   821
      apply (rule setsum.cong)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   822
      apply (auto simp add: of_nat_diff field_simps)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   823
      done
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   824
    finally have "(f * ?D g + ?D f * g) $ n = ?D (f*g) $ n" .
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   825
  }
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   826
  then show ?thesis unfolding fps_eq_iff by auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   827
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   828
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   829
lemma fps_deriv_X[simp]: "fps_deriv X = 1"
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   830
  by (simp add: fps_deriv_def X_def fps_eq_iff)
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
   831
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   832
lemma fps_deriv_neg[simp]:
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   833
  "fps_deriv (- (f:: 'a::comm_ring_1 fps)) = - (fps_deriv f)"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   834
  by (simp add: fps_eq_iff fps_deriv_def)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   835
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   836
lemma fps_deriv_add[simp]:
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   837
  "fps_deriv ((f:: 'a::comm_ring_1 fps) + g) = fps_deriv f + fps_deriv g"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   838
  using fps_deriv_linear[of 1 f 1 g] by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   839
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   840
lemma fps_deriv_sub[simp]:
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   841
  "fps_deriv ((f:: 'a::comm_ring_1 fps) - g) = fps_deriv f - fps_deriv g"
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53374
diff changeset
   842
  using fps_deriv_add [of f "- g"] by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   843
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   844
lemma fps_deriv_const[simp]: "fps_deriv (fps_const c) = 0"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
   845
  by (simp add: fps_ext fps_deriv_def fps_const_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   846
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   847
lemma fps_deriv_mult_const_left[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   848
  "fps_deriv (fps_const (c::'a::comm_ring_1) * f) = fps_const c * fps_deriv f"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   849
  by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   850
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   851
lemma fps_deriv_0[simp]: "fps_deriv 0 = 0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   852
  by (simp add: fps_deriv_def fps_eq_iff)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   853
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   854
lemma fps_deriv_1[simp]: "fps_deriv 1 = 0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   855
  by (simp add: fps_deriv_def fps_eq_iff )
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   856
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   857
lemma fps_deriv_mult_const_right[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   858
  "fps_deriv (f * fps_const (c::'a::comm_ring_1)) = fps_deriv f * fps_const c"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   859
  by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   860
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   861
lemma fps_deriv_setsum:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   862
  "fps_deriv (setsum f S) = setsum (\<lambda>i. fps_deriv (f i :: 'a::comm_ring_1 fps)) S"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   863
proof (cases "finite S")
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   864
  case False
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   865
  then show ?thesis by simp
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   866
next
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   867
  case True
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   868
  show ?thesis by (induct rule: finite_induct [OF True]) simp_all
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   869
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   870
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   871
lemma fps_deriv_eq_0_iff [simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   872
  "fps_deriv f = 0 \<longleftrightarrow> f = fps_const (f$0 :: 'a::{idom,semiring_char_0})"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
   873
proof -
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   874
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   875
    assume "f = fps_const (f$0)"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   876
    then have "fps_deriv f = fps_deriv (fps_const (f$0))" by simp
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   877
    then have "fps_deriv f = 0" by simp
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   878
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   879
  moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   880
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   881
    assume z: "fps_deriv f = 0"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   882
    then have "\<forall>n. (fps_deriv f)$n = 0" by simp
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   883
    then have "\<forall>n. f$(n+1) = 0" by (simp del: of_nat_Suc of_nat_add One_nat_def)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   884
    then have "f = fps_const (f$0)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   885
      apply (clarsimp simp add: fps_eq_iff fps_const_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   886
      apply (erule_tac x="n - 1" in allE)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   887
      apply simp
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   888
      done
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   889
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   890
  ultimately show ?thesis by blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   891
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   892
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   893
lemma fps_deriv_eq_iff:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   894
  fixes f :: "'a::{idom,semiring_char_0} fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   895
  shows "fps_deriv f = fps_deriv g \<longleftrightarrow> (f = fps_const(f$0 - g$0) + g)"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   896
proof -
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   897
  have "fps_deriv f = fps_deriv g \<longleftrightarrow> fps_deriv (f - g) = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   898
    by simp
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   899
  also have "\<dots> \<longleftrightarrow> f - g = fps_const ((f - g) $ 0)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   900
    unfolding fps_deriv_eq_0_iff ..
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
   901
  finally show ?thesis by (simp add: field_simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   902
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   903
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   904
lemma fps_deriv_eq_iff_ex:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   905
  "(fps_deriv f = fps_deriv g) \<longleftrightarrow> (\<exists>c::'a::{idom,semiring_char_0}. f = fps_const c + g)"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
   906
  by (auto simp: fps_deriv_eq_iff)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   907
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   908
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   909
fun fps_nth_deriv :: "nat \<Rightarrow> 'a::semiring_1 fps \<Rightarrow> 'a fps"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   910
where
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   911
  "fps_nth_deriv 0 f = f"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   912
| "fps_nth_deriv (Suc n) f = fps_nth_deriv n (fps_deriv f)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   913
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   914
lemma fps_nth_deriv_commute: "fps_nth_deriv (Suc n) f = fps_deriv (fps_nth_deriv n f)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   915
  by (induct n arbitrary: f) auto
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   916
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   917
lemma fps_nth_deriv_linear[simp]:
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   918
  "fps_nth_deriv n (fps_const (a::'a::comm_semiring_1) * f + fps_const b * g) =
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   919
    fps_const a * fps_nth_deriv n f + fps_const b * fps_nth_deriv n g"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   920
  by (induct n arbitrary: f g) (auto simp add: fps_nth_deriv_commute)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   921
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   922
lemma fps_nth_deriv_neg[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   923
  "fps_nth_deriv n (- (f :: 'a::comm_ring_1 fps)) = - (fps_nth_deriv n f)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   924
  by (induct n arbitrary: f) simp_all
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   925
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   926
lemma fps_nth_deriv_add[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   927
  "fps_nth_deriv n ((f :: 'a::comm_ring_1 fps) + g) = fps_nth_deriv n f + fps_nth_deriv n g"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   928
  using fps_nth_deriv_linear[of n 1 f 1 g] by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   929
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   930
lemma fps_nth_deriv_sub[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   931
  "fps_nth_deriv n ((f :: 'a::comm_ring_1 fps) - g) = fps_nth_deriv n f - fps_nth_deriv n g"
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53374
diff changeset
   932
  using fps_nth_deriv_add [of n f "- g"] by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   933
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   934
lemma fps_nth_deriv_0[simp]: "fps_nth_deriv n 0 = 0"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   935
  by (induct n) simp_all
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   936
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   937
lemma fps_nth_deriv_1[simp]: "fps_nth_deriv n 1 = (if n = 0 then 1 else 0)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   938
  by (induct n) simp_all
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   939
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   940
lemma fps_nth_deriv_const[simp]:
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   941
  "fps_nth_deriv n (fps_const c) = (if n = 0 then fps_const c else 0)"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   942
  by (cases n) simp_all
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   943
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   944
lemma fps_nth_deriv_mult_const_left[simp]:
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   945
  "fps_nth_deriv n (fps_const (c::'a::comm_ring_1) * f) = fps_const c * fps_nth_deriv n f"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   946
  using fps_nth_deriv_linear[of n "c" f 0 0 ] by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   947
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   948
lemma fps_nth_deriv_mult_const_right[simp]:
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   949
  "fps_nth_deriv n (f * fps_const (c::'a::comm_ring_1)) = fps_nth_deriv n f * fps_const c"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
   950
  using fps_nth_deriv_linear[of n "c" f 0 0] by (simp add: mult.commute)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   951
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   952
lemma fps_nth_deriv_setsum:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   953
  "fps_nth_deriv n (setsum f S) = setsum (\<lambda>i. fps_nth_deriv n (f i :: 'a::comm_ring_1 fps)) S"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   954
proof (cases "finite S")
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   955
  case True
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   956
  show ?thesis by (induct rule: finite_induct [OF True]) simp_all
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   957
next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   958
  case False
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
   959
  then show ?thesis by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   960
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   961
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   962
lemma fps_deriv_maclauren_0:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   963
  "(fps_nth_deriv k (f :: 'a::comm_semiring_1 fps)) $ 0 = of_nat (fact k) * f $ k"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
   964
  by (induct k arbitrary: f) (auto simp add: field_simps of_nat_mult)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   965
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   966
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   967
subsection {* Powers *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   968
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   969
lemma fps_power_zeroth_eq_one: "a$0 =1 \<Longrightarrow> a^n $ 0 = (1::'a::semiring_1)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   970
  by (induct n) (auto simp add: expand_fps_eq fps_mult_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   971
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   972
lemma fps_power_first_eq: "(a :: 'a::comm_ring_1 fps) $ 0 =1 \<Longrightarrow> a^n $ 1 = of_nat n * a$1"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   973
proof (induct n)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   974
  case 0
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   975
  then show ?case by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   976
next
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   977
  case (Suc n)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   978
  note h = Suc.hyps[OF `a$0 = 1`]
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
   979
  show ?case unfolding power_Suc fps_mult_nth
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   980
    using h `a$0 = 1` fps_power_zeroth_eq_one[OF `a$0=1`]
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   981
    by (simp add: field_simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   982
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   983
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   984
lemma startsby_one_power:"a $ 0 = (1::'a::comm_ring_1) \<Longrightarrow> a^n $ 0 = 1"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   985
  by (induct n) (auto simp add: fps_mult_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   986
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   987
lemma startsby_zero_power:"a $0 = (0::'a::comm_ring_1) \<Longrightarrow> n > 0 \<Longrightarrow> a^n $0 = 0"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
   988
  by (induct n) (auto simp add: fps_mult_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   989
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   990
lemma startsby_power:"a $0 = (v::'a::comm_ring_1) \<Longrightarrow> a^n $0 = v^n"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   991
  by (induct n) (auto simp add: fps_mult_nth)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   992
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
   993
lemma startsby_zero_power_iff[simp]: "a^n $0 = (0::'a::idom) \<longleftrightarrow> n \<noteq> 0 \<and> a$0 = 0"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   994
  apply (rule iffI)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   995
  apply (induct n)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   996
  apply (auto simp add: fps_mult_nth)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   997
  apply (rule startsby_zero_power, simp_all)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
   998
  done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
   999
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1000
lemma startsby_zero_power_prefix:
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1001
  assumes a0: "a $0 = (0::'a::idom)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1002
  shows "\<forall>n < k. a ^ k $ n = 0"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1003
  using a0
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1004
proof (induct k rule: nat_less_induct)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1005
  fix k
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1006
  assume H: "\<forall>m<k. a $0 =  0 \<longrightarrow> (\<forall>n<m. a ^ m $ n = 0)" and a0: "a $ 0 = 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1007
  let ?ths = "\<forall>m<k. a ^ k $ m = 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1008
  {
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1009
    assume "k = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1010
    then have ?ths by simp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1011
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1012
  moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1013
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1014
    fix l
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1015
    assume k: "k = Suc l"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1016
    {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1017
      fix m
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1018
      assume mk: "m < k"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1019
      {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1020
        assume "m = 0"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1021
        then have "a^k $ m = 0"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1022
          using startsby_zero_power[of a k] k a0 by simp
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1023
      }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1024
      moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1025
      {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1026
        assume m0: "m \<noteq> 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1027
        have "a ^k $ m = (a^l * a) $m"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  1028
          by (simp add: k mult.commute)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1029
        also have "\<dots> = (\<Sum>i = 0..m. a ^ l $ i * a $ (m - i))"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1030
          by (simp add: fps_mult_nth)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1031
        also have "\<dots> = 0"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1032
          apply (rule setsum.neutral)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1033
          apply auto
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 51107
diff changeset
  1034
          apply (case_tac "x = m")
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1035
          using a0 apply simp
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1036
          apply (rule H[rule_format])
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1037
          using a0 k mk apply auto
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1038
          done
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1039
        finally have "a^k $ m = 0" .
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1040
      }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1041
      ultimately have "a^k $ m = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1042
        by blast
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1043
    }
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1044
    then have ?ths by blast
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1045
  }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1046
  ultimately show ?ths
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1047
    by (cases k) auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1048
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1049
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1050
lemma startsby_zero_setsum_depends:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1051
  assumes a0: "a $0 = (0::'a::idom)"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1052
    and kn: "n \<ge> k"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1053
  shows "setsum (\<lambda>i. (a ^ i)$k) {0 .. n} = setsum (\<lambda>i. (a ^ i)$k) {0 .. k}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1054
  apply (rule setsum.mono_neutral_right)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1055
  using kn
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1056
  apply auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1057
  apply (rule startsby_zero_power_prefix[rule_format, OF a0])
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1058
  apply arith
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1059
  done
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1060
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1061
lemma startsby_zero_power_nth_same:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1062
  assumes a0: "a$0 = (0::'a::idom)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1063
  shows "a^n $ n = (a$1) ^ n"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1064
proof (induct n)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1065
  case 0
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1066
  then show ?case by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1067
next
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1068
  case (Suc n)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1069
  have "a ^ Suc n $ (Suc n) = (a^n * a)$(Suc n)"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1070
    by (simp add: field_simps)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1071
  also have "\<dots> = setsum (\<lambda>i. a^n$i * a $ (Suc n - i)) {0.. Suc n}"
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1072
    by (simp add: fps_mult_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1073
  also have "\<dots> = setsum (\<lambda>i. a^n$i * a $ (Suc n - i)) {n .. Suc n}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1074
    apply (rule setsum.mono_neutral_right)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1075
    apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1076
    apply clarsimp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1077
    apply clarsimp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1078
    apply (rule startsby_zero_power_prefix[rule_format, OF a0])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1079
    apply arith
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1080
    done
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1081
  also have "\<dots> = a^n $ n * a$1"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1082
    using a0 by simp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1083
  finally show ?case
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1084
    using Suc.hyps by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1085
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1086
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1087
lemma fps_inverse_power:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1088
  fixes a :: "'a::field fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1089
  shows "inverse (a^n) = inverse a ^ n"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1090
proof -
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1091
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1092
    assume a0: "a$0 = 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1093
    then have eq: "inverse a = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1094
      by (simp add: fps_inverse_def)
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1095
    {
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1096
      assume "n = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1097
      then have ?thesis by simp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1098
    }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1099
    moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1100
    {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1101
      assume n: "n > 0"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1102
      from startsby_zero_power[OF a0 n] eq a0 n have ?thesis
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1103
        by (simp add: fps_inverse_def)
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1104
    }
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1105
    ultimately have ?thesis by blast
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1106
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1107
  moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1108
  {
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1109
    assume a0: "a$0 \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1110
    have ?thesis
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1111
      apply (rule fps_inverse_unique)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1112
      apply (simp add: a0)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1113
      unfolding power_mult_distrib[symmetric]
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1114
      apply (rule ssubst[where t = "a * inverse a" and s= 1])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1115
      apply simp_all
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  1116
      apply (subst mult.commute)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1117
      apply (rule inverse_mult_eq_1[OF a0])
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1118
      done
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1119
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1120
  ultimately show ?thesis by blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1121
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1122
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1123
lemma fps_deriv_power:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1124
  "fps_deriv (a ^ n) = fps_const (of_nat n :: 'a::comm_ring_1) * fps_deriv a * a ^ (n - 1)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1125
  apply (induct n)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1126
  apply (auto simp add: field_simps fps_const_add[symmetric] simp del: fps_const_add)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1127
  apply (case_tac n)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1128
  apply (auto simp add: field_simps)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1129
  done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1130
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1131
lemma fps_inverse_deriv:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1132
  fixes a :: "'a::field fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1133
  assumes a0: "a$0 \<noteq> 0"
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  1134
  shows "fps_deriv (inverse a) = - fps_deriv a * (inverse a)\<^sup>2"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1135
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1136
  from inverse_mult_eq_1[OF a0]
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1137
  have "fps_deriv (inverse a * a) = 0" by simp
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1138
  then have "inverse a * fps_deriv a + fps_deriv (inverse a) * a = 0"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1139
    by simp
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1140
  then have "inverse a * (inverse a * fps_deriv a + fps_deriv (inverse a) * a) = 0"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1141
    by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1142
  with inverse_mult_eq_1[OF a0]
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  1143
  have "(inverse a)\<^sup>2 * fps_deriv a + fps_deriv (inverse a) = 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1144
    unfolding power2_eq_square
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  1145
    apply (simp add: field_simps)
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  1146
    apply (simp add: mult.assoc[symmetric])
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1147
    done
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  1148
  then have "(inverse a)\<^sup>2 * fps_deriv a + fps_deriv (inverse a) - fps_deriv a * (inverse a)\<^sup>2 =
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  1149
      0 - fps_deriv a * (inverse a)\<^sup>2"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1150
    by simp
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  1151
  then show "fps_deriv (inverse a) = - fps_deriv a * (inverse a)\<^sup>2"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1152
    by (simp add: field_simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1153
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1154
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1155
lemma fps_inverse_mult:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1156
  fixes a :: "'a::field fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1157
  shows "inverse (a * b) = inverse a * inverse b"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1158
proof -
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1159
  {
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1160
    assume a0: "a$0 = 0"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1161
    then have ab0: "(a*b)$0 = 0" by (simp add: fps_mult_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1162
    from a0 ab0 have th: "inverse a = 0" "inverse (a*b) = 0" by simp_all
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1163
    have ?thesis unfolding th by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1164
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1165
  moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1166
  {
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1167
    assume b0: "b$0 = 0"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1168
    then have ab0: "(a*b)$0 = 0" by (simp add: fps_mult_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1169
    from b0 ab0 have th: "inverse b = 0" "inverse (a*b) = 0" by simp_all
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1170
    have ?thesis unfolding th by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1171
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1172
  moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1173
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1174
    assume a0: "a$0 \<noteq> 0" and b0: "b$0 \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1175
    from a0 b0 have ab0:"(a*b) $ 0 \<noteq> 0" by (simp  add: fps_mult_nth)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1176
    from inverse_mult_eq_1[OF ab0]
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1177
    have "inverse (a*b) * (a*b) * inverse a * inverse b = 1 * inverse a * inverse b" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1178
    then have "inverse (a*b) * (inverse a * a) * (inverse b * b) = inverse a * inverse b"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  1179
      by (simp add: field_simps)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1180
    then have ?thesis using inverse_mult_eq_1[OF a0] inverse_mult_eq_1[OF b0] by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1181
  }
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1182
  ultimately show ?thesis by blast
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1183
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1184
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1185
lemma fps_inverse_deriv':
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1186
  fixes a :: "'a::field fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1187
  assumes a0: "a$0 \<noteq> 0"
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  1188
  shows "fps_deriv (inverse a) = - fps_deriv a / a\<^sup>2"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1189
  using fps_inverse_deriv[OF a0]
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1190
  unfolding power2_eq_square fps_divide_def fps_inverse_mult
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1191
  by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1192
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1193
lemma inverse_mult_eq_1':
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1194
  assumes f0: "f$0 \<noteq> (0::'a::field)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1195
  shows "f * inverse f= 1"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  1196
  by (metis mult.commute inverse_mult_eq_1 f0)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1197
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1198
lemma fps_divide_deriv:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1199
  fixes a :: "'a::field fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1200
  assumes a0: "b$0 \<noteq> 0"
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  1201
  shows "fps_deriv (a / b) = (fps_deriv a * b - a * fps_deriv b) / b\<^sup>2"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1202
  using fps_inverse_deriv[OF a0]
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1203
  by (simp add: fps_divide_def field_simps
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1204
    power2_eq_square fps_inverse_mult inverse_mult_eq_1'[OF a0])
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1205
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1206
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1207
lemma fps_inverse_gp': "inverse (Abs_fps (\<lambda>n. 1::'a::field)) = 1 - X"
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
  1208
  by (simp add: fps_inverse_gp fps_eq_iff X_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1209
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1210
lemma fps_nth_deriv_X[simp]: "fps_nth_deriv n X = (if n = 0 then X else if n=1 then 1 else 0)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1211
  by (cases n) simp_all
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1212
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1213
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1214
lemma fps_inverse_X_plus1:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1215
  "inverse (1 + X) = Abs_fps (\<lambda>n. (- (1::'a::field)) ^ n)" (is "_ = ?r")
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1216
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1217
  have eq: "(1 + X) * ?r = 1"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1218
    unfolding minus_one_power_iff
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  1219
    by (auto simp add: field_simps fps_eq_iff)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1220
  show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1221
    by (auto simp add: eq intro: fps_inverse_unique)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1222
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1223
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1224
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  1225
subsection{* Integration *}
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1226
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1227
definition fps_integral :: "'a::field_char_0 fps \<Rightarrow> 'a \<Rightarrow> 'a fps"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1228
  where "fps_integral a a0 = Abs_fps (\<lambda>n. if n = 0 then a0 else (a$(n - 1) / of_nat n))"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1229
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1230
lemma fps_deriv_fps_integral: "fps_deriv (fps_integral a a0) = a"
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1231
  unfolding fps_integral_def fps_deriv_def
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1232
  by (simp add: fps_eq_iff del: of_nat_Suc)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1233
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1234
lemma fps_integral_linear:
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1235
  "fps_integral (fps_const a * f + fps_const b * g) (a*a0 + b*b0) =
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1236
    fps_const a * fps_integral f a0 + fps_const b * fps_integral g b0"
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1237
  (is "?l = ?r")
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1238
proof -
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1239
  have "fps_deriv ?l = fps_deriv ?r"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1240
    by (simp add: fps_deriv_fps_integral)
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1241
  moreover have "?l$0 = ?r$0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1242
    by (simp add: fps_integral_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1243
  ultimately show ?thesis
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1244
    unfolding fps_deriv_eq_iff by auto
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1245
qed
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1246
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1247
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  1248
subsection {* Composition of FPSs *}
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1249
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1250
definition fps_compose :: "'a::semiring_1 fps \<Rightarrow> 'a fps \<Rightarrow> 'a fps" (infixl "oo" 55)
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1251
  where "a oo b = Abs_fps (\<lambda>n. setsum (\<lambda>i. a$i * (b^i$n)) {0..n})"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1252
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1253
lemma fps_compose_nth: "(a oo b)$n = setsum (\<lambda>i. a$i * (b^i$n)) {0..n}"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1254
  by (simp add: fps_compose_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1255
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1256
lemma fps_compose_X[simp]: "a oo X = (a :: 'a::comm_ring_1 fps)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1257
  by (simp add: fps_ext fps_compose_def mult_delta_right setsum.delta')
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1258
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1259
lemma fps_const_compose[simp]:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1260
  "fps_const (a::'a::comm_ring_1) oo b = fps_const a"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1261
  by (simp add: fps_eq_iff fps_compose_nth mult_delta_left setsum.delta)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1262
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1263
lemma numeral_compose[simp]: "(numeral k :: 'a::comm_ring_1 fps) oo b = numeral k"
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
  1264
  unfolding numeral_fps_const by simp
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
  1265
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1266
lemma neg_numeral_compose[simp]: "(- numeral k :: 'a::comm_ring_1 fps) oo b = - numeral k"
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
  1267
  unfolding neg_numeral_fps_const by simp
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  1268
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1269
lemma X_fps_compose_startby0[simp]: "a$0 = 0 \<Longrightarrow> X oo a = (a :: 'a::comm_ring_1 fps)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1270
  by (simp add: fps_eq_iff fps_compose_def mult_delta_left setsum.delta not_le)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1271
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1272
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  1273
subsection {* Rules from Herbert Wilf's Generatingfunctionology*}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1274
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  1275
subsubsection {* Rule 1 *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1276
  (* {a_{n+k}}_0^infty Corresponds to (f - setsum (\<lambda>i. a_i * x^i))/x^h, for h>0*)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1277
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1278
lemma fps_power_mult_eq_shift:
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1279
  "X^Suc k * Abs_fps (\<lambda>n. a (n + Suc k)) =
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1280
    Abs_fps a - setsum (\<lambda>i. fps_const (a i :: 'a::comm_ring_1) * X^i) {0 .. k}"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1281
  (is "?lhs = ?rhs")
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1282
proof -
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1283
  { fix n :: nat
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1284
    have "?lhs $ n = (if n < Suc k then 0 else a n)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1285
      unfolding X_power_mult_nth by auto
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1286
    also have "\<dots> = ?rhs $ n"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1287
    proof (induct k)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1288
      case 0
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1289
      then show ?case by (simp add: fps_setsum_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1290
    next
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1291
      case (Suc k)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1292
      note th = Suc.hyps[symmetric]
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1293
      have "(Abs_fps a - setsum (\<lambda>i. fps_const (a i :: 'a) * X^i) {0 .. Suc k})$n =
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1294
        (Abs_fps a - setsum (\<lambda>i. fps_const (a i :: 'a) * X^i) {0 .. k} -
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1295
          fps_const (a (Suc k)) * X^ Suc k) $ n"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1296
        by (simp add: field_simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1297
      also have "\<dots> = (if n < Suc k then 0 else a n) - (fps_const (a (Suc k)) * X^ Suc k)$n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1298
        using th unfolding fps_sub_nth by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1299
      also have "\<dots> = (if n < Suc (Suc k) then 0 else a n)"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1300
        unfolding X_power_mult_right_nth
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1301
        apply (auto simp add: not_less fps_const_def)
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1302
        apply (rule cong[of a a, OF refl])
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1303
        apply arith
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1304
        done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1305
      finally show ?case by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1306
    qed
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1307
    finally have "?lhs $ n = ?rhs $ n" .
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1308
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1309
  then show ?thesis by (simp add: fps_eq_iff)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1310
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1311
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1312
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1313
subsubsection {* Rule 2*}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1314
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1315
  (* We can not reach the form of Wilf, but still near to it using rewrite rules*)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1316
  (* If f reprents {a_n} and P is a polynomial, then
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1317
        P(xD) f represents {P(n) a_n}*)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1318
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1319
definition "XD = op * X \<circ> fps_deriv"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1320
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1321
lemma XD_add[simp]:"XD (a + b) = XD a + XD (b :: 'a::comm_ring_1 fps)"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  1322
  by (simp add: XD_def field_simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1323
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1324
lemma XD_mult_const[simp]:"XD (fps_const (c::'a::comm_ring_1) * a) = fps_const c * XD a"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  1325
  by (simp add: XD_def field_simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1326
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1327
lemma XD_linear[simp]: "XD (fps_const c * a + fps_const d * b) =
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1328
    fps_const c * XD a + fps_const d * XD (b :: 'a::comm_ring_1 fps)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1329
  by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1330
30952
7ab2716dd93b power operation on functions with syntax o^; power operation on relations with syntax ^^
haftmann
parents: 30837
diff changeset
  1331
lemma XDN_linear:
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1332
  "(XD ^^ n) (fps_const c * a + fps_const d * b) =
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1333
    fps_const c * (XD ^^ n) a + fps_const d * (XD ^^ n) (b :: 'a::comm_ring_1 fps)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1334
  by (induct n) simp_all
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1335
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1336
lemma fps_mult_X_deriv_shift: "X* fps_deriv a = Abs_fps (\<lambda>n. of_nat n* a$n)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1337
  by (simp add: fps_eq_iff)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1338
30994
chaieb
parents: 30971 30992
diff changeset
  1339
30952
7ab2716dd93b power operation on functions with syntax o^; power operation on relations with syntax ^^
haftmann
parents: 30837
diff changeset
  1340
lemma fps_mult_XD_shift:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1341
  "(XD ^^ k) (a :: 'a::comm_ring_1 fps) = Abs_fps (\<lambda>n. (of_nat n ^ k) * a$n)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1342
  by (induct k arbitrary: a) (simp_all add: XD_def fps_eq_iff field_simps del: One_nat_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1343
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1344
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1345
subsubsection {* Rule 3 is trivial and is given by @{text fps_times_def} *}
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1346
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1347
subsubsection {* Rule 5 --- summation and "division" by (1 - X) *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1348
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1349
lemma fps_divide_X_minus1_setsum_lemma:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1350
  "a = ((1::'a::comm_ring_1 fps) - X) * Abs_fps (\<lambda>n. setsum (\<lambda>i. a $ i) {0..n})"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1351
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1352
  let ?sa = "Abs_fps (\<lambda>n. setsum (\<lambda>i. a $ i) {0..n})"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1353
  have th0: "\<And>i. (1 - (X::'a fps)) $ i = (if i = 0 then 1 else if i = 1 then - 1 else 0)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1354
    by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1355
  {
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1356
    fix n :: nat
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1357
    {
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1358
      assume "n = 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1359
      then have "a $ n = ((1 - X) * ?sa) $ n"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1360
        by (simp add: fps_mult_nth)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1361
    }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1362
    moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1363
    {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1364
      assume n0: "n \<noteq> 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1365
      then have u: "{0} \<union> ({1} \<union> {2..n}) = {0..n}" "{1} \<union> {2..n} = {1..n}"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1366
        "{0..n - 1} \<union> {n} = {0..n}"
39302
d7728f65b353 renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents: 39198
diff changeset
  1367
        by (auto simp: set_eq_iff)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1368
      have d: "{0} \<inter> ({1} \<union> {2..n}) = {}" "{1} \<inter> {2..n} = {}" "{0..n - 1} \<inter> {n} = {}"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1369
        using n0 by simp_all
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1370
      have f: "finite {0}" "finite {1}" "finite {2 .. n}"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1371
        "finite {0 .. n - 1}" "finite {n}" by simp_all
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1372
      have "((1 - X) * ?sa) $ n = setsum (\<lambda>i. (1 - X)$ i * ?sa $ (n - i)) {0 .. n}"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1373
        by (simp add: fps_mult_nth)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1374
      also have "\<dots> = a$n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1375
        unfolding th0
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1376
        unfolding setsum.union_disjoint[OF f(1) finite_UnI[OF f(2,3)] d(1), unfolded u(1)]
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1377
        unfolding setsum.union_disjoint[OF f(2) f(3) d(2)]
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1378
        apply (simp)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1379
        unfolding setsum.union_disjoint[OF f(4,5) d(3), unfolded u(3)]
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1380
        apply simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1381
        done
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1382
      finally have "a$n = ((1 - X) * ?sa) $ n"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1383
        by simp
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1384
    }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1385
    ultimately have "a$n = ((1 - X) * ?sa) $ n"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1386
      by blast
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1387
  }
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1388
  then show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1389
    unfolding fps_eq_iff by blast
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1390
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1391
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1392
lemma fps_divide_X_minus1_setsum:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1393
  "a /((1::'a::field fps) - X) = Abs_fps (\<lambda>n. setsum (\<lambda>i. a $ i) {0..n})"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1394
proof -
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1395
  let ?X = "1 - (X::'a fps)"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1396
  have th0: "?X $ 0 \<noteq> 0"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1397
    by simp
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1398
  have "a /?X = ?X *  Abs_fps (\<lambda>n::nat. setsum (op $ a) {0..n}) * inverse ?X"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1399
    using fps_divide_X_minus1_setsum_lemma[of a, symmetric] th0
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  1400
    by (simp add: fps_divide_def mult.assoc)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1401
  also have "\<dots> = (inverse ?X * ?X) * Abs_fps (\<lambda>n::nat. setsum (op $ a) {0..n}) "
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
  1402
    by (simp add: ac_simps)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1403
  finally show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1404
    by (simp add: inverse_mult_eq_1[OF th0])
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1405
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1406
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1407
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1408
subsubsection{* Rule 4 in its more general form: generalizes Rule 3 for an arbitrary
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1409
  finite product of FPS, also the relvant instance of powers of a FPS*}
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1410
46131
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1411
definition "natpermute n k = {l :: nat list. length l = k \<and> listsum l = n}"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1412
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1413
lemma natlist_trivial_1: "natpermute n 1 = {[n]}"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1414
  apply (auto simp add: natpermute_def)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1415
  apply (case_tac x)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1416
  apply auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1417
  done
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1418
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1419
lemma append_natpermute_less_eq:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1420
  assumes "xs @ ys \<in> natpermute n k"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1421
  shows "listsum xs \<le> n"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1422
    and "listsum ys \<le> n"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1423
proof -
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1424
  from assms have "listsum (xs @ ys) = n"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1425
    by (simp add: natpermute_def)
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1426
  then have "listsum xs + listsum ys = n"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1427
    by simp
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1428
  then show "listsum xs \<le> n" and "listsum ys \<le> n"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1429
    by simp_all
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1430
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1431
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1432
lemma natpermute_split:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1433
  assumes "h \<le> k"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1434
  shows "natpermute n k =
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1435
    (\<Union>m \<in>{0..n}. {l1 @ l2 |l1 l2. l1 \<in> natpermute m h \<and> l2 \<in> natpermute (n - m) (k - h)})"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1436
  (is "?L = ?R" is "?L = (\<Union>m \<in>{0..n}. ?S m)")
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1437
proof -
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1438
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1439
    fix l
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1440
    assume l: "l \<in> ?R"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1441
    from l obtain m xs ys where h: "m \<in> {0..n}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1442
      and xs: "xs \<in> natpermute m h"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1443
      and ys: "ys \<in> natpermute (n - m) (k - h)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1444
      and leq: "l = xs@ys" by blast
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1445
    from xs have xs': "listsum xs = m"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1446
      by (simp add: natpermute_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1447
    from ys have ys': "listsum ys = n - m"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1448
      by (simp add: natpermute_def)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1449
    have "l \<in> ?L" using leq xs ys h
46131
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1450
      apply (clarsimp simp add: natpermute_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1451
      unfolding xs' ys'
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1452
      using assms xs ys
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1453
      unfolding natpermute_def
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1454
      apply simp
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1455
      done
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1456
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1457
  moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1458
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1459
    fix l
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1460
    assume l: "l \<in> natpermute n k"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1461
    let ?xs = "take h l"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1462
    let ?ys = "drop h l"
46131
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1463
    let ?m = "listsum ?xs"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1464
    from l have ls: "listsum (?xs @ ?ys) = n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1465
      by (simp add: natpermute_def)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1466
    have xs: "?xs \<in> natpermute ?m h" using l assms
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1467
      by (simp add: natpermute_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1468
    have l_take_drop: "listsum l = listsum (take h l @ drop h l)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1469
      by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1470
    then have ys: "?ys \<in> natpermute (n - ?m) (k - h)"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1471
      using l assms ls by (auto simp add: natpermute_def simp del: append_take_drop_id)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1472
    from ls have m: "?m \<in> {0..n}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1473
      by (simp add: l_take_drop del: append_take_drop_id)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1474
    from xs ys ls have "l \<in> ?R"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1475
      apply auto
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1476
      apply (rule bexI [where x = "?m"])
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1477
      apply (rule exI [where x = "?xs"])
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1478
      apply (rule exI [where x = "?ys"])
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  1479
      using ls l
46131
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1480
      apply (auto simp add: natpermute_def l_take_drop simp del: append_take_drop_id)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1481
      apply simp
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1482
      done
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1483
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1484
  ultimately show ?thesis by blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1485
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1486
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1487
lemma natpermute_0: "natpermute n 0 = (if n = 0 then {[]} else {})"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1488
  by (auto simp add: natpermute_def)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1489
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1490
lemma natpermute_0'[simp]: "natpermute 0 k = (if k = 0 then {[]} else {replicate k 0})"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1491
  apply (auto simp add: set_replicate_conv_if natpermute_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1492
  apply (rule nth_equalityI)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1493
  apply simp_all
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1494
  done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1495
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1496
lemma natpermute_finite: "finite (natpermute n k)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1497
proof (induct k arbitrary: n)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1498
  case 0
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1499
  then show ?case
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1500
    apply (subst natpermute_split[of 0 0, simplified])
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1501
    apply (simp add: natpermute_0)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1502
    done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1503
next
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1504
  case (Suc k)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1505
  then show ?case unfolding natpermute_split [of k "Suc k", simplified]
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1506
    apply -
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1507
    apply (rule finite_UN_I)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1508
    apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1509
    unfolding One_nat_def[symmetric] natlist_trivial_1
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1510
    apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1511
    done
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1512
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1513
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1514
lemma natpermute_contain_maximal:
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1515
  "{xs \<in> natpermute n (k+1). n \<in> set xs} = UNION {0 .. k} (\<lambda>i. {(replicate (k+1) 0) [i:=n]})"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1516
  (is "?A = ?B")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1517
proof -
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1518
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1519
    fix xs
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1520
    assume H: "xs \<in> natpermute n (k+1)" and n: "n \<in> set xs"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1521
    from n obtain i where i: "i \<in> {0.. k}" "xs!i = n" using H
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1522
      unfolding in_set_conv_nth by (auto simp add: less_Suc_eq_le natpermute_def)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1523
    have eqs: "({0..k} - {i}) \<union> {i} = {0..k}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1524
      using i by auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1525
    have f: "finite({0..k} - {i})" "finite {i}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1526
      by auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1527
    have d: "({0..k} - {i}) \<inter> {i} = {}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1528
      using i by auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1529
    from H have "n = setsum (nth xs) {0..k}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1530
      apply (simp add: natpermute_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1531
      apply (auto simp add: atLeastLessThanSuc_atLeastAtMost listsum_setsum_nth)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1532
      done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1533
    also have "\<dots> = n + setsum (nth xs) ({0..k} - {i})"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1534
      unfolding setsum.union_disjoint[OF f d, unfolded eqs] using i by simp
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1535
    finally have zxs: "\<forall> j\<in> {0..k} - {i}. xs!j = 0"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1536
      by auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1537
    from H have xsl: "length xs = k+1"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1538
      by (simp add: natpermute_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1539
    from i have i': "i < length (replicate (k+1) 0)"   "i < k+1"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1540
      unfolding length_replicate by presburger+
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1541
    have "xs = replicate (k+1) 0 [i := n]"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1542
      apply (rule nth_equalityI)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1543
      unfolding xsl length_list_update length_replicate
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1544
      apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1545
      apply clarify
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1546
      unfolding nth_list_update[OF i'(1)]
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1547
      using i zxs
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1548
      apply (case_tac "ia = i")
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1549
      apply (auto simp del: replicate.simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1550
      done
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1551
    then have "xs \<in> ?B" using i by blast
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1552
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1553
  moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1554
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1555
    fix i
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1556
    assume i: "i \<in> {0..k}"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1557
    let ?xs = "replicate (k+1) 0 [i:=n]"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1558
    have nxs: "n \<in> set ?xs"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1559
      apply (rule set_update_memI)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1560
      using i apply simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1561
      done
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1562
    have xsl: "length ?xs = k+1"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1563
      by (simp only: length_replicate length_list_update)
46131
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1564
    have "listsum ?xs = setsum (nth ?xs) {0..<k+1}"
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1565
      unfolding listsum_setsum_nth xsl ..
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1566
    also have "\<dots> = setsum (\<lambda>j. if j = i then n else 0) {0..< k+1}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1567
      by (rule setsum.cong) (simp_all del: replicate.simps)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1568
    also have "\<dots> = n" using i by (simp add: setsum.delta)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1569
    finally have "?xs \<in> natpermute n (k+1)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1570
      using xsl unfolding natpermute_def mem_Collect_eq by blast
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1571
    then have "?xs \<in> ?A"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1572
      using nxs  by blast
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1573
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1574
  ultimately show ?thesis by auto
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1575
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1576
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1577
text {* The general form *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1578
lemma fps_setprod_nth:
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1579
  fixes m :: nat
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1580
    and a :: "nat \<Rightarrow> 'a::comm_ring_1 fps"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1581
  shows "(setprod a {0 .. m}) $ n =
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1582
    setsum (\<lambda>v. setprod (\<lambda>j. (a j) $ (v!j)) {0..m}) (natpermute n (m+1))"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1583
  (is "?P m n")
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1584
proof (induct m arbitrary: n rule: nat_less_induct)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1585
  fix m n assume H: "\<forall>m' < m. \<forall>n. ?P m' n"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1586
  show "?P m n"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1587
  proof (cases m)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1588
    case 0
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1589
    then show ?thesis
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1590
      apply simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1591
      unfolding natlist_trivial_1[where n = n, unfolded One_nat_def]
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1592
      apply simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1593
      done
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1594
  next
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1595
    case (Suc k)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1596
    then have km: "k < m" by arith
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1597
    have u0: "{0 .. k} \<union> {m} = {0..m}"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1598
      using Suc by (simp add: set_eq_iff) presburger
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1599
    have f0: "finite {0 .. k}" "finite {m}" by auto
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1600
    have d0: "{0 .. k} \<inter> {m} = {}" using Suc by auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1601
    have "(setprod a {0 .. m}) $ n = (setprod a {0 .. k} * a m) $ n"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1602
      unfolding setprod.union_disjoint[OF f0 d0, unfolded u0] by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1603
    also have "\<dots> = (\<Sum>i = 0..n. (\<Sum>v\<in>natpermute i (k + 1). \<Prod>j\<in>{0..k}. a j $ v ! j) * a m $ (n - i))"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1604
      unfolding fps_mult_nth H[rule_format, OF km] ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1605
    also have "\<dots> = (\<Sum>v\<in>natpermute n (m + 1). \<Prod>j\<in>{0..m}. a j $ v ! j)"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1606
      apply (simp add: Suc)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1607
      unfolding natpermute_split[of m "m + 1", simplified, of n,
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1608
        unfolded natlist_trivial_1[unfolded One_nat_def] Suc]
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1609
      apply (subst setsum.UNION_disjoint)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1610
      apply simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1611
      apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1612
      unfolding image_Collect[symmetric]
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1613
      apply clarsimp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1614
      apply (rule finite_imageI)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1615
      apply (rule natpermute_finite)
39302
d7728f65b353 renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents: 39198
diff changeset
  1616
      apply (clarsimp simp add: set_eq_iff)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1617
      apply auto
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1618
      apply (rule setsum.cong)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1619
      apply (rule refl)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1620
      unfolding setsum_left_distrib
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1621
      apply (rule sym)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1622
      apply (rule_tac l = "\<lambda>xs. xs @ [n - x]" in setsum.reindex_cong)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1623
      apply (simp add: inj_on_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1624
      apply auto
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1625
      unfolding setprod.union_disjoint[OF f0 d0, unfolded u0, unfolded Suc]
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1626
      apply (clarsimp simp add: natpermute_def nth_append)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1627
      done
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1628
    finally show ?thesis .
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1629
  qed
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1630
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1631
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1632
text{* The special form for powers *}
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1633
lemma fps_power_nth_Suc:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1634
  fixes m :: nat
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1635
    and a :: "'a::comm_ring_1 fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1636
  shows "(a ^ Suc m)$n = setsum (\<lambda>v. setprod (\<lambda>j. a $ (v!j)) {0..m}) (natpermute n (m+1))"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1637
proof -
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1638
  have th0: "a^Suc m = setprod (\<lambda>i. a) {0..m}"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1639
    by (simp add: setprod_constant)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1640
  show ?thesis unfolding th0 fps_setprod_nth ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1641
qed
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1642
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1643
lemma fps_power_nth:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1644
  fixes m :: nat
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1645
    and a :: "'a::comm_ring_1 fps"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1646
  shows "(a ^m)$n =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1647
    (if m=0 then 1$n else setsum (\<lambda>v. setprod (\<lambda>j. a $ (v!j)) {0..m - 1}) (natpermute n m))"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1648
  by (cases m) (simp_all add: fps_power_nth_Suc del: power_Suc)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1649
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1650
lemma fps_nth_power_0:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1651
  fixes m :: nat
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1652
    and a :: "'a::comm_ring_1 fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1653
  shows "(a ^m)$0 = (a$0) ^ m"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1654
proof (cases m)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1655
  case 0
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1656
  then show ?thesis by simp
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1657
next
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1658
  case (Suc n)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1659
  then have c: "m = card {0..n}" by simp
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1660
  have "(a ^m)$0 = setprod (\<lambda>i. a$0) {0..n}"
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1661
    by (simp add: Suc fps_power_nth del: replicate.simps power_Suc)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1662
  also have "\<dots> = (a$0) ^ m"
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1663
   unfolding c by (rule setprod_constant) simp
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  1664
 finally show ?thesis .
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1665
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1666
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1667
lemma fps_compose_inj_right:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1668
  assumes a0: "a$0 = (0::'a::idom)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1669
    and a1: "a$1 \<noteq> 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1670
  shows "(b oo a = c oo a) \<longleftrightarrow> b = c"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1671
  (is "?lhs \<longleftrightarrow>?rhs")
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1672
proof
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1673
  assume ?rhs
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1674
  then show "?lhs" by simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1675
next
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1676
  assume h: ?lhs
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1677
  {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1678
    fix n
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1679
    have "b$n = c$n"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1680
    proof (induct n rule: nat_less_induct)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1681
      fix n
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1682
      assume H: "\<forall>m<n. b$m = c$m"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1683
      {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1684
        assume n0: "n=0"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1685
        from h have "(b oo a)$n = (c oo a)$n" by simp
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1686
        then have "b$n = c$n" using n0 by (simp add: fps_compose_nth)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1687
      }
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1688
      moreover
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1689
      {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1690
        fix n1 assume n1: "n = Suc n1"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1691
        have f: "finite {0 .. n1}" "finite {n}" by simp_all
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1692
        have eq: "{0 .. n1} \<union> {n} = {0 .. n}" using n1 by auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1693
        have d: "{0 .. n1} \<inter> {n} = {}" using n1 by auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1694
        have seq: "(\<Sum>i = 0..n1. b $ i * a ^ i $ n) = (\<Sum>i = 0..n1. c $ i * a ^ i $ n)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1695
          apply (rule setsum.cong)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1696
          using H n1
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1697
          apply auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1698
          done
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1699
        have th0: "(b oo a) $n = (\<Sum>i = 0..n1. c $ i * a ^ i $ n) + b$n * (a$1)^n"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1700
          unfolding fps_compose_nth setsum.union_disjoint[OF f d, unfolded eq] seq
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1701
          using startsby_zero_power_nth_same[OF a0]
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1702
          by simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1703
        have th1: "(c oo a) $n = (\<Sum>i = 0..n1. c $ i * a ^ i $ n) + c$n * (a$1)^n"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1704
          unfolding fps_compose_nth setsum.union_disjoint[OF f d, unfolded eq]
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1705
          using startsby_zero_power_nth_same[OF a0]
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1706
          by simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1707
        from h[unfolded fps_eq_iff, rule_format, of n] th0 th1 a1
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1708
        have "b$n = c$n" by auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1709
      }
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1710
      ultimately show "b$n = c$n" by (cases n) auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1711
    qed}
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1712
  then show ?rhs by (simp add: fps_eq_iff)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1713
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1714
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1715
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  1716
subsection {* Radicals *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1717
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1718
declare setprod.cong [fundef_cong]
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1719
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1720
function radical :: "(nat \<Rightarrow> 'a \<Rightarrow> 'a) \<Rightarrow> nat \<Rightarrow> 'a::field fps \<Rightarrow> nat \<Rightarrow> 'a"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1721
where
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1722
  "radical r 0 a 0 = 1"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1723
| "radical r 0 a (Suc n) = 0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1724
| "radical r (Suc k) a 0 = r (Suc k) (a$0)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1725
| "radical r (Suc k) a (Suc n) =
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1726
    (a$ Suc n - setsum (\<lambda>xs. setprod (\<lambda>j. radical r (Suc k) a (xs ! j)) {0..k})
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1727
      {xs. xs \<in> natpermute (Suc n) (Suc k) \<and> Suc n \<notin> set xs}) /
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1728
    (of_nat (Suc k) * (radical r (Suc k) a 0)^k)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1729
  by pat_completeness auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1730
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1731
termination radical
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1732
proof
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1733
  let ?R = "measure (\<lambda>(r, k, a, n). n)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1734
  {
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1735
    show "wf ?R" by auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1736
  next
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1737
    fix r k a n xs i
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1738
    assume xs: "xs \<in> {xs \<in> natpermute (Suc n) (Suc k). Suc n \<notin> set xs}" and i: "i \<in> {0..k}"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1739
    {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1740
      assume c: "Suc n \<le> xs ! i"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1741
      from xs i have "xs !i \<noteq> Suc n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1742
        by (auto simp add: in_set_conv_nth natpermute_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1743
      with c have c': "Suc n < xs!i" by arith
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1744
      have fths: "finite {0 ..< i}" "finite {i}" "finite {i+1..<Suc k}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1745
        by simp_all
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1746
      have d: "{0 ..< i} \<inter> ({i} \<union> {i+1 ..< Suc k}) = {}" "{i} \<inter> {i+1..< Suc k} = {}"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1747
        by auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1748
      have eqs: "{0..<Suc k} = {0 ..< i} \<union> ({i} \<union> {i+1 ..< Suc k})"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1749
        using i by auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1750
      from xs have "Suc n = listsum xs"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1751
        by (simp add: natpermute_def)
46131
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1752
      also have "\<dots> = setsum (nth xs) {0..<Suc k}" using xs
ab07a3ef821c prefer listsum over foldl plus 0
haftmann
parents: 44174
diff changeset
  1753
        by (simp add: natpermute_def listsum_setsum_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1754
      also have "\<dots> = xs!i + setsum (nth xs) {0..<i} + setsum (nth xs) {i+1..<Suc k}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1755
        unfolding eqs  setsum.union_disjoint[OF fths(1) finite_UnI[OF fths(2,3)] d(1)]
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1756
        unfolding setsum.union_disjoint[OF fths(2) fths(3) d(2)]
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1757
        by simp
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1758
      finally have False using c' by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1759
    }
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1760
    then show "((r, Suc k, a, xs!i), r, Suc k, a, Suc n) \<in> ?R"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1761
      apply auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1762
      apply (metis not_less)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1763
      done
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1764
  next
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1765
    fix r k a n
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1766
    show "((r, Suc k, a, 0), r, Suc k, a, Suc n) \<in> ?R" by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1767
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1768
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1769
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1770
definition "fps_radical r n a = Abs_fps (radical r n a)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1771
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1772
lemma fps_radical0[simp]: "fps_radical r 0 a = 1"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1773
  apply (auto simp add: fps_eq_iff fps_radical_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1774
  apply (case_tac n)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1775
  apply auto
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1776
  done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1777
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1778
lemma fps_radical_nth_0[simp]: "fps_radical r n a $ 0 = (if n=0 then 1 else r n (a$0))"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1779
  by (cases n) (simp_all add: fps_radical_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1780
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1781
lemma fps_radical_power_nth[simp]:
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1782
  assumes r: "(r k (a$0)) ^ k = a$0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1783
  shows "fps_radical r k a ^ k $ 0 = (if k = 0 then 1 else a$0)"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1784
proof (cases k)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1785
  case 0
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1786
  then show ?thesis by simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1787
next
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1788
  case (Suc h)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1789
  have eq1: "fps_radical r k a ^ k $ 0 = (\<Prod>j\<in>{0..h}. fps_radical r k a $ (replicate k 0) ! j)"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1790
    unfolding fps_power_nth Suc by simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1791
  also have "\<dots> = (\<Prod>j\<in>{0..h}. r k (a$0))"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1792
    apply (rule setprod.cong)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1793
    apply simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1794
    using Suc
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  1795
    apply (subgoal_tac "replicate k 0 ! x = 0")
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1796
    apply (auto intro: nth_replicate simp del: replicate.simps)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1797
    done
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1798
  also have "\<dots> = a$0" using r Suc by (simp add: setprod_constant)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1799
  finally show ?thesis using Suc by simp
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1800
qed
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1801
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1802
lemma natpermute_max_card:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1803
  assumes n0: "n \<noteq> 0"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1804
  shows "card {xs \<in> natpermute n (k+1). n \<in> set xs} = k + 1"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1805
  unfolding natpermute_contain_maximal
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1806
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1807
  let ?A= "\<lambda>i. {replicate (k + 1) 0[i := n]}"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1808
  let ?K = "{0 ..k}"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1809
  have fK: "finite ?K" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1810
  have fAK: "\<forall>i\<in>?K. finite (?A i)" by auto
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1811
  have d: "\<forall>i\<in> ?K. \<forall>j\<in> ?K. i \<noteq> j \<longrightarrow>
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  1812
    {replicate (k + 1) 0[i := n]} \<inter> {replicate (k + 1) 0[j := n]} = {}"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1813
  proof clarify
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1814
    fix i j
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1815
    assume i: "i \<in> ?K" and j: "j\<in> ?K" and ij: "i\<noteq>j"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1816
    {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1817
      assume eq: "replicate (k+1) 0 [i:=n] = replicate (k+1) 0 [j:= n]"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1818
      have "(replicate (k+1) 0 [i:=n] ! i) = n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1819
        using i by (simp del: replicate.simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1820
      moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1821
      have "(replicate (k+1) 0 [j:=n] ! i) = 0"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1822
        using i ij by (simp del: replicate.simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1823
      ultimately have False
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1824
        using eq n0 by (simp del: replicate.simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1825
    }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1826
    then show "{replicate (k + 1) 0[i := n]} \<inter> {replicate (k + 1) 0[j := n]} = {}"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1827
      by auto
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1828
  qed
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1829
  from card_UN_disjoint[OF fK fAK d]
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1830
  show "card (\<Union>i\<in>{0..k}. {replicate (k + 1) 0[i := n]}) = k + 1"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  1831
    by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1832
qed
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1833
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1834
lemma power_radical:
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1835
  fixes a:: "'a::field_char_0 fps"
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1836
  assumes a0: "a$0 \<noteq> 0"
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1837
  shows "(r (Suc k) (a$0)) ^ Suc k = a$0 \<longleftrightarrow> (fps_radical r (Suc k) a) ^ (Suc k) = a"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1838
proof -
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1839
  let ?r = "fps_radical r (Suc k) a"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1840
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1841
    assume r0: "(r (Suc k) (a$0)) ^ Suc k = a$0"
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1842
    from a0 r0 have r00: "r (Suc k) (a$0) \<noteq> 0" by auto
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1843
    {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1844
      fix z
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1845
      have "?r ^ Suc k $ z = a$z"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1846
      proof (induct z rule: nat_less_induct)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1847
        fix n
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1848
        assume H: "\<forall>m<n. ?r ^ Suc k $ m = a$m"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1849
        {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1850
          assume "n = 0"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1851
          then have "?r ^ Suc k $ n = a $n"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1852
            using fps_radical_power_nth[of r "Suc k" a, OF r0] by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1853
        }
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1854
        moreover
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1855
        {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1856
          fix n1 assume n1: "n = Suc n1"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1857
          have nz: "n \<noteq> 0" using n1 by arith
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1858
          let ?Pnk = "natpermute n (k + 1)"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1859
          let ?Pnkn = "{xs \<in> ?Pnk. n \<in> set xs}"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1860
          let ?Pnknn = "{xs \<in> ?Pnk. n \<notin> set xs}"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1861
          have eq: "?Pnkn \<union> ?Pnknn = ?Pnk" by blast
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1862
          have d: "?Pnkn \<inter> ?Pnknn = {}" by blast
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1863
          have f: "finite ?Pnkn" "finite ?Pnknn"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1864
            using finite_Un[of ?Pnkn ?Pnknn, unfolded eq]
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1865
            by (metis natpermute_finite)+
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1866
          let ?f = "\<lambda>v. \<Prod>j\<in>{0..k}. ?r $ v ! j"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1867
          have "setsum ?f ?Pnkn = setsum (\<lambda>v. ?r $ n * r (Suc k) (a $ 0) ^ k) ?Pnkn"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1868
          proof (rule setsum.cong)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1869
            fix v assume v: "v \<in> {xs \<in> natpermute n (k + 1). n \<in> set xs}"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1870
            let ?ths = "(\<Prod>j\<in>{0..k}. fps_radical r (Suc k) a $ v ! j) =
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1871
              fps_radical r (Suc k) a $ n * r (Suc k) (a $ 0) ^ k"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1872
            from v obtain i where i: "i \<in> {0..k}" "v = replicate (k+1) 0 [i:= n]"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1873
              unfolding natpermute_contain_maximal by auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1874
            have "(\<Prod>j\<in>{0..k}. fps_radical r (Suc k) a $ v ! j) =
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1875
                (\<Prod>j\<in>{0..k}. if j = i then fps_radical r (Suc k) a $ n else r (Suc k) (a$0))"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1876
              apply (rule setprod.cong, simp)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1877
              using i r0
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1878
              apply (simp del: replicate.simps)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1879
              done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1880
            also have "\<dots> = (fps_radical r (Suc k) a $ n) * r (Suc k) (a$0) ^ k"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1881
              using i r0 by (simp add: setprod_gen_delta)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1882
            finally show ?ths .
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1883
          qed rule
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1884
          then have "setsum ?f ?Pnkn = of_nat (k+1) * ?r $ n * r (Suc k) (a $ 0) ^ k"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1885
            by (simp add: natpermute_max_card[OF nz, simplified])
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1886
          also have "\<dots> = a$n - setsum ?f ?Pnknn"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1887
            unfolding n1 using r00 a0 by (simp add: field_simps fps_radical_def del: of_nat_Suc)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1888
          finally have fn: "setsum ?f ?Pnkn = a$n - setsum ?f ?Pnknn" .
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1889
          have "(?r ^ Suc k)$n = setsum ?f ?Pnkn + setsum ?f ?Pnknn"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1890
            unfolding fps_power_nth_Suc setsum.union_disjoint[OF f d, unfolded eq] ..
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1891
          also have "\<dots> = a$n" unfolding fn by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1892
          finally have "?r ^ Suc k $ n = a $n" .
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1893
        }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1894
        ultimately  show "?r ^ Suc k $ n = a $n" by (cases n) auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1895
      qed
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1896
    }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1897
    then have ?thesis using r0 by (simp add: fps_eq_iff)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1898
  }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1899
  moreover
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1900
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1901
    assume h: "(fps_radical r (Suc k) a) ^ (Suc k) = a"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1902
    then have "((fps_radical r (Suc k) a) ^ (Suc k))$0 = a$0" by simp
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1903
    then have "(r (Suc k) (a$0)) ^ Suc k = a$0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1904
      unfolding fps_power_nth_Suc
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1905
      by (simp add: setprod_constant del: replicate.simps)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1906
  }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1907
  ultimately show ?thesis by blast
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1908
qed
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1909
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1910
(*
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1911
lemma power_radical:
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  1912
  fixes a:: "'a::field_char_0 fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1913
  assumes r0: "(r (Suc k) (a$0)) ^ Suc k = a$0" and a0: "a$0 \<noteq> 0"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1914
  shows "(fps_radical r (Suc k) a) ^ (Suc k) = a"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1915
proof-
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1916
  let ?r = "fps_radical r (Suc k) a"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1917
  from a0 r0 have r00: "r (Suc k) (a$0) \<noteq> 0" by auto
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1918
  {fix z have "?r ^ Suc k $ z = a$z"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1919
    proof(induct z rule: nat_less_induct)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1920
      fix n assume H: "\<forall>m<n. ?r ^ Suc k $ m = a$m"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1921
      {assume "n = 0" then have "?r ^ Suc k $ n = a $n"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1922
          using fps_radical_power_nth[of r "Suc k" a, OF r0] by simp}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1923
      moreover
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1924
      {fix n1 assume n1: "n = Suc n1"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1925
        have fK: "finite {0..k}" by simp
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1926
        have nz: "n \<noteq> 0" using n1 by arith
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1927
        let ?Pnk = "natpermute n (k + 1)"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1928
        let ?Pnkn = "{xs \<in> ?Pnk. n \<in> set xs}"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1929
        let ?Pnknn = "{xs \<in> ?Pnk. n \<notin> set xs}"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1930
        have eq: "?Pnkn \<union> ?Pnknn = ?Pnk" by blast
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1931
        have d: "?Pnkn \<inter> ?Pnknn = {}" by blast
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1932
        have f: "finite ?Pnkn" "finite ?Pnknn"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1933
          using finite_Un[of ?Pnkn ?Pnknn, unfolded eq]
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1934
          by (metis natpermute_finite)+
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1935
        let ?f = "\<lambda>v. \<Prod>j\<in>{0..k}. ?r $ v ! j"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1936
        have "setsum ?f ?Pnkn = setsum (\<lambda>v. ?r $ n * r (Suc k) (a $ 0) ^ k) ?Pnkn"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1937
        proof(rule setsum.cong2)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1938
          fix v assume v: "v \<in> {xs \<in> natpermute n (k + 1). n \<in> set xs}"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1939
          let ?ths = "(\<Prod>j\<in>{0..k}. fps_radical r (Suc k) a $ v ! j) = fps_radical r (Suc k) a $ n * r (Suc k) (a $ 0) ^ k"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1940
          from v obtain i where i: "i \<in> {0..k}" "v = replicate (k+1) 0 [i:= n]"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1941
            unfolding natpermute_contain_maximal by auto
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1942
          have "(\<Prod>j\<in>{0..k}. fps_radical r (Suc k) a $ v ! j) = (\<Prod>j\<in>{0..k}. if j = i then fps_radical r (Suc k) a $ n else r (Suc k) (a$0))"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1943
            apply (rule setprod.cong, simp)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1944
            using i r0 by (simp del: replicate.simps)
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1945
          also have "\<dots> = (fps_radical r (Suc k) a $ n) * r (Suc k) (a$0) ^ k"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1946
            unfolding setprod_gen_delta[OF fK] using i r0 by simp
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1947
          finally show ?ths .
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1948
        qed
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1949
        then have "setsum ?f ?Pnkn = of_nat (k+1) * ?r $ n * r (Suc k) (a $ 0) ^ k"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1950
          by (simp add: natpermute_max_card[OF nz, simplified])
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1951
        also have "\<dots> = a$n - setsum ?f ?Pnknn"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1952
          unfolding n1 using r00 a0 by (simp add: field_simps fps_radical_def del: of_nat_Suc )
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1953
        finally have fn: "setsum ?f ?Pnkn = a$n - setsum ?f ?Pnknn" .
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1954
        have "(?r ^ Suc k)$n = setsum ?f ?Pnkn + setsum ?f ?Pnknn"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  1955
          unfolding fps_power_nth_Suc setsum.union_disjoint[OF f d, unfolded eq] ..
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1956
        also have "\<dots> = a$n" unfolding fn by simp
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1957
        finally have "?r ^ Suc k $ n = a $n" .}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1958
      ultimately  show "?r ^ Suc k $ n = a $n" by (cases n, auto)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1959
  qed }
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1960
  then show ?thesis by (simp add: fps_eq_iff)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1961
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1962
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  1963
*)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1964
lemma eq_divide_imp':
56480
093ea91498e6 field_simps: better support for negation and division, and power
hoelzl
parents: 56479
diff changeset
  1965
  fixes c :: "'a::field" shows "c \<noteq> 0 \<Longrightarrow> a * c = b \<Longrightarrow> a = b / c"
093ea91498e6 field_simps: better support for negation and division, and power
hoelzl
parents: 56479
diff changeset
  1966
  by (simp add: field_simps)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1967
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1968
lemma radical_unique:
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  1969
  assumes r0: "(r (Suc k) (b$0)) ^ Suc k = b$0"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1970
    and a0: "r (Suc k) (b$0 ::'a::field_char_0) = a$0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1971
    and b0: "b$0 \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1972
  shows "a^(Suc k) = b \<longleftrightarrow> a = fps_radical r (Suc k) b"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  1973
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1974
  let ?r = "fps_radical r (Suc k) b"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1975
  have r00: "r (Suc k) (b$0) \<noteq> 0" using b0 r0 by auto
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1976
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1977
    assume H: "a = ?r"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1978
    from H have "a^Suc k = b"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1979
      using power_radical[OF b0, of r k, unfolded r0] by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1980
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1981
  moreover
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1982
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1983
    assume H: "a^Suc k = b"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1984
    have ceq: "card {0..k} = Suc k" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  1985
    from a0 have a0r0: "a$0 = ?r$0" by simp
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1986
    {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1987
      fix n
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1988
      have "a $ n = ?r $ n"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1989
      proof (induct n rule: nat_less_induct)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1990
        fix n
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1991
        assume h: "\<forall>m<n. a$m = ?r $m"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1992
        {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1993
          assume "n = 0"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  1994
          then have "a$n = ?r $n" using a0 by simp
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1995
        }
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  1996
        moreover
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1997
        {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1998
          fix n1
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  1999
          assume n1: "n = Suc n1"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2000
          have fK: "finite {0..k}" by simp
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2001
        have nz: "n \<noteq> 0" using n1 by arith
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2002
        let ?Pnk = "natpermute n (Suc k)"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2003
        let ?Pnkn = "{xs \<in> ?Pnk. n \<in> set xs}"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2004
        let ?Pnknn = "{xs \<in> ?Pnk. n \<notin> set xs}"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2005
        have eq: "?Pnkn \<union> ?Pnknn = ?Pnk" by blast
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2006
        have d: "?Pnkn \<inter> ?Pnknn = {}" by blast
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2007
        have f: "finite ?Pnkn" "finite ?Pnknn"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2008
          using finite_Un[of ?Pnkn ?Pnknn, unfolded eq]
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2009
          by (metis natpermute_finite)+
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2010
        let ?f = "\<lambda>v. \<Prod>j\<in>{0..k}. ?r $ v ! j"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2011
        let ?g = "\<lambda>v. \<Prod>j\<in>{0..k}. a $ v ! j"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2012
        have "setsum ?g ?Pnkn = setsum (\<lambda>v. a $ n * (?r$0)^k) ?Pnkn"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2013
        proof (rule setsum.cong)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2014
          fix v
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2015
          assume v: "v \<in> {xs \<in> natpermute n (Suc k). n \<in> set xs}"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2016
          let ?ths = "(\<Prod>j\<in>{0..k}. a $ v ! j) = a $ n * (?r$0)^k"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2017
          from v obtain i where i: "i \<in> {0..k}" "v = replicate (k+1) 0 [i:= n]"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2018
            unfolding Suc_eq_plus1 natpermute_contain_maximal
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2019
            by (auto simp del: replicate.simps)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2020
          have "(\<Prod>j\<in>{0..k}. a $ v ! j) = (\<Prod>j\<in>{0..k}. if j = i then a $ n else r (Suc k) (b$0))"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2021
            apply (rule setprod.cong, simp)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2022
            using i a0
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2023
            apply (simp del: replicate.simps)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2024
            done
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2025
          also have "\<dots> = a $ n * (?r $ 0)^k"
46757
ad878aff9c15 removing finiteness goals
bulwahn
parents: 46131
diff changeset
  2026
            using i by (simp add: setprod_gen_delta)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2027
          finally show ?ths .
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2028
        qed rule
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2029
        then have th0: "setsum ?g ?Pnkn = of_nat (k+1) * a $ n * (?r $ 0)^k"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2030
          by (simp add: natpermute_max_card[OF nz, simplified])
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2031
        have th1: "setsum ?g ?Pnknn = setsum ?f ?Pnknn"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2032
        proof (rule setsum.cong, rule refl, rule setprod.cong, simp)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2033
          fix xs i
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2034
          assume xs: "xs \<in> ?Pnknn" and i: "i \<in> {0..k}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2035
          {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2036
            assume c: "n \<le> xs ! i"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2037
            from xs i have "xs !i \<noteq> n"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2038
              by (auto simp add: in_set_conv_nth natpermute_def)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2039
            with c have c': "n < xs!i" by arith
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2040
            have fths: "finite {0 ..< i}" "finite {i}" "finite {i+1..<Suc k}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2041
              by simp_all
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2042
            have d: "{0 ..< i} \<inter> ({i} \<union> {i+1 ..< Suc k}) = {}" "{i} \<inter> {i+1..< Suc k} = {}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2043
              by auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2044
            have eqs: "{0..<Suc k} = {0 ..< i} \<union> ({i} \<union> {i+1 ..< Suc k})"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2045
              using i by auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2046
            from xs have "n = listsum xs"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2047
              by (simp add: natpermute_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2048
            also have "\<dots> = setsum (nth xs) {0..<Suc k}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2049
              using xs by (simp add: natpermute_def listsum_setsum_nth)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2050
            also have "\<dots> = xs!i + setsum (nth xs) {0..<i} + setsum (nth xs) {i+1..<Suc k}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2051
              unfolding eqs  setsum.union_disjoint[OF fths(1) finite_UnI[OF fths(2,3)] d(1)]
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2052
              unfolding setsum.union_disjoint[OF fths(2) fths(3) d(2)]
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2053
              by simp
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2054
            finally have False using c' by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2055
          }
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2056
          then have thn: "xs!i < n" by presburger
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2057
          from h[rule_format, OF thn] show "a$(xs !i) = ?r$(xs!i)" .
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2058
        qed
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2059
        have th00: "\<And>x::'a. of_nat (Suc k) * (x * inverse (of_nat (Suc k))) = x"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2060
          by (simp add: field_simps del: of_nat_Suc)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2061
        from H have "b$n = a^Suc k $ n"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2062
          by (simp add: fps_eq_iff)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2063
        also have "a ^ Suc k$n = setsum ?g ?Pnkn + setsum ?g ?Pnknn"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2064
          unfolding fps_power_nth_Suc
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2065
          using setsum.union_disjoint[OF f d, unfolded Suc_eq_plus1[symmetric],
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2066
            unfolded eq, of ?g] by simp
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2067
        also have "\<dots> = of_nat (k+1) * a $ n * (?r $ 0)^k + setsum ?f ?Pnknn"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2068
          unfolding th0 th1 ..
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2069
        finally have "of_nat (k+1) * a $ n * (?r $ 0)^k = b$n - setsum ?f ?Pnknn"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2070
          by simp
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2071
        then have "a$n = (b$n - setsum ?f ?Pnknn) / (of_nat (k+1) * (?r $ 0)^k)"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2072
          apply -
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2073
          apply (rule eq_divide_imp')
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2074
          using r00
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2075
          apply (simp del: of_nat_Suc)
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
  2076
          apply (simp add: ac_simps)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2077
          done
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2078
        then have "a$n = ?r $n"
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2079
          apply (simp del: of_nat_Suc)
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2080
          unfolding fps_radical_def n1
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2081
          apply (simp add: field_simps n1 th00 del: of_nat_Suc)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2082
          done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2083
        }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2084
        ultimately show "a$n = ?r $ n" by (cases n) auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2085
      qed
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2086
    }
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2087
    then have "a = ?r" by (simp add: fps_eq_iff)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2088
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2089
  ultimately show ?thesis by blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2090
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2091
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2092
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2093
lemma radical_power:
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2094
  assumes r0: "r (Suc k) ((a$0) ^ Suc k) = a$0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2095
    and a0: "(a$0 :: 'a::field_char_0) \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2096
  shows "(fps_radical r (Suc k) (a ^ Suc k)) = a"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2097
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2098
  let ?ak = "a^ Suc k"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2099
  have ak0: "?ak $ 0 = (a$0) ^ Suc k"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2100
    by (simp add: fps_nth_power_0 del: power_Suc)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2101
  from r0 have th0: "r (Suc k) (a ^ Suc k $ 0) ^ Suc k = a ^ Suc k $ 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2102
    using ak0 by auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2103
  from r0 ak0 have th1: "r (Suc k) (a ^ Suc k $ 0) = a $ 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2104
    by auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2105
  from ak0 a0 have ak00: "?ak $ 0 \<noteq>0 "
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2106
    by auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2107
  from radical_unique[of r k ?ak a, OF th0 th1 ak00] show ?thesis
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2108
    by metis
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2109
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2110
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2111
lemma fps_deriv_radical:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2112
  fixes a :: "'a::field_char_0 fps"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2113
  assumes r0: "(r (Suc k) (a$0)) ^ Suc k = a$0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2114
    and a0: "a$0 \<noteq> 0"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  2115
  shows "fps_deriv (fps_radical r (Suc k) a) =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  2116
    fps_deriv a / (fps_const (of_nat (Suc k)) * (fps_radical r (Suc k) a) ^ k)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2117
proof -
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2118
  let ?r = "fps_radical r (Suc k) a"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2119
  let ?w = "(fps_const (of_nat (Suc k)) * ?r ^ k)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2120
  from a0 r0 have r0': "r (Suc k) (a$0) \<noteq> 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2121
    by auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2122
  from r0' have w0: "?w $ 0 \<noteq> 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2123
    by (simp del: of_nat_Suc)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2124
  note th0 = inverse_mult_eq_1[OF w0]
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2125
  let ?iw = "inverse ?w"
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2126
  from iffD1[OF power_radical[of a r], OF a0 r0]
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2127
  have "fps_deriv (?r ^ Suc k) = fps_deriv a"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2128
    by simp
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2129
  then have "fps_deriv ?r * ?w = fps_deriv a"
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
  2130
    by (simp add: fps_deriv_power ac_simps del: power_Suc)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2131
  then have "?iw * fps_deriv ?r * ?w = ?iw * fps_deriv a"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2132
    by simp
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2133
  then have "fps_deriv ?r * (?iw * ?w) = fps_deriv a / ?w"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2134
    by (simp add: fps_divide_def)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2135
  then show ?thesis unfolding th0 by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2136
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2137
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2138
lemma radical_mult_distrib:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2139
  fixes a :: "'a::field_char_0 fps"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2140
  assumes k: "k > 0"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2141
    and ra0: "r k (a $ 0) ^ k = a $ 0"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2142
    and rb0: "r k (b $ 0) ^ k = b $ 0"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2143
    and a0: "a$0 \<noteq> 0"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2144
    and b0: "b$0 \<noteq> 0"
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2145
  shows "r k ((a * b) $ 0) = r k (a $ 0) * r k (b $ 0) \<longleftrightarrow>
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2146
    fps_radical r (k) (a*b) = fps_radical r (k) a * fps_radical r (k) (b)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2147
proof -
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2148
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2149
    assume  r0': "r k ((a * b) $ 0) = r k (a $ 0) * r k (b $ 0)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2150
    from r0' have r0: "(r (k) ((a*b)$0)) ^ k = (a*b)$0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2151
      by (simp add: fps_mult_nth ra0 rb0 power_mult_distrib)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2152
    {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2153
      assume "k = 0"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2154
      then have ?thesis using r0' by simp
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2155
    }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2156
    moreover
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2157
    {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2158
      fix h assume k: "k = Suc h"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2159
      let ?ra = "fps_radical r (Suc h) a"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2160
      let ?rb = "fps_radical r (Suc h) b"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2161
      have th0: "r (Suc h) ((a * b) $ 0) = (fps_radical r (Suc h) a * fps_radical r (Suc h) b) $ 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2162
        using r0' k by (simp add: fps_mult_nth)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2163
      have ab0: "(a*b) $ 0 \<noteq> 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2164
        using a0 b0 by (simp add: fps_mult_nth)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2165
      from radical_unique[of r h "a*b" "fps_radical r (Suc h) a * fps_radical r (Suc h) b", OF r0[unfolded k] th0 ab0, symmetric]
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2166
        iffD1[OF power_radical[of _ r], OF a0 ra0[unfolded k]] iffD1[OF power_radical[of _ r], OF b0 rb0[unfolded k]] k r0'
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2167
      have ?thesis by (auto simp add: power_mult_distrib simp del: power_Suc)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2168
    }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2169
    ultimately have ?thesis by (cases k) auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2170
  }
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2171
  moreover
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2172
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2173
    assume h: "fps_radical r k (a*b) = fps_radical r k a * fps_radical r k b"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2174
    then have "(fps_radical r k (a*b))$0 = (fps_radical r k a * fps_radical r k b)$0"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2175
      by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2176
    then have "r k ((a * b) $ 0) = r k (a $ 0) * r k (b $ 0)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2177
      using k by (simp add: fps_mult_nth)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2178
  }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2179
  ultimately show ?thesis by blast
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2180
qed
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2181
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2182
(*
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2183
lemma radical_mult_distrib:
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2184
  fixes a:: "'a::field_char_0 fps"
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2185
  assumes
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2186
  ra0: "r k (a $ 0) ^ k = a $ 0"
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2187
  and rb0: "r k (b $ 0) ^ k = b $ 0"
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2188
  and r0': "r k ((a * b) $ 0) = r k (a $ 0) * r k (b $ 0)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2189
  and a0: "a$0 \<noteq> 0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2190
  and b0: "b$0 \<noteq> 0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2191
  shows "fps_radical r (k) (a*b) = fps_radical r (k) a * fps_radical r (k) (b)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2192
proof-
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2193
  from r0' have r0: "(r (k) ((a*b)$0)) ^ k = (a*b)$0"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2194
    by (simp add: fps_mult_nth ra0 rb0 power_mult_distrib)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2195
  {assume "k=0" then have ?thesis by simp}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2196
  moreover
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2197
  {fix h assume k: "k = Suc h"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2198
  let ?ra = "fps_radical r (Suc h) a"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2199
  let ?rb = "fps_radical r (Suc h) b"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2200
  have th0: "r (Suc h) ((a * b) $ 0) = (fps_radical r (Suc h) a * fps_radical r (Suc h) b) $ 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2201
    using r0' k by (simp add: fps_mult_nth)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2202
  have ab0: "(a*b) $ 0 \<noteq> 0" using a0 b0 by (simp add: fps_mult_nth)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2203
  from radical_unique[of r h "a*b" "fps_radical r (Suc h) a * fps_radical r (Suc h) b", OF r0[unfolded k] th0 ab0, symmetric]
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2204
    power_radical[of r, OF ra0[unfolded k] a0] power_radical[of r, OF rb0[unfolded k] b0] k
30273
ecd6f0ca62ea declare power_Suc [simp]; remove redundant type-specific versions of power_Suc
huffman
parents: 29915
diff changeset
  2205
  have ?thesis by (auto simp add: power_mult_distrib simp del: power_Suc)}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2206
ultimately show ?thesis by (cases k, auto)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2207
qed
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2208
*)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2209
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2210
lemma fps_divide_1[simp]: "(a :: 'a::field fps) / 1 = a"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2211
  by (simp add: fps_divide_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2212
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2213
lemma radical_divide:
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2214
  fixes a :: "'a::field_char_0 fps"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2215
  assumes kp: "k > 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2216
    and ra0: "(r k (a $ 0)) ^ k = a $ 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2217
    and rb0: "(r k (b $ 0)) ^ k = b $ 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2218
    and a0: "a$0 \<noteq> 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2219
    and b0: "b$0 \<noteq> 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2220
  shows "r k ((a $ 0) / (b$0)) = r k (a$0) / r k (b $ 0) \<longleftrightarrow>
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2221
    fps_radical r k (a/b) = fps_radical r k a / fps_radical r k b"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2222
  (is "?lhs = ?rhs")
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2223
proof -
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2224
  let ?r = "fps_radical r k"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2225
  from kp obtain h where k: "k = Suc h" by (cases k) auto
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2226
  have ra0': "r k (a$0) \<noteq> 0" using a0 ra0 k by auto
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2227
  have rb0': "r k (b$0) \<noteq> 0" using b0 rb0 k by auto
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2228
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2229
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2230
    assume ?rhs
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2231
    then have "?r (a/b) $ 0 = (?r a / ?r b)$0" by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2232
    then have ?lhs using k a0 b0 rb0'
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2233
      by (simp add: fps_divide_def fps_mult_nth fps_inverse_def divide_inverse)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2234
  }
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2235
  moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2236
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2237
    assume h: ?lhs
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2238
    from a0 b0 have ab0[simp]: "(a/b)$0 = a$0 / b$0"
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2239
      by (simp add: fps_divide_def fps_mult_nth divide_inverse fps_inverse_def)
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2240
    have th0: "r k ((a/b)$0) ^ k = (a/b)$0"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2241
      by (simp add: h nonzero_power_divide[OF rb0'] ra0 rb0)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2242
    from a0 b0 ra0' rb0' kp h
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2243
    have th1: "r k ((a / b) $ 0) = (fps_radical r k a / fps_radical r k b) $ 0"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2244
      by (simp add: fps_divide_def fps_mult_nth fps_inverse_def divide_inverse)
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2245
    from a0 b0 ra0' rb0' kp have ab0': "(a / b) $ 0 \<noteq> 0"
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2246
      by (simp add: fps_divide_def fps_mult_nth fps_inverse_def nonzero_imp_inverse_nonzero)
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2247
    note tha[simp] = iffD1[OF power_radical[where r=r and k=h], OF a0 ra0[unfolded k], unfolded k[symmetric]]
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2248
    note thb[simp] = iffD1[OF power_radical[where r=r and k=h], OF b0 rb0[unfolded k], unfolded k[symmetric]]
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2249
    have th2: "(?r a / ?r b)^k = a/b"
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2250
      by (simp add: fps_divide_def power_mult_distrib fps_inverse_power[symmetric])
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2251
    from iffD1[OF radical_unique[where r=r and a="?r a / ?r b" and b="a/b" and k=h], symmetric, unfolded k[symmetric], OF th0 th1 ab0' th2]
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2252
    have ?rhs .
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2253
  }
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2254
  ultimately show ?thesis by blast
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2255
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2256
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2257
lemma radical_inverse:
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2258
  fixes a :: "'a::field_char_0 fps"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2259
  assumes k: "k > 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2260
    and ra0: "r k (a $ 0) ^ k = a $ 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2261
    and r1: "(r k 1)^k = 1"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2262
    and a0: "a$0 \<noteq> 0"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  2263
  shows "r k (inverse (a $ 0)) = r k 1 / (r k (a $ 0)) \<longleftrightarrow>
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  2264
    fps_radical r k (inverse a) = fps_radical r k 1 / fps_radical r k a"
31073
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2265
  using radical_divide[where k=k and r=r and a=1 and b=a, OF k ] ra0 r1 a0
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2266
  by (simp add: divide_inverse fps_divide_def)
4b44c4d08aa6 Generalized distributivity theorems of radicals over multiplication, division and inverses
chaieb
parents: 31021
diff changeset
  2267
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  2268
subsection{* Derivative of composition *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2269
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2270
lemma fps_compose_deriv:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2271
  fixes a :: "'a::idom fps"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2272
  assumes b0: "b$0 = 0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2273
  shows "fps_deriv (a oo b) = ((fps_deriv a) oo b) * fps_deriv b"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2274
proof -
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2275
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2276
    fix n
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2277
    have "(fps_deriv (a oo b))$n = setsum (\<lambda>i. a $ i * (fps_deriv (b^i))$n) {0.. Suc n}"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2278
      by (simp add: fps_compose_def field_simps setsum_right_distrib del: of_nat_Suc)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2279
    also have "\<dots> = setsum (\<lambda>i. a$i * ((fps_const (of_nat i)) * (fps_deriv b * (b^(i - 1))))$n) {0.. Suc n}"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2280
      by (simp add: field_simps fps_deriv_power del: fps_mult_left_const_nth of_nat_Suc)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2281
    also have "\<dots> = setsum (\<lambda>i. of_nat i * a$i * (((b^(i - 1)) * fps_deriv b))$n) {0.. Suc n}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2282
      unfolding fps_mult_left_const_nth  by (simp add: field_simps)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2283
    also have "\<dots> = setsum (\<lambda>i. of_nat i * a$i * (setsum (\<lambda>j. (b^ (i - 1))$j * (fps_deriv b)$(n - j)) {0..n})) {0.. Suc n}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2284
      unfolding fps_mult_nth ..
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2285
    also have "\<dots> = setsum (\<lambda>i. of_nat i * a$i * (setsum (\<lambda>j. (b^ (i - 1))$j * (fps_deriv b)$(n - j)) {0..n})) {1.. Suc n}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2286
      apply (rule setsum.mono_neutral_right)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2287
      apply (auto simp add: mult_delta_left setsum.delta not_le)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2288
      done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2289
    also have "\<dots> = setsum (\<lambda>i. of_nat (i + 1) * a$(i+1) * (setsum (\<lambda>j. (b^ i)$j * of_nat (n - j + 1) * b$(n - j + 1)) {0..n})) {0.. n}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2290
      unfolding fps_deriv_nth
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  2291
      by (rule setsum.reindex_cong [of Suc]) (auto simp add: mult.assoc)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2292
    finally have th0: "(fps_deriv (a oo b))$n =
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2293
      setsum (\<lambda>i. of_nat (i + 1) * a$(i+1) * (setsum (\<lambda>j. (b^ i)$j * of_nat (n - j + 1) * b$(n - j + 1)) {0..n})) {0.. n}" .
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2294
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2295
    have "(((fps_deriv a) oo b) * (fps_deriv b))$n = setsum (\<lambda>i. (fps_deriv b)$ (n - i) * ((fps_deriv a) oo b)$i) {0..n}"
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
  2296
      unfolding fps_mult_nth by (simp add: ac_simps)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2297
    also have "\<dots> = setsum (\<lambda>i. setsum (\<lambda>j. of_nat (n - i +1) * b$(n - i + 1) * of_nat (j + 1) * a$(j+1) * (b^j)$i) {0..n}) {0..n}"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  2298
      unfolding fps_deriv_nth fps_compose_nth setsum_right_distrib mult.assoc
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2299
      apply (rule setsum.cong)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2300
      apply (rule refl)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2301
      apply (rule setsum.mono_neutral_left)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2302
      apply (simp_all add: subset_eq)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2303
      apply clarify
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2304
      apply (subgoal_tac "b^i$x = 0")
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2305
      apply simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2306
      apply (rule startsby_zero_power_prefix[OF b0, rule_format])
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2307
      apply simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2308
      done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2309
    also have "\<dots> = setsum (\<lambda>i. of_nat (i + 1) * a$(i+1) * (setsum (\<lambda>j. (b^ i)$j * of_nat (n - j + 1) * b$(n - j + 1)) {0..n})) {0.. n}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2310
      unfolding setsum_right_distrib
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2311
      apply (subst setsum.commute)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2312
      apply (rule setsum.cong, rule refl)+
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2313
      apply simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2314
      done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2315
    finally have "(fps_deriv (a oo b))$n = (((fps_deriv a) oo b) * (fps_deriv b)) $n"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2316
      unfolding th0 by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2317
  }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2318
  then show ?thesis by (simp add: fps_eq_iff)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2319
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2320
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2321
lemma fps_mult_X_plus_1_nth:
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2322
  "((1+X)*a) $n = (if n = 0 then (a$n :: 'a::comm_ring_1) else a$n + a$(n - 1))"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2323
proof (cases n)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2324
  case 0
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2325
  then show ?thesis
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2326
    by (simp add: fps_mult_nth )
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2327
next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2328
  case (Suc m)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2329
  have "((1+X)*a) $n = setsum (\<lambda>i. (1+X)$i * a$(n-i)) {0..n}"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2330
    by (simp add: fps_mult_nth)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2331
  also have "\<dots> = setsum (\<lambda>i. (1+X)$i * a$(n-i)) {0.. 1}"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2332
    unfolding Suc by (rule setsum.mono_neutral_right) auto
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2333
  also have "\<dots> = (if n = 0 then (a$n :: 'a::comm_ring_1) else a$n + a$(n - 1))"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2334
    by (simp add: Suc)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2335
  finally show ?thesis .
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2336
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2337
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2338
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2339
subsection {* Finite FPS (i.e. polynomials) and X *}
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2340
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2341
lemma fps_poly_sum_X:
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2342
  assumes z: "\<forall>i > n. a$i = (0::'a::comm_ring_1)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2343
  shows "a = setsum (\<lambda>i. fps_const (a$i) * X^i) {0..n}" (is "a = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2344
proof -
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2345
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2346
    fix i
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2347
    have "a$i = ?r$i"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2348
      unfolding fps_setsum_nth fps_mult_left_const_nth X_power_nth
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2349
      by (simp add: mult_delta_right setsum.delta' z)
29913
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
  2350
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2351
  then show ?thesis unfolding fps_eq_iff by blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2352
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2353
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2354
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  2355
subsection{* Compositional inverses *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2356
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2357
fun compinv :: "'a fps \<Rightarrow> nat \<Rightarrow> 'a::field"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2358
where
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2359
  "compinv a 0 = X$0"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2360
| "compinv a (Suc n) =
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2361
    (X$ Suc n - setsum (\<lambda>i. (compinv a i) * (a^i)$Suc n) {0 .. n}) / (a$1) ^ Suc n"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2362
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2363
definition "fps_inv a = Abs_fps (compinv a)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2364
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2365
lemma fps_inv:
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2366
  assumes a0: "a$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2367
    and a1: "a$1 \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2368
  shows "fps_inv a oo a = X"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2369
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2370
  let ?i = "fps_inv a oo a"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2371
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2372
    fix n
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2373
    have "?i $n = X$n"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2374
    proof (induct n rule: nat_less_induct)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2375
      fix n
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2376
      assume h: "\<forall>m<n. ?i$m = X$m"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2377
      show "?i $ n = X$n"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2378
      proof (cases n)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2379
        case 0
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2380
        then show ?thesis using a0
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2381
          by (simp add: fps_compose_nth fps_inv_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2382
      next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2383
        case (Suc n1)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2384
        have "?i $ n = setsum (\<lambda>i. (fps_inv a $ i) * (a^i)$n) {0 .. n1} + fps_inv a $ Suc n1 * (a $ 1)^ Suc n1"
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  2385
          by (simp only: fps_compose_nth) (simp add: Suc startsby_zero_power_nth_same [OF a0] del: power_Suc)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2386
        also have "\<dots> = setsum (\<lambda>i. (fps_inv a $ i) * (a^i)$n) {0 .. n1} +
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2387
          (X$ Suc n1 - setsum (\<lambda>i. (fps_inv a $ i) * (a^i)$n) {0 .. n1})"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2388
          using a0 a1 Suc by (simp add: fps_inv_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2389
        also have "\<dots> = X$n" using Suc by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2390
        finally show ?thesis .
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2391
      qed
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2392
    qed
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2393
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2394
  then show ?thesis by (simp add: fps_eq_iff)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2395
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2396
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2397
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2398
fun gcompinv :: "'a fps \<Rightarrow> 'a fps \<Rightarrow> nat \<Rightarrow> 'a::field"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2399
where
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2400
  "gcompinv b a 0 = b$0"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2401
| "gcompinv b a (Suc n) =
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2402
    (b$ Suc n - setsum (\<lambda>i. (gcompinv b a i) * (a^i)$Suc n) {0 .. n}) / (a$1) ^ Suc n"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2403
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2404
definition "fps_ginv b a = Abs_fps (gcompinv b a)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2405
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2406
lemma fps_ginv:
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2407
  assumes a0: "a$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2408
    and a1: "a$1 \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2409
  shows "fps_ginv b a oo a = b"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2410
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2411
  let ?i = "fps_ginv b a oo a"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2412
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2413
    fix n
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2414
    have "?i $n = b$n"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2415
    proof (induct n rule: nat_less_induct)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2416
      fix n
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2417
      assume h: "\<forall>m<n. ?i$m = b$m"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2418
      show "?i $ n = b$n"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2419
      proof (cases n)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2420
        case 0
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2421
        then show ?thesis using a0
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2422
          by (simp add: fps_compose_nth fps_ginv_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2423
      next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2424
        case (Suc n1)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  2425
        have "?i $ n = setsum (\<lambda>i. (fps_ginv b a $ i) * (a^i)$n) {0 .. n1} + fps_ginv b a $ Suc n1 * (a $ 1)^ Suc n1"
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  2426
          by (simp only: fps_compose_nth) (simp add: Suc startsby_zero_power_nth_same [OF a0] del: power_Suc)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2427
        also have "\<dots> = setsum (\<lambda>i. (fps_ginv b a $ i) * (a^i)$n) {0 .. n1} +
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2428
          (b$ Suc n1 - setsum (\<lambda>i. (fps_ginv b a $ i) * (a^i)$n) {0 .. n1})"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2429
          using a0 a1 Suc by (simp add: fps_ginv_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2430
        also have "\<dots> = b$n" using Suc by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2431
        finally show ?thesis .
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2432
      qed
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2433
    qed
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2434
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2435
  then show ?thesis by (simp add: fps_eq_iff)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2436
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2437
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2438
lemma fps_inv_ginv: "fps_inv = fps_ginv X"
39302
d7728f65b353 renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents: 39198
diff changeset
  2439
  apply (auto simp add: fun_eq_iff fps_eq_iff fps_inv_def fps_ginv_def)
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2440
  apply (induct_tac n rule: nat_less_induct)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2441
  apply auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2442
  apply (case_tac na)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2443
  apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2444
  apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2445
  done
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2446
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2447
lemma fps_compose_1[simp]: "1 oo a = 1"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2448
  by (simp add: fps_eq_iff fps_compose_nth mult_delta_left setsum.delta)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2449
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2450
lemma fps_compose_0[simp]: "0 oo a = 0"
29913
89eadbe71e97 add mult_delta lemmas; simplify some proofs
huffman
parents: 29912
diff changeset
  2451
  by (simp add: fps_eq_iff fps_compose_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2452
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2453
lemma fps_compose_0_right[simp]: "a oo 0 = fps_const (a$0)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2454
  by (auto simp add: fps_eq_iff fps_compose_nth power_0_left setsum.neutral)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2455
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2456
lemma fps_compose_add_distrib: "(a + b) oo c = (a oo c) + (b oo c)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2457
  by (simp add: fps_eq_iff fps_compose_nth field_simps setsum.distrib)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2458
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2459
lemma fps_compose_setsum_distrib: "(setsum f S) oo a = setsum (\<lambda>i. f i oo a) S"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2460
proof (cases "finite S")
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2461
  case True
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2462
  show ?thesis
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2463
  proof (rule finite_induct[OF True])
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2464
    show "setsum f {} oo a = (\<Sum>i\<in>{}. f i oo a)" by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2465
  next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2466
    fix x F
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2467
    assume fF: "finite F"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2468
      and xF: "x \<notin> F"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2469
      and h: "setsum f F oo a = setsum (\<lambda>i. f i oo a) F"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2470
    show "setsum f (insert x F) oo a  = setsum (\<lambda>i. f i oo a) (insert x F)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2471
      using fF xF h by (simp add: fps_compose_add_distrib)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2472
  qed
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2473
next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2474
  case False
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2475
  then show ?thesis by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2476
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2477
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2478
lemma convolution_eq:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2479
  "setsum (\<lambda>i. a (i :: nat) * b (n - i)) {0 .. n} =
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2480
    setsum (\<lambda>(i,j). a i * b j) {(i,j). i \<le> n \<and> j \<le> n \<and> i + j = n}"
57129
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
  2481
  by (rule setsum.reindex_bij_witness[where i=fst and j="\<lambda>i. (i, n - i)"]) auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2482
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2483
lemma product_composition_lemma:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2484
  assumes c0: "c$0 = (0::'a::idom)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2485
    and d0: "d$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2486
  shows "((a oo c) * (b oo d))$n =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2487
    setsum (\<lambda>(k,m). a$k * b$m * (c^k * d^m) $ n) {(k,m). k + m \<le> n}"  (is "?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2488
proof -
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2489
  let ?S = "{(k::nat, m::nat). k + m \<le> n}"
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2490
  have s: "?S \<subseteq> {0..n} <*> {0..n}" by (auto simp add: subset_eq)
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2491
  have f: "finite {(k::nat, m::nat). k + m \<le> n}"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2492
    apply (rule finite_subset[OF s])
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2493
    apply auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2494
    done
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2495
  have "?r =  setsum (\<lambda>i. setsum (\<lambda>(k,m). a$k * (c^k)$i * b$m * (d^m) $ (n - i)) {(k,m). k + m \<le> n}) {0..n}"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2496
    apply (simp add: fps_mult_nth setsum_right_distrib)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2497
    apply (subst setsum.commute)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2498
    apply (rule setsum.cong)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2499
    apply (auto simp add: field_simps)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2500
    done
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2501
  also have "\<dots> = ?l"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2502
    apply (simp add: fps_mult_nth fps_compose_nth setsum_product)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2503
    apply (rule setsum.cong)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2504
    apply (rule refl)
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  2505
    apply (simp add: setsum.cartesian_product mult.assoc)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2506
    apply (rule setsum.mono_neutral_right[OF f])
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2507
    apply (simp add: subset_eq)
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2508
    apply presburger
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2509
    apply clarsimp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2510
    apply (rule ccontr)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2511
    apply (clarsimp simp add: not_le)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2512
    apply (case_tac "x < aa")
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2513
    apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2514
    apply (frule_tac startsby_zero_power_prefix[rule_format, OF c0])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2515
    apply blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2516
    apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2517
    apply (frule_tac startsby_zero_power_prefix[rule_format, OF d0])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2518
    apply blast
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2519
    done
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2520
  finally show ?thesis by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2521
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2522
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2523
lemma product_composition_lemma':
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2524
  assumes c0: "c$0 = (0::'a::idom)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2525
    and d0: "d$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2526
  shows "((a oo c) * (b oo d))$n =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2527
    setsum (\<lambda>k. setsum (\<lambda>m. a$k * b$m * (c^k * d^m) $ n) {0..n}) {0..n}"  (is "?l = ?r")
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2528
  unfolding product_composition_lemma[OF c0 d0]
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2529
  unfolding setsum.cartesian_product
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2530
  apply (rule setsum.mono_neutral_left)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2531
  apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2532
  apply (clarsimp simp add: subset_eq)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2533
  apply clarsimp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2534
  apply (rule ccontr)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2535
  apply (subgoal_tac "(c^aa * d^ba) $ n = 0")
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2536
  apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2537
  unfolding fps_mult_nth
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2538
  apply (rule setsum.neutral)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2539
  apply (clarsimp simp add: not_le)
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 51107
diff changeset
  2540
  apply (case_tac "x < aa")
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2541
  apply (rule startsby_zero_power_prefix[OF c0, rule_format])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2542
  apply simp
51489
f738e6dbd844 fundamental revision of big operators on sets
haftmann
parents: 51107
diff changeset
  2543
  apply (subgoal_tac "n - x < ba")
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2544
  apply (frule_tac k = "ba" in startsby_zero_power_prefix[OF d0, rule_format])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2545
  apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2546
  apply arith
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2547
  done
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2548
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2549
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2550
lemma setsum_pair_less_iff:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2551
  "setsum (\<lambda>((k::nat),m). a k * b m * c (k + m)) {(k,m). k + m \<le> n} =
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2552
    setsum (\<lambda>s. setsum (\<lambda>i. a i * b (s - i) * c s) {0..s}) {0..n}"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2553
  (is "?l = ?r")
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2554
proof -
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2555
  let ?KM = "{(k,m). k + m \<le> n}"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2556
  let ?f = "\<lambda>s. UNION {(0::nat)..s} (\<lambda>i. {(i,s - i)})"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2557
  have th0: "?KM = UNION {0..n} ?f"
59862
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  2558
    by (auto simp add: set_eq_iff Bex_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2559
  show "?l = ?r "
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2560
    unfolding th0
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2561
    apply (subst setsum.UNION_disjoint)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2562
    apply auto
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2563
    apply (subst setsum.UNION_disjoint)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2564
    apply auto
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2565
    done
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2566
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2567
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2568
lemma fps_compose_mult_distrib_lemma:
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2569
  assumes c0: "c$0 = (0::'a::idom)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2570
  shows "((a oo c) * (b oo c))$n =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2571
    setsum (\<lambda>s. setsum (\<lambda>i. a$i * b$(s - i) * (c^s) $ n) {0..s}) {0..n}"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2572
    (is "?l = ?r")
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2573
  unfolding product_composition_lemma[OF c0 c0] power_add[symmetric]
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2574
  unfolding setsum_pair_less_iff[where a = "\<lambda>k. a$k" and b="\<lambda>m. b$m" and c="\<lambda>s. (c ^ s)$n" and n = n] ..
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2575
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2576
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2577
lemma fps_compose_mult_distrib:
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  2578
  assumes c0: "c $ 0 = (0::'a::idom)"
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  2579
  shows "(a * b) oo c = (a oo c) * (b oo c)"
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  2580
  apply (simp add: fps_eq_iff fps_compose_mult_distrib_lemma [OF c0])
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2581
  apply (simp add: fps_compose_nth fps_mult_nth setsum_left_distrib)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2582
  done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2583
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2584
lemma fps_compose_setprod_distrib:
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2585
  assumes c0: "c$0 = (0::'a::idom)"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2586
  shows "setprod a S oo c = setprod (\<lambda>k. a k oo c) S"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2587
  apply (cases "finite S")
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2588
  apply simp_all
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2589
  apply (induct S rule: finite_induct)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2590
  apply simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2591
  apply (simp add: fps_compose_mult_distrib[OF c0])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2592
  done
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2593
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2594
lemma fps_compose_power:
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2595
  assumes c0: "c$0 = (0::'a::idom)"
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2596
  shows "(a oo c)^n = a^n oo c"
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2597
  (is "?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2598
proof (cases n)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2599
  case 0
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2600
  then show ?thesis by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2601
next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2602
  case (Suc m)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2603
  have th0: "a^n = setprod (\<lambda>k. a) {0..m}" "(a oo c) ^ n = setprod (\<lambda>k. a oo c) {0..m}"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2604
    by (simp_all add: setprod_constant Suc)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2605
  then show ?thesis
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2606
    by (simp add: fps_compose_setprod_distrib[OF c0])
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2607
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2608
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2609
lemma fps_compose_uminus: "- (a::'a::ring_1 fps) oo c = - (a oo c)"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2610
  by (simp add: fps_eq_iff fps_compose_nth field_simps setsum_negf[symmetric])
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2611
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2612
lemma fps_compose_sub_distrib: "(a - b) oo (c::'a::ring_1 fps) = (a oo c) - (b oo c)"
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53374
diff changeset
  2613
  using fps_compose_add_distrib [of a "- b" c] by (simp add: fps_compose_uminus)
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2614
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2615
lemma X_fps_compose: "X oo a = Abs_fps (\<lambda>n. if n = 0 then (0::'a::comm_ring_1) else a$n)"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2616
  by (simp add: fps_eq_iff fps_compose_nth mult_delta_left setsum.delta)
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2617
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2618
lemma fps_inverse_compose:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2619
  assumes b0: "(b$0 :: 'a::field) = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2620
    and a0: "a$0 \<noteq> 0"
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2621
  shows "inverse a oo b = inverse (a oo b)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2622
proof -
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2623
  let ?ia = "inverse a"
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2624
  let ?ab = "a oo b"
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2625
  let ?iab = "inverse ?ab"
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2626
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2627
  from a0 have ia0: "?ia $ 0 \<noteq> 0" by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2628
  from a0 have ab0: "?ab $ 0 \<noteq> 0" by (simp add: fps_compose_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2629
  have "(?ia oo b) *  (a oo b) = 1"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2630
    unfolding fps_compose_mult_distrib[OF b0, symmetric]
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2631
    unfolding inverse_mult_eq_1[OF a0]
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2632
    fps_compose_1 ..
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2633
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2634
  then have "(?ia oo b) *  (a oo b) * ?iab  = 1 * ?iab" by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2635
  then have "(?ia oo b) *  (?iab * (a oo b))  = ?iab" by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2636
  then show ?thesis unfolding inverse_mult_eq_1[OF ab0] by simp
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2637
qed
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2638
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2639
lemma fps_divide_compose:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2640
  assumes c0: "(c$0 :: 'a::field) = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2641
    and b0: "b$0 \<noteq> 0"
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2642
  shows "(a/b) oo c = (a oo c) / (b oo c)"
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2643
    unfolding fps_divide_def fps_compose_mult_distrib[OF c0]
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2644
    fps_inverse_compose[OF c0 b0] ..
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2645
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2646
lemma gp:
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2647
  assumes a0: "a$0 = (0::'a::field)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2648
  shows "(Abs_fps (\<lambda>n. 1)) oo a = 1/(1 - a)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2649
    (is "?one oo a = _")
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2650
proof -
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2651
  have o0: "?one $ 0 \<noteq> 0" by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2652
  have th0: "(1 - X) $ 0 \<noteq> (0::'a)" by simp
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2653
  from fps_inverse_gp[where ?'a = 'a]
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2654
  have "inverse ?one = 1 - X" by (simp add: fps_eq_iff)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2655
  then have "inverse (inverse ?one) = inverse (1 - X)" by simp
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2656
  then have th: "?one = 1/(1 - X)" unfolding fps_inverse_idempotent[OF o0]
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2657
    by (simp add: fps_divide_def)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2658
  show ?thesis
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2659
    unfolding th
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2660
    unfolding fps_divide_compose[OF a0 th0]
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2661
    fps_compose_1 fps_compose_sub_distrib X_fps_compose_startby0[OF a0] ..
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2662
qed
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2663
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2664
lemma fps_const_power [simp]: "fps_const (c::'a::ring_1) ^ n = fps_const (c^n)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  2665
  by (induct n) auto
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2666
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2667
lemma fps_compose_radical:
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2668
  assumes b0: "b$0 = (0::'a::field_char_0)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2669
    and ra0: "r (Suc k) (a$0) ^ Suc k = a$0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2670
    and a0: "a$0 \<noteq> 0"
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2671
  shows "fps_radical r (Suc k)  a oo b = fps_radical r (Suc k) (a oo b)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2672
proof -
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2673
  let ?r = "fps_radical r (Suc k)"
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2674
  let ?ab = "a oo b"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2675
  have ab0: "?ab $ 0 = a$0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2676
    by (simp add: fps_compose_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2677
  from ab0 a0 ra0 have rab0: "?ab $ 0 \<noteq> 0" "r (Suc k) (?ab $ 0) ^ Suc k = ?ab $ 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2678
    by simp_all
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2679
  have th00: "r (Suc k) ((a oo b) $ 0) = (fps_radical r (Suc k) a oo b) $ 0"
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2680
    by (simp add: ab0 fps_compose_def)
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2681
  have th0: "(?r a oo b) ^ (Suc k) = a  oo b"
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2682
    unfolding fps_compose_power[OF b0]
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2683
    unfolding iffD1[OF power_radical[of a r k], OF a0 ra0]  ..
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2684
  from iffD1[OF radical_unique[where r=r and k=k and b= ?ab and a = "?r a oo b", OF rab0(2) th00 rab0(1)], OF th0]
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2685
  show ?thesis  .
31199
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2686
qed
10d413b08fa7 FPS composition distributes over inverses, division and arbitrary nth roots. General geometric series theorem
chaieb
parents: 31148
diff changeset
  2687
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2688
lemma fps_const_mult_apply_left: "fps_const c * (a oo b) = (fps_const c * a) oo b"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  2689
  by (simp add: fps_eq_iff fps_compose_nth setsum_right_distrib mult.assoc)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2690
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2691
lemma fps_const_mult_apply_right:
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2692
  "(a oo b) * fps_const (c::'a::comm_semiring_1) = (fps_const c * a) oo b"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  2693
  by (auto simp add: fps_const_mult_apply_left mult.commute)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2694
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2695
lemma fps_compose_assoc:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2696
  assumes c0: "c$0 = (0::'a::idom)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2697
    and b0: "b$0 = 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2698
  shows "a oo (b oo c) = a oo b oo c" (is "?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2699
proof -
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2700
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2701
    fix n
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2702
    have "?l$n = (setsum (\<lambda>i. (fps_const (a$i) * b^i) oo c) {0..n})$n"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2703
      by (simp add: fps_compose_nth fps_compose_power[OF c0] fps_const_mult_apply_left
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  2704
        setsum_right_distrib mult.assoc fps_setsum_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2705
    also have "\<dots> = ((setsum (\<lambda>i. fps_const (a$i) * b^i) {0..n}) oo c)$n"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2706
      by (simp add: fps_compose_setsum_distrib)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2707
    also have "\<dots> = ?r$n"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  2708
      apply (simp add: fps_compose_nth fps_setsum_nth setsum_left_distrib mult.assoc)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2709
      apply (rule setsum.cong)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2710
      apply (rule refl)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2711
      apply (rule setsum.mono_neutral_right)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2712
      apply (auto simp add: not_le)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2713
      apply (erule startsby_zero_power_prefix[OF b0, rule_format])
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2714
      done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2715
    finally have "?l$n = ?r$n" .
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2716
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2717
  then show ?thesis by (simp add: fps_eq_iff)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2718
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2719
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2720
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2721
lemma fps_X_power_compose:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2722
  assumes a0: "a$0=0"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2723
  shows "X^k oo a = (a::'a::idom fps)^k"
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2724
  (is "?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2725
proof (cases k)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2726
  case 0
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2727
  then show ?thesis by simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2728
next
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  2729
  case (Suc h)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2730
  {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2731
    fix n
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2732
    {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2733
      assume kn: "k>n"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2734
      then have "?l $ n = ?r $n" using a0 startsby_zero_power_prefix[OF a0] Suc
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2735
        by (simp add: fps_compose_nth del: power_Suc)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2736
    }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2737
    moreover
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2738
    {
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2739
      assume kn: "k \<le> n"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2740
      then have "?l$n = ?r$n"
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2741
        by (simp add: fps_compose_nth mult_delta_left setsum.delta)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2742
    }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2743
    moreover have "k >n \<or> k\<le> n"  by arith
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2744
    ultimately have "?l$n = ?r$n"  by blast
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2745
  }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2746
  then show ?thesis unfolding fps_eq_iff by blast
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2747
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2748
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2749
lemma fps_inv_right:
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2750
  assumes a0: "a$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2751
    and a1: "a$1 \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2752
  shows "a oo fps_inv a = X"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2753
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2754
  let ?ia = "fps_inv a"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2755
  let ?iaa = "a oo fps_inv a"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2756
  have th0: "?ia $ 0 = 0" by (simp add: fps_inv_def)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2757
  have th1: "?iaa $ 0 = 0" using a0 a1
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2758
    by (simp add: fps_inv_def fps_compose_nth)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2759
  have th2: "X$0 = 0" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2760
  from fps_inv[OF a0 a1] have "a oo (fps_inv a oo a) = a oo X" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2761
  then have "(a oo fps_inv a) oo a = X oo a"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2762
    by (simp add: fps_compose_assoc[OF a0 th0] X_fps_compose_startby0[OF a0])
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2763
  with fps_compose_inj_right[OF a0 a1]
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2764
  show ?thesis by simp
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2765
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2766
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2767
lemma fps_inv_deriv:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2768
  assumes a0:"a$0 = (0::'a::field)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2769
    and a1: "a$1 \<noteq> 0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2770
  shows "fps_deriv (fps_inv a) = inverse (fps_deriv a oo fps_inv a)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2771
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2772
  let ?ia = "fps_inv a"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2773
  let ?d = "fps_deriv a oo ?ia"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2774
  let ?dia = "fps_deriv ?ia"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2775
  have ia0: "?ia$0 = 0" by (simp add: fps_inv_def)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2776
  have th0: "?d$0 \<noteq> 0" using a1 by (simp add: fps_compose_nth)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2777
  from fps_inv_right[OF a0 a1] have "?d * ?dia = 1"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2778
    by (simp add: fps_compose_deriv[OF ia0, of a, symmetric] )
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2779
  then have "inverse ?d * ?d * ?dia = inverse ?d * 1" by simp
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2780
  with inverse_mult_eq_1 [OF th0]
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2781
  show "?dia = inverse ?d" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2782
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2783
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2784
lemma fps_inv_idempotent:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2785
  assumes a0: "a$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2786
    and a1: "a$1 \<noteq> 0"
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2787
  shows "fps_inv (fps_inv a) = a"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2788
proof -
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2789
  let ?r = "fps_inv"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2790
  have ra0: "?r a $ 0 = 0" by (simp add: fps_inv_def)
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2791
  from a1 have ra1: "?r a $ 1 \<noteq> 0" by (simp add: fps_inv_def field_simps)
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2792
  have X0: "X$0 = 0" by simp
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2793
  from fps_inv[OF ra0 ra1] have "?r (?r a) oo ?r a = X" .
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2794
  then have "?r (?r a) oo ?r a oo a = X oo a" by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2795
  then have "?r (?r a) oo (?r a oo a) = a"
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2796
    unfolding X_fps_compose_startby0[OF a0]
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2797
    unfolding fps_compose_assoc[OF a0 ra0, symmetric] .
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2798
  then show ?thesis unfolding fps_inv[OF a0 a1] by simp
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2799
qed
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2800
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2801
lemma fps_ginv_ginv:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2802
  assumes a0: "a$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2803
    and a1: "a$1 \<noteq> 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2804
    and c0: "c$0 = 0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2805
    and  c1: "c$1 \<noteq> 0"
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2806
  shows "fps_ginv b (fps_ginv c a) = b oo a oo fps_inv c"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2807
proof -
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2808
  let ?r = "fps_ginv"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2809
  from c0 have rca0: "?r c a $0 = 0" by (simp add: fps_ginv_def)
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2810
  from a1 c1 have rca1: "?r c a $ 1 \<noteq> 0" by (simp add: fps_ginv_def field_simps)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2811
  from fps_ginv[OF rca0 rca1]
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2812
  have "?r b (?r c a) oo ?r c a = b" .
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2813
  then have "?r b (?r c a) oo ?r c a oo a = b oo a" by simp
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2814
  then have "?r b (?r c a) oo (?r c a oo a) = b oo a"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2815
    apply (subst fps_compose_assoc)
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2816
    using a0 c0
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2817
    apply (auto simp add: fps_ginv_def)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2818
    done
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2819
  then have "?r b (?r c a) oo c = b oo a"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2820
    unfolding fps_ginv[OF a0 a1] .
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2821
  then have "?r b (?r c a) oo c oo fps_inv c= b oo a oo fps_inv c" by simp
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2822
  then have "?r b (?r c a) oo (c oo fps_inv c) = b oo a oo fps_inv c"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2823
    apply (subst fps_compose_assoc)
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2824
    using a0 c0
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2825
    apply (auto simp add: fps_inv_def)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2826
    done
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2827
  then show ?thesis unfolding fps_inv_right[OF c0 c1] by simp
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2828
qed
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2829
32410
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2830
lemma fps_ginv_deriv:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2831
  assumes a0:"a$0 = (0::'a::field)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2832
    and a1: "a$1 \<noteq> 0"
32410
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2833
  shows "fps_deriv (fps_ginv b a) = (fps_deriv b / fps_deriv a) oo fps_ginv X a"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2834
proof -
32410
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2835
  let ?ia = "fps_ginv b a"
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2836
  let ?iXa = "fps_ginv X a"
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2837
  let ?d = "fps_deriv"
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2838
  let ?dia = "?d ?ia"
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2839
  have iXa0: "?iXa $ 0 = 0" by (simp add: fps_ginv_def)
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2840
  have da0: "?d a $ 0 \<noteq> 0" using a1 by simp
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2841
  from fps_ginv[OF a0 a1, of b] have "?d (?ia oo a) = fps_deriv b" by simp
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2842
  then have "(?d ?ia oo a) * ?d a = ?d b" unfolding fps_compose_deriv[OF a0] .
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2843
  then have "(?d ?ia oo a) * ?d a * inverse (?d a) = ?d b * inverse (?d a)" by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2844
  then have "(?d ?ia oo a) * (inverse (?d a) * ?d a) = ?d b / ?d a"
32410
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2845
    by (simp add: fps_divide_def)
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2846
  then have "(?d ?ia oo a) oo ?iXa =  (?d b / ?d a) oo ?iXa "
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2847
    unfolding inverse_mult_eq_1[OF da0] by simp
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2848
  then have "?d ?ia oo (a oo ?iXa) =  (?d b / ?d a) oo ?iXa"
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2849
    unfolding fps_compose_assoc[OF iXa0 a0] .
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2850
  then show ?thesis unfolding fps_inv_ginv[symmetric]
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2851
    unfolding fps_inv_right[OF a0 a1] by simp
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2852
qed
624bd2ea7c1e Derivative of general reverses
chaieb
parents: 31075
diff changeset
  2853
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  2854
subsection{* Elementary series *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2855
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  2856
subsubsection{* Exponential series *}
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2857
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2858
definition "E x = Abs_fps (\<lambda>n. x^n / of_nat (fact n))"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2859
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2860
lemma E_deriv[simp]: "fps_deriv (E a) = fps_const (a::'a::field_char_0) * E a" (is "?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2861
proof -
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2862
  {
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2863
    fix n
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2864
    have "?l$n = ?r $ n"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2865
      apply (auto simp add: E_def field_simps power_Suc[symmetric]
59730
b7c394c7a619 The factorial function, "fact", now has type "nat => 'a"
paulson <lp15@cam.ac.uk>
parents: 59667
diff changeset
  2866
        simp del: fact.simps of_nat_Suc power_Suc)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2867
      apply (simp add: of_nat_mult field_simps)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2868
      done
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2869
  }
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2870
  then show ?thesis by (simp add: fps_eq_iff)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2871
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2872
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2873
lemma E_unique_ODE:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2874
  "fps_deriv a = fps_const c * a \<longleftrightarrow> a = fps_const (a$0) * E (c::'a::field_char_0)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2875
  (is "?lhs \<longleftrightarrow> ?rhs")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2876
proof
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2877
  assume d: ?lhs
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2878
  from d have th: "\<And>n. a $ Suc n = c * a$n / of_nat (Suc n)"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2879
    by (simp add: fps_deriv_def fps_eq_iff field_simps del: of_nat_Suc)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2880
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2881
    fix n
59730
b7c394c7a619 The factorial function, "fact", now has type "nat => 'a"
paulson <lp15@cam.ac.uk>
parents: 59667
diff changeset
  2882
    have "a$n = a$0 * c ^ n/ (fact n)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2883
      apply (induct n)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2884
      apply simp
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2885
      unfolding th
59730
b7c394c7a619 The factorial function, "fact", now has type "nat => 'a"
paulson <lp15@cam.ac.uk>
parents: 59667
diff changeset
  2886
      using fact_gt_zero
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2887
      apply (simp add: field_simps del: of_nat_Suc fact_Suc)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2888
      apply (drule sym)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2889
      apply (simp add: field_simps of_nat_mult)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2890
      done
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2891
  }
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2892
  note th' = this
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2893
  show ?rhs by (auto simp add: fps_eq_iff fps_const_mult_left E_def intro: th')
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2894
next
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2895
  assume h: ?rhs
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2896
  show ?lhs
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2897
    apply (subst h)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2898
    apply simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2899
    apply (simp only: h[symmetric])
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2900
    apply simp
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2901
    done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2902
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2903
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2904
lemma E_add_mult: "E (a + b) = E (a::'a::field_char_0) * E b" (is "?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2905
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2906
  have "fps_deriv (?r) = fps_const (a+b) * ?r"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  2907
    by (simp add: fps_const_add[symmetric] field_simps del: fps_const_add)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2908
  then have "?r = ?l" apply (simp only: E_unique_ODE)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2909
    by (simp add: fps_mult_nth E_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2910
  then show ?thesis ..
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2911
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2912
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2913
lemma E_nth[simp]: "E a $ n = a^n / of_nat (fact n)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2914
  by (simp add: E_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2915
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2916
lemma E0[simp]: "E (0::'a::field) = 1"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2917
  by (simp add: fps_eq_iff power_0_left)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2918
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2919
lemma E_neg: "E (- a) = inverse (E (a::'a::field_char_0))"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2920
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2921
  from E_add_mult[of a "- a"] have th0: "E a * E (- a) = 1"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2922
    by (simp )
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2923
  have th1: "E a $ 0 \<noteq> 0" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2924
  from fps_inverse_unique[OF th1 th0] show ?thesis by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2925
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2926
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2927
lemma E_nth_deriv[simp]: "fps_nth_deriv n (E (a::'a::field_char_0)) = (fps_const a)^n * (E a)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2928
  by (induct n) auto
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2929
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2930
lemma X_compose_E[simp]: "X oo E (a::'a::field) = E a - 1"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2931
  by (simp add: fps_eq_iff X_fps_compose)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2932
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2933
lemma LE_compose:
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2934
  assumes a: "a\<noteq>0"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2935
  shows "fps_inv (E a - 1) oo (E a - 1) = X"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2936
    and "(E a - 1) oo fps_inv (E a - 1) = X"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2937
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2938
  let ?b = "E a - 1"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2939
  have b0: "?b $ 0 = 0" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2940
  have b1: "?b $ 1 \<noteq> 0" by (simp add: a)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2941
  from fps_inv[OF b0 b1] show "fps_inv (E a - 1) oo (E a - 1) = X" .
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2942
  from fps_inv_right[OF b0 b1] show "(E a - 1) oo fps_inv (E a - 1) = X" .
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2943
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2944
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2945
lemma fps_const_inverse:
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2946
  "a \<noteq> 0 \<Longrightarrow> inverse (fps_const (a::'a::field)) = fps_const (inverse a)"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2947
  apply (auto simp add: fps_eq_iff fps_inverse_def)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2948
  apply (case_tac n)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2949
  apply auto
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2950
  done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2951
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2952
lemma inverse_one_plus_X:
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2953
  "inverse (1 + X) = Abs_fps (\<lambda>n. (- 1 ::'a::field)^n)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2954
  (is "inverse ?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2955
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2956
  have th: "?l * ?r = 1"
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  2957
    by (auto simp add: field_simps fps_eq_iff minus_one_power_iff)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2958
  have th': "?l $ 0 \<noteq> 0" by (simp add: )
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2959
  from fps_inverse_unique[OF th' th] show ?thesis .
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2960
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2961
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  2962
lemma E_power_mult: "(E (c::'a::field_char_0))^n = E (of_nat n * c)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2963
  by (induct n) (auto simp add: field_simps E_add_mult)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2964
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  2965
lemma radical_E:
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2966
  assumes r: "r (Suc k) 1 = 1"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2967
  shows "fps_radical r (Suc k) (E (c::'a::field_char_0)) = E (c / of_nat (Suc k))"
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  2968
proof -
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2969
  let ?ck = "(c / of_nat (Suc k))"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2970
  let ?r = "fps_radical r (Suc k)"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2971
  have eq0[simp]: "?ck * of_nat (Suc k) = c" "of_nat (Suc k) * ?ck = c"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2972
    by (simp_all del: of_nat_Suc)
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2973
  have th0: "E ?ck ^ (Suc k) = E c" unfolding E_power_mult eq0 ..
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2974
  have th: "r (Suc k) (E c $0) ^ Suc k = E c $ 0"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2975
    "r (Suc k) (E c $ 0) = E ?ck $ 0" "E c $ 0 \<noteq> 0" using r by simp_all
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2976
  from th0 radical_unique[where r=r and k=k, OF th]
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2977
  show ?thesis by auto
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2978
qed
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2979
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  2980
lemma Ec_E1_eq: "E (1::'a::field_char_0) oo (fps_const c * X) = E c"
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2981
  apply (auto simp add: fps_eq_iff E_def fps_compose_def power_mult_distrib)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  2982
  apply (simp add: cond_value_iff cond_application_beta setsum.delta' cong del: if_weak_cong)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2983
  done
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2984
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  2985
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  2986
subsubsection{* Logarithmic series *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2987
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  2988
lemma Abs_fps_if_0:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  2989
  "Abs_fps(\<lambda>n. if n=0 then (v::'a::ring_1) else f n) = fps_const v + X * Abs_fps (\<lambda>n. f (Suc n))"
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2990
  by (auto simp add: fps_eq_iff)
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2991
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2992
definition L :: "'a::field_char_0 \<Rightarrow> 'a fps"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  2993
  where "L c = fps_const (1/c) * Abs_fps (\<lambda>n. if n = 0 then 0 else (- 1) ^ (n - 1) / of_nat n)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2994
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2995
lemma fps_deriv_L: "fps_deriv (L c) = fps_const (1/c) * inverse (1 + X)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  2996
  unfolding inverse_one_plus_X
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2997
  by (simp add: L_def fps_eq_iff del: of_nat_Suc)
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2998
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  2999
lemma L_nth: "L c $ n = (if n=0 then 0 else 1/c * ((- 1) ^ (n - 1) / of_nat n))"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3000
  by (simp add: L_def field_simps)
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3001
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3002
lemma L_0[simp]: "L c $ 0 = 0" by (simp add: L_def)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3003
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3004
lemma L_E_inv:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3005
  fixes a :: "'a::field_char_0"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3006
  assumes a: "a \<noteq> 0"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3007
  shows "L a = fps_inv (E a - 1)"  (is "?l = ?r")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3008
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3009
  let ?b = "E a - 1"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3010
  have b0: "?b $ 0 = 0" by simp
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3011
  have b1: "?b $ 1 \<noteq> 0" by (simp add: a)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3012
  have "fps_deriv (E a - 1) oo fps_inv (E a - 1) =
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3013
    (fps_const a * (E a - 1) + fps_const a) oo fps_inv (E a - 1)"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3014
    by (simp add: field_simps)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3015
  also have "\<dots> = fps_const a * (X + 1)"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3016
    apply (simp add: fps_compose_add_distrib fps_const_mult_apply_left[symmetric] fps_inv_right[OF b0 b1])
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3017
    apply (simp add: field_simps)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3018
    done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3019
  finally have eq: "fps_deriv (E a - 1) oo fps_inv (E a - 1) = fps_const a * (X + 1)" .
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3020
  from fps_inv_deriv[OF b0 b1, unfolded eq]
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3021
  have "fps_deriv (fps_inv ?b) = fps_const (inverse a) / (X + 1)"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3022
    using a
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3023
    by (simp add: fps_const_inverse eq fps_divide_def fps_inverse_mult)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3024
  then have "fps_deriv ?l = fps_deriv ?r"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  3025
    by (simp add: fps_deriv_L add.commute fps_divide_def divide_inverse)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3026
  then show ?thesis unfolding fps_deriv_eq_iff
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3027
    by (simp add: L_nth fps_inv_def)
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3028
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3029
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3030
lemma L_mult_add:
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3031
  assumes c0: "c\<noteq>0"
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3032
    and d0: "d\<noteq>0"
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3033
  shows "L c + L d = fps_const (c+d) * L (c*d)"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3034
  (is "?r = ?l")
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3035
proof-
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3036
  from c0 d0 have eq: "1/c + 1/d = (c+d)/(c*d)" by (simp add: field_simps)
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3037
  have "fps_deriv ?r = fps_const (1/c + 1/d) * inverse (1 + X)"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3038
    by (simp add: fps_deriv_L fps_const_add[symmetric] algebra_simps del: fps_const_add)
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3039
  also have "\<dots> = fps_deriv ?l"
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3040
    apply (simp add: fps_deriv_L)
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3041
    apply (simp add: fps_eq_iff eq)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3042
    done
31369
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3043
  finally show ?thesis
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3044
    unfolding fps_deriv_eq_iff by simp
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3045
qed
8b460fd12100 Reverses idempotent; radical of E; generalized logarithm;
chaieb
parents: 31199
diff changeset
  3046
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3047
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3048
subsubsection{* Binomial series *}
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3049
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3050
definition "fps_binomial a = Abs_fps (\<lambda>n. a gchoose n)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3051
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3052
lemma fps_binomial_nth[simp]: "fps_binomial a $ n = a gchoose n"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3053
  by (simp add: fps_binomial_def)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3054
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3055
lemma fps_binomial_ODE_unique:
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3056
  fixes c :: "'a::field_char_0"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3057
  shows "fps_deriv a = (fps_const c * a) / (1 + X) \<longleftrightarrow> a = fps_const (a$0) * fps_binomial c"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3058
  (is "?lhs \<longleftrightarrow> ?rhs")
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3059
proof -
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3060
  let ?da = "fps_deriv a"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3061
  let ?x1 = "(1 + X):: 'a fps"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3062
  let ?l = "?x1 * ?da"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3063
  let ?r = "fps_const c * a"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3064
  have x10: "?x1 $ 0 \<noteq> 0" by simp
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3065
  have "?l = ?r \<longleftrightarrow> inverse ?x1 * ?l = inverse ?x1 * ?r" by simp
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3066
  also have "\<dots> \<longleftrightarrow> ?da = (fps_const c * a) / ?x1"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  3067
    apply (simp only: fps_divide_def  mult.assoc[symmetric] inverse_mult_eq_1[OF x10])
52903
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3068
    apply (simp add: field_simps)
6c89225ddeba tuned proofs;
wenzelm
parents: 52902
diff changeset
  3069
    done
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3070
  finally have eq: "?l = ?r \<longleftrightarrow> ?lhs" by simp
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3071
  moreover
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3072
  {assume h: "?l = ?r"
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3073
    {fix n
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3074
      from h have lrn: "?l $ n = ?r$n" by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3075
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3076
      from lrn
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3077
      have "a$ Suc n = ((c - of_nat n) / of_nat (Suc n)) * a $n"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3078
        apply (simp add: field_simps del: of_nat_Suc)
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3079
        by (cases n, simp_all add: field_simps del: of_nat_Suc)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3080
    }
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3081
    note th0 = this
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3082
    {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3083
      fix n
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3084
      have "a$n = (c gchoose n) * a$0"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3085
      proof (induct n)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3086
        case 0
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3087
        then show ?case by simp
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3088
      next
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3089
        case (Suc m)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3090
        then show ?case unfolding th0
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3091
          apply (simp add: field_simps del: of_nat_Suc)
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  3092
          unfolding mult.assoc[symmetric] gbinomial_mult_1
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3093
          apply (simp add: field_simps)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3094
          done
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3095
      qed
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3096
    }
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3097
    note th1 = this
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3098
    have ?rhs
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3099
      apply (simp add: fps_eq_iff)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3100
      apply (subst th1)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3101
      apply (simp add: field_simps)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3102
      done
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3103
  }
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3104
  moreover
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3105
  {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3106
    assume h: ?rhs
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3107
    have th00: "\<And>x y. x * (a$0 * y) = a$0 * (x*y)"
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  3108
      by (simp add: mult.commute)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3109
    have "?l = ?r"
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3110
      apply (subst h)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3111
      apply (subst (2) h)
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3112
      apply (clarsimp simp add: fps_eq_iff field_simps)
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  3113
      unfolding mult.assoc[symmetric] th00 gbinomial_mult_1
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3114
      apply (simp add: field_simps gbinomial_mult_1)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3115
      done
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3116
  }
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3117
  ultimately show ?thesis by blast
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3118
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3119
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3120
lemma fps_binomial_deriv: "fps_deriv (fps_binomial c) = fps_const c * fps_binomial c / (1 + X)"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3121
proof -
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3122
  let ?a = "fps_binomial c"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3123
  have th0: "?a = fps_const (?a$0) * ?a" by (simp)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3124
  from iffD2[OF fps_binomial_ODE_unique, OF th0] show ?thesis .
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3125
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3126
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3127
lemma fps_binomial_add_mult: "fps_binomial (c+d) = fps_binomial c * fps_binomial d" (is "?l = ?r")
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3128
proof -
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3129
  let ?P = "?r - ?l"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3130
  let ?b = "fps_binomial"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3131
  let ?db = "\<lambda>x. fps_deriv (?b x)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3132
  have "fps_deriv ?P = ?db c * ?b d + ?b c * ?db d - ?db (c + d)"  by simp
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3133
  also have "\<dots> = inverse (1 + X) *
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3134
      (fps_const c * ?b c * ?b d + fps_const d * ?b c * ?b d - fps_const (c+d) * ?b (c + d))"
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3135
    unfolding fps_binomial_deriv
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3136
    by (simp add: fps_divide_def field_simps)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3137
  also have "\<dots> = (fps_const (c + d)/ (1 + X)) * ?P"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3138
    by (simp add: field_simps fps_divide_def fps_const_add[symmetric] del: fps_const_add)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3139
  finally have th0: "fps_deriv ?P = fps_const (c+d) * ?P / (1 + X)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3140
    by (simp add: fps_divide_def)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3141
  have "?P = fps_const (?P$0) * ?b (c + d)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3142
    unfolding fps_binomial_ODE_unique[symmetric]
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3143
    using th0 by simp
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3144
  then have "?P = 0" by (simp add: fps_mult_nth)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3145
  then show ?thesis by simp
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3146
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3147
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3148
lemma fps_minomial_minus_one: "fps_binomial (- 1) = inverse (1 + X)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3149
  (is "?l = inverse ?r")
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3150
proof-
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3151
  have th: "?r$0 \<noteq> 0" by simp
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3152
  have th': "fps_deriv (inverse ?r) = fps_const (- 1) * inverse ?r / (1 + X)"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3153
    by (simp add: fps_inverse_deriv[OF th] fps_divide_def
57512
cc97b347b301 reduced name variants for assoc and commute on plus and mult
haftmann
parents: 57418
diff changeset
  3154
      power2_eq_square mult.commute fps_const_neg[symmetric] del: fps_const_neg)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3155
  have eq: "inverse ?r $ 0 = 1"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3156
    by (simp add: fps_inverse_def)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3157
  from iffD1[OF fps_binomial_ODE_unique[of "inverse (1 + X)" "- 1"] th'] eq
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3158
  show ?thesis by (simp add: fps_inverse_def)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3159
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3160
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3161
text{* Vandermonde's Identity as a consequence *}
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3162
lemma gbinomial_Vandermonde:
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3163
  "setsum (\<lambda>k. (a gchoose k) * (b gchoose (n - k))) {0..n} = (a + b) gchoose n"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3164
proof -
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3165
  let ?ba = "fps_binomial a"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3166
  let ?bb = "fps_binomial b"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3167
  let ?bab = "fps_binomial (a + b)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3168
  from fps_binomial_add_mult[of a b] have "?bab $ n = (?ba * ?bb)$n" by simp
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3169
  then show ?thesis by (simp add: fps_mult_nth)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3170
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3171
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3172
lemma binomial_Vandermonde:
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3173
  "setsum (\<lambda>k. (a choose k) * (b choose (n - k))) {0..n} = (a + b) choose n"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3174
  using gbinomial_Vandermonde[of "(of_nat a)" "of_nat b" n]
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3175
  apply (simp only: binomial_gbinomial[symmetric] of_nat_mult[symmetric]
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3176
    of_nat_setsum[symmetric] of_nat_add[symmetric])
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3177
  apply simp
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3178
  done
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3179
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  3180
lemma binomial_Vandermonde_same: "setsum (\<lambda>k. (n choose k)\<^sup>2) {0..n} = (2*n) choose n"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3181
  using binomial_Vandermonde[of n n n,symmetric]
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3182
  unfolding mult_2
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3183
  apply (simp add: power2_eq_square)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3184
  apply (rule setsum.cong)
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3185
  apply (auto intro:  binomial_symmetric)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3186
  done
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3187
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3188
lemma Vandermonde_pochhammer_lemma:
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3189
  fixes a :: "'a::field_char_0"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3190
  assumes b: "\<forall> j\<in>{0 ..<n}. b \<noteq> of_nat j"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3191
  shows "setsum (\<lambda>k. (pochhammer (- a) k * pochhammer (- (of_nat n)) k) /
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3192
      (of_nat (fact k) * pochhammer (b - of_nat n + 1) k)) {0..n} =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3193
    pochhammer (- (a + b)) n / pochhammer (- b) n"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3194
  (is "?l = ?r")
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3195
proof -
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3196
  let ?m1 = "\<lambda>m. (- 1 :: 'a) ^ m"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3197
  let ?f = "\<lambda>m. of_nat (fact m)"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3198
  let ?p = "\<lambda>(x::'a). pochhammer (- x)"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3199
  from b have bn0: "?p b n \<noteq> 0" unfolding pochhammer_eq_0_iff by simp
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3200
  {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3201
    fix k
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3202
    assume kn: "k \<in> {0..n}"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3203
    {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3204
      assume c:"pochhammer (b - of_nat n + 1) n = 0"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3205
      then obtain j where j: "j < n" "b - of_nat n + 1 = - of_nat j"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3206
        unfolding pochhammer_eq_0_iff by blast
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3207
      from j have "b = of_nat n - of_nat j - of_nat 1"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3208
        by (simp add: algebra_simps)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3209
      then have "b = of_nat (n - j - 1)"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3210
        using j kn by (simp add: of_nat_diff)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3211
      with b have False using j by auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3212
    }
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3213
    then have nz: "pochhammer (1 + b - of_nat n) n \<noteq> 0"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3214
      by (auto simp add: algebra_simps)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3215
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3216
    from nz kn [simplified] have nz': "pochhammer (1 + b - of_nat n) k \<noteq> 0"
35175
61255c81da01 fix more looping simp rules
huffman
parents: 32960
diff changeset
  3217
      by (rule pochhammer_neq_0_mono)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3218
    {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3219
      assume k0: "k = 0 \<or> n =0"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3220
      then have "b gchoose (n - k) =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3221
        (?m1 n * ?p b n * ?m1 k * ?p (of_nat n) k) / (?f n * pochhammer (b - of_nat n + 1) k)"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3222
        using kn
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3223
        by (cases "k = 0") (simp_all add: gbinomial_pochhammer)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3224
    }
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3225
    moreover
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3226
    {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3227
      assume n0: "n \<noteq> 0" and k0: "k \<noteq> 0"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3228
      then obtain m where m: "n = Suc m" by (cases n) auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3229
      from k0 obtain h where h: "k = Suc h" by (cases k) auto
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3230
      {
59862
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  3231
        assume "k = n"
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3232
        then have "b gchoose (n - k) =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3233
          (?m1 n * ?p b n * ?m1 k * ?p (of_nat n) k) / (?f n * pochhammer (b - of_nat n + 1) k)"
59862
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  3234
          using pochhammer_minus'[where k=k and b=b]
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  3235
          apply (simp add: pochhammer_same)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3236
          using bn0
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3237
          apply (simp add: field_simps power_add[symmetric])
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3238
          done
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3239
      }
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3240
      moreover
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3241
      {
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3242
        assume nk: "k \<noteq> n"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3243
        have m1nk: "?m1 n = setprod (\<lambda>i. - 1) {0..m}" "?m1 k = setprod (\<lambda>i. - 1) {0..h}"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3244
          by (simp_all add: setprod_constant m h)
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3245
        from kn nk have kn': "k < n" by simp
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3246
        have bnz0: "pochhammer (b - of_nat n + 1) k \<noteq> 0"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3247
          using bn0 kn
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3248
          unfolding pochhammer_eq_0_iff
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3249
          apply auto
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3250
          apply (erule_tac x= "n - ka - 1" in allE)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3251
          apply (auto simp add: algebra_simps of_nat_diff)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3252
          done
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3253
        have eq1: "setprod (\<lambda>k. (1::'a) + of_nat m - of_nat k) {0 .. h} =
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3254
          setprod of_nat {Suc (m - h) .. Suc m}"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3255
          using kn' h m
57129
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
  3256
          by (intro setprod.reindex_bij_witness[where i="\<lambda>k. Suc m - k" and j="\<lambda>k. Suc m - k"])
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
  3257
             (auto simp: of_nat_diff)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3258
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3259
        have th1: "(?m1 k * ?p (of_nat n) k) / ?f n = 1 / of_nat(fact (n - k))"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3260
          unfolding m1nk
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3261
          unfolding m h pochhammer_Suc_setprod
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  3262
          apply (simp add: field_simps del: fact_Suc)
59730
b7c394c7a619 The factorial function, "fact", now has type "nat => 'a"
paulson <lp15@cam.ac.uk>
parents: 59667
diff changeset
  3263
          unfolding fact_altdef id_def
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3264
          unfolding of_nat_setprod
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3265
          unfolding setprod.distrib[symmetric]
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3266
          apply auto
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3267
          unfolding eq1
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3268
          apply (subst setprod.union_disjoint[symmetric])
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3269
          apply (auto)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3270
          apply (rule setprod.cong)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3271
          apply auto
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3272
          done
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3273
        have th20: "?m1 n * ?p b n = setprod (\<lambda>i. b - of_nat i) {0..m}"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3274
          unfolding m1nk
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3275
          unfolding m h pochhammer_Suc_setprod
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3276
          unfolding setprod.distrib[symmetric]
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3277
          apply (rule setprod.cong)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3278
          apply auto
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3279
          done
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3280
        have th21:"pochhammer (b - of_nat n + 1) k = setprod (\<lambda>i. b - of_nat i) {n - k .. n - 1}"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3281
          unfolding h m
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3282
          unfolding pochhammer_Suc_setprod
57129
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
  3283
          using kn m h
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
  3284
          by (intro setprod.reindex_bij_witness[where i="\<lambda>k. n - 1 - k" and j="\<lambda>i. m-i"])
7edb7550663e introduce more powerful reindexing rules for big operators
hoelzl
parents: 56480
diff changeset
  3285
             (auto simp: of_nat_diff)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3286
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3287
        have "?m1 n * ?p b n =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3288
          pochhammer (b - of_nat n + 1) k * setprod (\<lambda>i. b - of_nat i) {0.. n - k - 1}"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3289
          unfolding th20 th21
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3290
          unfolding h m
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3291
          apply (subst setprod.union_disjoint[symmetric])
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3292
          using kn' h m
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3293
          apply auto
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3294
          apply (rule setprod.cong)
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3295
          apply auto
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3296
          done
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3297
        then have th2: "(?m1 n * ?p b n)/pochhammer (b - of_nat n + 1) k =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3298
          setprod (\<lambda>i. b - of_nat i) {0.. n - k - 1}"
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3299
          using nz' by (simp add: field_simps)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3300
        have "(?m1 n * ?p b n * ?m1 k * ?p (of_nat n) k) / (?f n * pochhammer (b - of_nat n + 1) k) =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3301
          ((?m1 k * ?p (of_nat n) k) / ?f n) * ((?m1 n * ?p b n)/pochhammer (b - of_nat n + 1) k)"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3302
          using bnz0
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3303
          by (simp add: field_simps)
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3304
        also have "\<dots> = b gchoose (n - k)"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3305
          unfolding th1 th2
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3306
          using kn' by (simp add: gbinomial_def)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3307
        finally have "b gchoose (n - k) =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3308
          (?m1 n * ?p b n * ?m1 k * ?p (of_nat n) k) / (?f n * pochhammer (b - of_nat n + 1) k)"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3309
          by simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3310
      }
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3311
      ultimately
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3312
      have "b gchoose (n - k) =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3313
        (?m1 n * ?p b n * ?m1 k * ?p (of_nat n) k) / (?f n * pochhammer (b - of_nat n + 1) k)"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3314
        by (cases "k = n") auto
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3315
    }
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3316
    ultimately have "b gchoose (n - k) =
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3317
        (?m1 n * ?p b n * ?m1 k * ?p (of_nat n) k) / (?f n * pochhammer (b - of_nat n + 1) k)"
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3318
      "pochhammer (1 + b - of_nat n) k \<noteq> 0 "
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3319
      apply (cases "n = 0")
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3320
      using nz'
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3321
      apply auto
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3322
      apply (cases k)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3323
      apply auto
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3324
      done
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3325
  }
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3326
  note th00 = this
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3327
  have "?r = ((a + b) gchoose n) * (of_nat (fact n)/ (?m1 n * pochhammer (- b) n))"
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3328
    unfolding gbinomial_pochhammer
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3329
    using bn0 by (auto simp add: field_simps)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3330
  also have "\<dots> = ?l"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3331
    unfolding gbinomial_Vandermonde[symmetric]
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3332
    apply (simp add: th00)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3333
    unfolding gbinomial_pochhammer
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3334
    using bn0
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3335
    apply (simp add: setsum_left_distrib setsum_right_distrib field_simps)
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3336
    apply (rule setsum.cong)
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3337
    apply (rule refl)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3338
    apply (drule th00(2))
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3339
    apply (simp add: field_simps power_add[symmetric])
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3340
    done
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3341
  finally show ?thesis by simp
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3342
qed
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3343
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3344
lemma Vandermonde_pochhammer:
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3345
  fixes a :: "'a::field_char_0"
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3346
  assumes c: "\<forall>i \<in> {0..< n}. c \<noteq> - of_nat i"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3347
  shows "setsum (\<lambda>k. (pochhammer a k * pochhammer (- (of_nat n)) k) /
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3348
    (of_nat (fact k) * pochhammer c k)) {0..n} = pochhammer (c - a) n / pochhammer c n"
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3349
proof -
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3350
  let ?a = "- a"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3351
  let ?b = "c + of_nat n - 1"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3352
  have h: "\<forall> j \<in>{0..< n}. ?b \<noteq> of_nat j" using c
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3353
    apply (auto simp add: algebra_simps of_nat_diff)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3354
    apply (erule_tac x= "n - j - 1" in ballE)
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3355
    apply (auto simp add: of_nat_diff algebra_simps)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3356
    done
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3357
  have th0: "pochhammer (- (?a + ?b)) n = (- 1)^n * pochhammer (c - a) n"
59862
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  3358
    unfolding pochhammer_minus
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3359
    by (simp add: algebra_simps)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3360
  have th1: "pochhammer (- ?b) n = (- 1)^n * pochhammer c n"
59862
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  3361
    unfolding pochhammer_minus
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3362
    by simp
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3363
  have nz: "pochhammer c n \<noteq> 0" using c
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3364
    by (simp add: pochhammer_eq_0_iff)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3365
  from Vandermonde_pochhammer_lemma[where a = "?a" and b="?b" and n=n, OF h, unfolded th0 th1]
36350
bc7982c54e37 dropped group_simps, ring_simps, field_eq_simps
haftmann
parents: 36311
diff changeset
  3366
  show ?thesis using nz by (simp add: field_simps setsum_right_distrib)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3367
qed
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3368
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3369
29906
80369da39838 section -> subsection
huffman
parents: 29692
diff changeset
  3370
subsubsection{* Formal trigonometric functions  *}
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3371
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3372
definition "fps_sin (c::'a::field_char_0) =
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3373
  Abs_fps (\<lambda>n. if even n then 0 else (- 1) ^((n - 1) div 2) * c^n /(of_nat (fact n)))"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3374
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3375
definition "fps_cos (c::'a::field_char_0) =
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3376
  Abs_fps (\<lambda>n. if even n then (- 1) ^ (n div 2) * c^n / (of_nat (fact n)) else 0)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3377
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  3378
lemma fps_sin_deriv:
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3379
  "fps_deriv (fps_sin c) = fps_const c * fps_cos c"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3380
  (is "?lhs = ?rhs")
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3381
proof (rule fps_ext)
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3382
  fix n :: nat
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3383
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3384
    assume en: "even n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3385
    have "?lhs$n = of_nat (n+1) * (fps_sin c $ (n+1))" by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3386
    also have "\<dots> = of_nat (n+1) * ((- 1)^(n div 2) * c^Suc n / of_nat (fact (Suc n)))"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3387
      using en by (simp add: fps_sin_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3388
    also have "\<dots> = (- 1)^(n div 2) * c^Suc n * (of_nat (n+1) / (of_nat (Suc n) * of_nat (fact n)))"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3389
      unfolding fact_Suc of_nat_mult
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3390
      by (simp add: field_simps del: of_nat_add of_nat_Suc)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3391
    also have "\<dots> = (- 1)^(n div 2) *c^Suc n / of_nat (fact n)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3392
      by (simp add: field_simps del: of_nat_add of_nat_Suc)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3393
    finally have "?lhs $n = ?rhs$n" using en
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3394
      by (simp add: fps_cos_def field_simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3395
  }
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3396
  then show "?lhs $ n = ?rhs $ n"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3397
    by (cases "even n") (simp_all add: fps_deriv_def fps_sin_def fps_cos_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3398
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3399
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3400
lemma fps_cos_deriv: "fps_deriv (fps_cos c) = fps_const (- c)* (fps_sin c)"
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3401
  (is "?lhs = ?rhs")
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3402
proof (rule fps_ext)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3403
  have th0: "\<And>n. - ((- 1::'a) ^ n) = (- 1)^Suc n" by simp
31273
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3404
  have th1: "\<And>n. odd n \<Longrightarrow> Suc ((n - 1) div 2) = Suc n div 2"
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3405
    by (case_tac n, simp_all)
da95bc889ad2 use class field_char_0 for fps definitions
huffman
parents: 31199
diff changeset
  3406
  fix n::nat
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3407
  {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3408
    assume en: "odd n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3409
    from en have n0: "n \<noteq>0 " by presburger
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3410
    have "?lhs$n = of_nat (n+1) * (fps_cos c $ (n+1))" by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3411
    also have "\<dots> = of_nat (n+1) * ((- 1)^((n + 1) div 2) * c^Suc n / of_nat (fact (Suc n)))"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3412
      using en by (simp add: fps_cos_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3413
    also have "\<dots> = (- 1)^((n + 1) div 2)*c^Suc n * (of_nat (n+1) / (of_nat (Suc n) * of_nat (fact n)))"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3414
      unfolding fact_Suc of_nat_mult
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3415
      by (simp add: field_simps del: of_nat_add of_nat_Suc)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3416
    also have "\<dots> = (- 1)^((n + 1) div 2) * c^Suc n / of_nat (fact n)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3417
      by (simp add: field_simps del: of_nat_add of_nat_Suc)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3418
    also have "\<dots> = (- ((- 1)^((n - 1) div 2))) * c^Suc n / of_nat (fact n)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3419
      unfolding th0 unfolding th1[OF en] by simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3420
    finally have "?lhs $n = ?rhs$n" using en
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3421
      by (simp add: fps_sin_def field_simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3422
  }
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3423
  then show "?lhs $ n = ?rhs $ n"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3424
    by (cases "even n") (simp_all add: fps_deriv_def fps_sin_def fps_cos_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3425
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3426
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3427
lemma fps_sin_cos_sum_of_squares:
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  3428
  "(fps_cos c)\<^sup>2 + (fps_sin c)\<^sup>2 = 1" (is "?lhs = 1")
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  3429
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3430
  have "fps_deriv ?lhs = 0"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3431
    apply (simp add:  fps_deriv_power fps_sin_deriv fps_cos_deriv)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3432
    apply (simp add: field_simps fps_const_neg[symmetric] del: fps_const_neg)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3433
    done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3434
  then have "?lhs = fps_const (?lhs $ 0)"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3435
    unfolding fps_deriv_eq_0_iff .
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3436
  also have "\<dots> = 1"
30960
fec1a04b7220 power operation defined generic
haftmann
parents: 30952
diff changeset
  3437
    by (auto simp add: fps_eq_iff numeral_2_eq_2 fps_mult_nth fps_cos_def fps_sin_def)
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3438
  finally show ?thesis .
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3439
qed
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3440
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3441
lemma divide_eq_iff: "a \<noteq> (0::'a::field) \<Longrightarrow> x / a = y \<longleftrightarrow> x = y * a"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3442
  by auto
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3443
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3444
lemma eq_divide_iff: "a \<noteq> (0::'a::field) \<Longrightarrow> x = y / a \<longleftrightarrow> x * a = y"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3445
  by auto
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3446
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3447
lemma fps_sin_nth_0 [simp]: "fps_sin c $ 0 = 0"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3448
  unfolding fps_sin_def by simp
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3449
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3450
lemma fps_sin_nth_1 [simp]: "fps_sin c $ 1 = c"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3451
  unfolding fps_sin_def by simp
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3452
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3453
lemma fps_sin_nth_add_2:
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3454
  "fps_sin c $ (n + 2) = - (c * c * fps_sin c $ n / (of_nat(n+1) * of_nat(n+2)))"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3455
  unfolding fps_sin_def
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3456
  apply (cases n, simp)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3457
  apply (simp add: divide_eq_iff eq_divide_iff del: of_nat_Suc fact_Suc)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3458
  apply (simp add: of_nat_mult del: of_nat_Suc mult_Suc)
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3459
  done
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3460
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3461
lemma fps_cos_nth_0 [simp]: "fps_cos c $ 0 = 1"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3462
  unfolding fps_cos_def by simp
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3463
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3464
lemma fps_cos_nth_1 [simp]: "fps_cos c $ 1 = 0"
53195
e4b18828a817 tuned proofs;
wenzelm
parents: 53077
diff changeset
  3465
  unfolding fps_cos_def by simp
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3466
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3467
lemma fps_cos_nth_add_2:
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3468
  "fps_cos c $ (n + 2) = - (c * c * fps_cos c $ n / (of_nat(n+1) * of_nat(n+2)))"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3469
  unfolding fps_cos_def
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3470
  apply (simp add: divide_eq_iff eq_divide_iff del: of_nat_Suc fact_Suc)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3471
  apply (simp add: of_nat_mult del: of_nat_Suc mult_Suc)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3472
  done
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3473
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3474
lemma nat_induct2: "P 0 \<Longrightarrow> P 1 \<Longrightarrow> (\<And>n. P n \<Longrightarrow> P (n + 2)) \<Longrightarrow> P (n::nat)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3475
  unfolding One_nat_def numeral_2_eq_2
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3476
  apply (induct n rule: nat_less_induct)
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3477
  apply (case_tac n)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3478
  apply simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3479
  apply (rename_tac m)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3480
  apply (case_tac m)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3481
  apply simp
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3482
  apply (rename_tac k)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3483
  apply (case_tac k)
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3484
  apply simp_all
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3485
  done
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3486
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3487
lemma nat_add_1_add_1: "(n::nat) + 1 + 1 = n + 2"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3488
  by simp
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3489
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3490
lemma eq_fps_sin:
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3491
  assumes 0: "a $ 0 = 0"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3492
    and 1: "a $ 1 = c"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3493
    and 2: "fps_deriv (fps_deriv a) = - (fps_const c * fps_const c * a)"
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3494
  shows "a = fps_sin c"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3495
  apply (rule fps_ext)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3496
  apply (induct_tac n rule: nat_induct2)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3497
  apply (simp add: 0)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3498
  apply (simp add: 1 del: One_nat_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3499
  apply (rename_tac m, cut_tac f="\<lambda>a. a $ m" in arg_cong [OF 2])
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3500
  apply (simp add: nat_add_1_add_1 fps_sin_nth_add_2
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3501
              del: One_nat_def of_nat_Suc of_nat_add add_2_eq_Suc')
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3502
  apply (subst minus_divide_left)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3503
  apply (subst eq_divide_iff)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3504
  apply (simp del: of_nat_add of_nat_Suc)
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
  3505
  apply (simp only: ac_simps)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3506
  done
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3507
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3508
lemma eq_fps_cos:
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3509
  assumes 0: "a $ 0 = 1"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3510
    and 1: "a $ 1 = 0"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3511
    and 2: "fps_deriv (fps_deriv a) = - (fps_const c * fps_const c * a)"
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3512
  shows "a = fps_cos c"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3513
  apply (rule fps_ext)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3514
  apply (induct_tac n rule: nat_induct2)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3515
  apply (simp add: 0)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3516
  apply (simp add: 1 del: One_nat_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3517
  apply (rename_tac m, cut_tac f="\<lambda>a. a $ m" in arg_cong [OF 2])
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3518
  apply (simp add: nat_add_1_add_1 fps_cos_nth_add_2
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3519
              del: One_nat_def of_nat_Suc of_nat_add add_2_eq_Suc')
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3520
  apply (subst minus_divide_left)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3521
  apply (subst eq_divide_iff)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3522
  apply (simp del: of_nat_add of_nat_Suc)
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
  3523
  apply (simp only: ac_simps)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3524
  done
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3525
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3526
lemma mult_nth_0 [simp]: "(a * b) $ 0 = a $ 0 * b $ 0"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3527
  by (simp add: fps_mult_nth)
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3528
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3529
lemma mult_nth_1 [simp]: "(a * b) $ 1 = a $ 0 * b $ 1 + a $ 1 * b $ 0"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3530
  by (simp add: fps_mult_nth)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3531
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3532
lemma fps_sin_add: "fps_sin (a + b) = fps_sin a * fps_cos b + fps_cos a * fps_sin b"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3533
  apply (rule eq_fps_sin [symmetric], simp, simp del: One_nat_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3534
  apply (simp del: fps_const_neg fps_const_add fps_const_mult
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3535
              add: fps_const_add [symmetric] fps_const_neg [symmetric]
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3536
                   fps_sin_deriv fps_cos_deriv algebra_simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3537
  done
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3538
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3539
lemma fps_cos_add: "fps_cos (a + b) = fps_cos a * fps_cos b - fps_sin a * fps_sin b"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3540
  apply (rule eq_fps_cos [symmetric], simp, simp del: One_nat_def)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3541
  apply (simp del: fps_const_neg fps_const_add fps_const_mult
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3542
              add: fps_const_add [symmetric] fps_const_neg [symmetric]
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3543
                   fps_sin_deriv fps_cos_deriv algebra_simps)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3544
  done
31274
d2b5c6b07988 addition formulas for fps_sin, fps_cos
huffman
parents: 31273
diff changeset
  3545
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
  3546
lemma fps_sin_even: "fps_sin (- c) = - fps_sin c"
56479
91958d4b30f7 revert c1bbd3e22226, a14831ac3023, and 36489d77c484: divide_minus_left/right are again simp rules
hoelzl
parents: 56410
diff changeset
  3547
  by (auto simp add: fps_eq_iff fps_sin_def)
31968
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
  3548
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
  3549
lemma fps_cos_odd: "fps_cos (- c) = fps_cos c"
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
  3550
  by (auto simp add: fps_eq_iff fps_cos_def)
0314441a53a6 FPS form a metric space, which justifies the infinte sum notation
chaieb
parents: 31790
diff changeset
  3551
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3552
definition "fps_tan c = fps_sin c / fps_cos c"
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3553
53077
a1b3784f8129 more symbols;
wenzelm
parents: 52903
diff changeset
  3554
lemma fps_tan_deriv: "fps_deriv (fps_tan c) = fps_const c / (fps_cos c)\<^sup>2"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3555
proof -
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3556
  have th0: "fps_cos c $ 0 \<noteq> 0" by (simp add: fps_cos_def)
30488
5c4c3a9e9102 remove trailing spaces
huffman
parents: 30273
diff changeset
  3557
  show ?thesis
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3558
    using fps_sin_cos_sum_of_squares[of c]
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3559
    apply (simp add: fps_tan_def fps_divide_deriv[OF th0] fps_sin_deriv fps_cos_deriv
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3560
      fps_const_neg[symmetric] field_simps power2_eq_square del: fps_const_neg)
49962
a8cc904a6820 Renamed {left,right}_distrib to distrib_{right,left}.
webertj
parents: 49834
diff changeset
  3561
    unfolding distrib_left[symmetric]
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3562
    apply simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3563
    done
29687
4d934a895d11 A formalization of formal power series
chaieb
parents:
diff changeset
  3564
qed
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
  3565
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3566
text {* Connection to E c over the complex numbers --- Euler and De Moivre*}
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3567
lemma Eii_sin_cos: "E (ii * c) = fps_cos c + fps_const ii * fps_sin c "
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3568
  (is "?l = ?r")
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3569
proof -
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3570
  { fix n :: nat
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3571
    {
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3572
      assume en: "even n"
58709
efdc6c533bd3 prefer generic elimination rules for even/odd over specialized unfold rules for nat
haftmann
parents: 58681
diff changeset
  3573
      from en obtain m where m: "n = 2 * m" ..
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3574
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3575
      have "?l $n = ?r$n"
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  3576
        by (simp add: m fps_sin_def fps_cos_def power_mult_distrib power_mult power_minus [of "c ^ 2"])
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3577
    }
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3578
    moreover
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3579
    {
58681
a478a0742a8e legacy cleanup
haftmann
parents: 57514
diff changeset
  3580
      assume "odd n"
a478a0742a8e legacy cleanup
haftmann
parents: 57514
diff changeset
  3581
      then obtain m where m: "n = 2 * m + 1" ..
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3582
      have "?l $n = ?r$n"
32960
69916a850301 eliminated hard tabulators, guessing at each author's individual tab-width;
wenzelm
parents: 32456
diff changeset
  3583
        by (simp add: m fps_sin_def fps_cos_def power_mult_distrib
54489
03ff4d1e6784 eliminiated neg_numeral in favour of - (numeral _)
haftmann
parents: 54452
diff changeset
  3584
          power_mult power_minus [of "c ^ 2"])
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3585
    }
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3586
    ultimately have "?l $n = ?r$n"  by blast
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3587
  } then show ?thesis by (simp add: fps_eq_iff)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3588
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3589
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3590
lemma E_minus_ii_sin_cos: "E (- (ii * c)) = fps_cos c - fps_const ii * fps_sin c"
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3591
  unfolding minus_mult_right Eii_sin_cos by (simp add: fps_sin_even fps_cos_odd)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3592
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3593
lemma fps_const_minus: "fps_const (c::'a::group_add) - fps_const d = fps_const (c - d)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3594
  by (simp add: fps_eq_iff fps_const_def)
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3595
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  3596
lemma fps_numeral_fps_const: "numeral i = fps_const (numeral i :: 'a::comm_ring_1)"
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
  3597
  by (fact numeral_fps_const) (* FIXME: duplicate *)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3598
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3599
lemma fps_cos_Eii: "fps_cos c = (E (ii * c) + E (- ii * c)) / fps_const 2"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3600
proof -
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3601
  have th: "fps_cos c + fps_cos c = fps_cos c * fps_const 2"
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
  3602
    by (simp add: numeral_fps_const)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3603
  show ?thesis
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3604
  unfolding Eii_sin_cos minus_mult_commute
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3605
  by (simp add: fps_sin_even fps_cos_odd numeral_fps_const fps_divide_def fps_const_inverse th)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3606
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3607
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3608
lemma fps_sin_Eii: "fps_sin c = (E (ii * c) - E (- ii * c)) / fps_const (2*ii)"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3609
proof -
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3610
  have th: "fps_const \<i> * fps_sin c + fps_const \<i> * fps_sin c = fps_sin c * fps_const (2 * ii)"
47108
2a1953f0d20d merged fork with new numeral representation (see NEWS)
huffman
parents: 46757
diff changeset
  3611
    by (simp add: fps_eq_iff numeral_fps_const)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3612
  show ?thesis
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3613
    unfolding Eii_sin_cos minus_mult_commute
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3614
    by (simp add: fps_sin_even fps_cos_odd fps_divide_def fps_const_inverse th)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3615
qed
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3616
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3617
lemma fps_tan_Eii:
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3618
  "fps_tan c = (E (ii * c) - E (- ii * c)) / (fps_const ii * (E (ii * c) + E (- ii * c)))"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3619
  unfolding fps_tan_def fps_sin_Eii fps_cos_Eii mult_minus_left E_neg
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3620
  apply (simp add: fps_divide_def fps_inverse_mult fps_const_mult[symmetric] fps_const_inverse del: fps_const_mult)
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3621
  apply simp
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3622
  done
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3623
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3624
lemma fps_demoivre: "(fps_cos a + fps_const ii * fps_sin a)^n = fps_cos (of_nat n * a) + fps_const ii * fps_sin (of_nat n * a)"
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3625
  unfolding Eii_sin_cos[symmetric] E_power_mult
57514
bdc2c6b40bf2 prefer ac_simps collections over separate name bindings for add and mult
haftmann
parents: 57512
diff changeset
  3626
  by (simp add: ac_simps)
32157
adea7a729c7a Moved important theorems from FPS_Examples to FPS --- they are not
chaieb
parents: 31968
diff changeset
  3627
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3628
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3629
subsection {* Hypergeometric series *}
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3630
59867
58043346ca64 given up separate type classes demanding `inverse 0 = 0`
haftmann
parents: 59862
diff changeset
  3631
definition "F as bs (c::'a::{field_char_0,field}) =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3632
  Abs_fps (\<lambda>n. (foldl (\<lambda>r a. r* pochhammer a n) 1 as * c^n) /
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3633
    (foldl (\<lambda>r b. r * pochhammer b n) 1 bs * of_nat (fact n)))"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3634
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3635
lemma F_nth[simp]: "F as bs c $ n =
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3636
  (foldl (\<lambda>r a. r* pochhammer a n) 1 as * c^n) /
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3637
    (foldl (\<lambda>r b. r * pochhammer b n) 1 bs * of_nat (fact n))"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3638
  by (simp add: F_def)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3639
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3640
lemma foldl_mult_start:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3641
  fixes v :: "'a::comm_ring_1"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3642
  shows "foldl (\<lambda>r x. r * f x) v as * x = foldl (\<lambda>r x. r * f x) (v * x) as "
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  3643
  by (induct as arbitrary: x v) (auto simp add: algebra_simps)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3644
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3645
lemma foldr_mult_foldl:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3646
  fixes v :: "'a::comm_ring_1"
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3647
  shows "foldr (\<lambda>x r. r * f x) as v = foldl (\<lambda>r x. r * f x) v as"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  3648
  by (induct as arbitrary: v) (auto simp add: foldl_mult_start)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3649
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3650
lemma F_nth_alt:
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3651
  "F as bs c $ n = foldr (\<lambda>a r. r * pochhammer a n) as (c ^ n) /
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3652
    foldr (\<lambda>b r. r * pochhammer b n) bs (of_nat (fact n))"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3653
  by (simp add: foldl_mult_start foldr_mult_foldl)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3654
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3655
lemma F_E[simp]: "F [] [] c = E c"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3656
  by (simp add: fps_eq_iff)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3657
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3658
lemma F_1_0[simp]: "F [1] [] c = 1/(1 - fps_const c * X)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3659
proof -
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3660
  let ?a = "(Abs_fps (\<lambda>n. 1)) oo (fps_const c * X)"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3661
  have th0: "(fps_const c * X) $ 0 = 0" by simp
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3662
  show ?thesis unfolding gp[OF th0, symmetric]
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3663
    by (auto simp add: fps_eq_iff pochhammer_fact[symmetric]
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3664
      fps_compose_nth power_mult_distrib cond_value_iff setsum.delta' cong del: if_weak_cong)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3665
qed
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3666
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3667
lemma F_B[simp]: "F [-a] [] (- 1) = fps_binomial a"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3668
  by (simp add: fps_eq_iff gbinomial_pochhammer algebra_simps)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3669
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3670
lemma F_0[simp]: "F as bs c $0 = 1"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3671
  apply simp
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3672
  apply (subgoal_tac "\<forall>as. foldl (\<lambda>(r::'a) (a::'a). r) 1 as = 1")
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3673
  apply auto
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  3674
  apply (induct_tac as)
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  3675
  apply auto
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3676
  done
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3677
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3678
lemma foldl_prod_prod:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3679
  "foldl (\<lambda>(r::'b::comm_ring_1) (x::'a::comm_ring_1). r * f x) v as * foldl (\<lambda>r x. r * g x) w as =
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3680
    foldl (\<lambda>r x. r * f x * g x) (v * w) as"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  3681
  by (induct as arbitrary: v w) (auto simp add: algebra_simps)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3682
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3683
53196
942a1b48bb31 tuned proofs;
wenzelm
parents: 53195
diff changeset
  3684
lemma F_rec:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3685
  "F as bs c $ Suc n = ((foldl (\<lambda>r a. r* (a + of_nat n)) c as) /
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3686
    (foldl (\<lambda>r b. r * (b + of_nat n)) (of_nat (Suc n)) bs )) * F as bs c $ n"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3687
  apply (simp del: of_nat_Suc of_nat_add fact_Suc)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3688
  apply (simp add: foldl_mult_start del: fact_Suc of_nat_Suc)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3689
  unfolding foldl_prod_prod[unfolded foldl_mult_start] pochhammer_Suc
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3690
  apply (simp add: algebra_simps of_nat_mult)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3691
  done
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3692
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3693
lemma XD_nth[simp]: "XD a $ n = (if n = 0 then 0 else of_nat n * a$n)"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3694
  by (simp add: XD_def)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3695
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3696
lemma XD_0th[simp]: "XD a $ 0 = 0" by simp
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3697
lemma XD_Suc[simp]:" XD a $ Suc n = of_nat (Suc n) * a $ Suc n" by simp
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3698
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3699
definition "XDp c a = XD a + fps_const c * a"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3700
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3701
lemma XDp_nth[simp]: "XDp c a $ n = (c + of_nat n) * a$n"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3702
  by (simp add: XDp_def algebra_simps)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3703
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  3704
lemma XDp_commute: "XDp b \<circ> XDp (c::'a::comm_ring_1) = XDp c \<circ> XDp b"
39302
d7728f65b353 renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents: 39198
diff changeset
  3705
  by (auto simp add: XDp_def fun_eq_iff fps_eq_iff algebra_simps)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3706
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3707
lemma XDp0 [simp]: "XDp 0 = XD"
39302
d7728f65b353 renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents: 39198
diff changeset
  3708
  by (simp add: fun_eq_iff fps_eq_iff)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3709
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3710
lemma XDp_fps_integral [simp]: "XDp 0 (fps_integral a c) = X * a"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3711
  by (simp add: fps_eq_iff fps_integral_def)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3712
52891
b8dede3a4f1d tuned proofs;
wenzelm
parents: 51542
diff changeset
  3713
lemma F_minus_nat:
59867
58043346ca64 given up separate type classes demanding `inverse 0 = 0`
haftmann
parents: 59862
diff changeset
  3714
  "F [- of_nat n] [- of_nat (n + m)] (c::'a::{field_char_0,field}) $ k =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3715
    (if k \<le> n then
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3716
      pochhammer (- of_nat n) k * c ^ k / (pochhammer (- of_nat (n + m)) k * of_nat (fact k))
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3717
     else 0)"
59867
58043346ca64 given up separate type classes demanding `inverse 0 = 0`
haftmann
parents: 59862
diff changeset
  3718
  "F [- of_nat m] [- of_nat (m + n)] (c::'a::{field_char_0,field}) $ k =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3719
    (if k \<le> m then
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3720
      pochhammer (- of_nat m) k * c ^ k / (pochhammer (- of_nat (m + n)) k * of_nat (fact k))
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3721
     else 0)"
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3722
  by (auto simp add: pochhammer_eq_0_iff)
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3723
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3724
lemma setsum_eq_if: "setsum f {(n::nat) .. m} = (if m < n then 0 else f n + setsum f {n+1 .. m})"
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3725
  apply simp
57418
6ab1c7cb0b8d fact consolidation
haftmann
parents: 57129
diff changeset
  3726
  apply (subst setsum.insert[symmetric])
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3727
  apply (auto simp add: not_less setsum_head_Suc)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3728
  done
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3729
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3730
lemma pochhammer_rec_if: "pochhammer a n = (if n = 0 then 1 else a * pochhammer (a + 1) (n - 1))"
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3731
  by (cases n) (simp_all add: pochhammer_rec)
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3732
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  3733
lemma XDp_foldr_nth [simp]: "foldr (\<lambda>c r. XDp c \<circ> r) cs (\<lambda>c. XDp c a) c0 $ n =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3734
    foldr (\<lambda>c r. (c + of_nat n) * r) cs (c0 + of_nat n) * a$n"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  3735
  by (induct cs arbitrary: c0) (auto simp add: algebra_simps)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3736
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3737
lemma genric_XDp_foldr_nth:
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3738
  assumes f: "\<forall>n c a. f c a $ n = (of_nat n + k c) * a$n"
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  3739
  shows "foldr (\<lambda>c r. f c \<circ> r) cs (\<lambda>c. g c a) c0 $ n =
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3740
    foldr (\<lambda>c r. (k c + of_nat n) * r) cs (g c0 a $ n)"
48757
1232760e208e tuned proofs;
wenzelm
parents: 47217
diff changeset
  3741
  by (induct cs arbitrary: c0) (auto simp add: algebra_simps f)
32160
63686057cbe8 Vandermonde vs Pochhammer; Hypergeometric series - very basic facts
chaieb
parents: 32157
diff changeset
  3742
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3743
lemma dist_less_imp_nth_equal:
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3744
  assumes "dist f g < inverse (2 ^ i)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3745
    and"j \<le> i"
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3746
  shows "f $ j = g $ j"
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3747
proof (rule ccontr)
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3748
  assume "f $ j \<noteq> g $ j"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3749
  then have "\<exists>n. f $ n \<noteq> g $ n" by auto
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3750
  with assms have "i < (LEAST n. f $ n \<noteq> g $ n)"
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3751
    by (simp add: split_if_asm dist_fps_def)
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3752
  also have "\<dots> \<le> j"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3753
    using `f $ j \<noteq> g $ j` by (auto intro: Least_le)
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3754
  finally show False using `j \<le> i` by simp
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3755
qed
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3756
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3757
lemma nth_equal_imp_dist_less:
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3758
  assumes "\<And>j. j \<le> i \<Longrightarrow> f $ j = g $ j"
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3759
  shows "dist f g < inverse (2 ^ i)"
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3760
proof (cases "f = g")
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3761
  case False
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3762
  then have "\<exists>n. f $ n \<noteq> g $ n" by (simp add: fps_eq_iff)
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3763
  with assms have "dist f g = inverse (2 ^ (LEAST n. f $ n \<noteq> g $ n))"
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3764
    by (simp add: split_if_asm dist_fps_def)
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3765
  moreover
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3766
  from assms `\<exists>n. f $ n \<noteq> g $ n` have "i < (LEAST n. f $ n \<noteq> g $ n)"
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3767
    by (metis (mono_tags) LeastI not_less)
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3768
  ultimately show ?thesis by simp
54263
c4159fe6fa46 move Lubs from HOL to HOL-Library (replaced by conditionally complete lattices)
hoelzl
parents: 54230
diff changeset
  3769
qed simp
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3770
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3771
lemma dist_less_eq_nth_equal: "dist f g < inverse (2 ^ i) \<longleftrightarrow> (\<forall>j \<le> i. f $ j = g $ j)"
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3772
  using dist_less_imp_nth_equal nth_equal_imp_dist_less by blast
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3773
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3774
instance fps :: (comm_ring_1) complete_space
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3775
proof
54681
8a8e6db7f391 tuned proofs;
wenzelm
parents: 54489
diff changeset
  3776
  fix X :: "nat \<Rightarrow> 'a fps"
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3777
  assume "Cauchy X"
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3778
  {
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3779
    fix i
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3780
    have "0 < inverse ((2::real)^i)" by simp
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3781
    from metric_CauchyD[OF `Cauchy X` this] dist_less_imp_nth_equal
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3782
    have "\<exists>M. \<forall>m \<ge> M. \<forall>j\<le>i. X M $ j = X m $ j" by blast
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3783
  }
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3784
  then obtain M where M: "\<forall>i. \<forall>m \<ge> M i. \<forall>j \<le> i. X (M i) $ j = X m $ j" by metis
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3785
  then have "\<forall>i. \<forall>m \<ge> M i. \<forall>j \<le> i. X (M i) $ j = X m $ j" by metis
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3786
  show "convergent X"
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3787
  proof (rule convergentI)
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3788
    show "X ----> Abs_fps (\<lambda>i. X (M i) $ i)"
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3789
      unfolding tendsto_iff
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3790
    proof safe
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3791
      fix e::real assume "0 < e"
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3792
      with LIMSEQ_inverse_realpow_zero[of 2, simplified, simplified filterlim_iff,
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3793
        THEN spec, of "\<lambda>x. x < e"]
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3794
      have "eventually (\<lambda>i. inverse (2 ^ i) < e) sequentially"
59862
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  3795
        unfolding eventually_nhds
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3796
        apply safe
59862
44b3f4fa33ca New material and binomial fix
paulson <lp15@cam.ac.uk>
parents: 59815
diff changeset
  3797
        apply auto --{*slow*}
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3798
        done
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3799
      then obtain i where "inverse (2 ^ i) < e" by (auto simp: eventually_sequentially)
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3800
      have "eventually (\<lambda>x. M i \<le> x) sequentially" by (auto simp: eventually_sequentially)
54452
f3090621446e tuned proofs;
wenzelm
parents: 54263
diff changeset
  3801
      then show "eventually (\<lambda>x. dist (X x) (Abs_fps (\<lambda>i. X (M i) $ i)) < e) sequentially"
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3802
      proof eventually_elim
52902
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3803
        fix x
7196e1ce1cd8 tuned proofs;
wenzelm
parents: 52891
diff changeset
  3804
        assume "M i \<le> x"
51107
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3805
        moreover
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3806
        have "\<And>j. j \<le> i \<Longrightarrow> X (M i) $ j = X (M j) $ j"
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3807
          using M by (metis nat_le_linear)
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3808
        ultimately have "dist (X x) (Abs_fps (\<lambda>j. X (M j) $ j)) < inverse (2 ^ i)"
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3809
          using M by (force simp: dist_less_eq_nth_equal)
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3810
        also note `inverse (2 ^ i) < e`
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3811
        finally show "dist (X x) (Abs_fps (\<lambda>j. X (M j) $ j)) < e" .
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3812
      qed
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3813
    qed
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3814
  qed
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3815
qed
3f9dbd2cc475 complete metric for formal power series
immler
parents: 49962
diff changeset
  3816
29911
c790a70a3d19 declare fps_nth as a typedef morphism; clean up instance proofs
huffman
parents: 29906
diff changeset
  3817
end