src/HOL/Nonstandard_Analysis/HDeriv.thy
author wenzelm
Tue, 11 May 2021 20:19:07 +0200
changeset 73675 6c56f2ebe157
parent 70723 4e39d87c9737
child 80914 d97fdabd9e2b
permissions -rw-r--r--
guess package more directly;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
62479
716336f19aa9 clarified session;
wenzelm
parents: 61982
diff changeset
     1
(*  Title:      HOL/Nonstandard_Analysis/HDeriv.thy
716336f19aa9 clarified session;
wenzelm
parents: 61982
diff changeset
     2
    Author:     Jacques D. Fleuriot
716336f19aa9 clarified session;
wenzelm
parents: 61982
diff changeset
     3
    Copyright:  1998  University of Cambridge
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
     4
    Conversion to Isar and new proofs by Lawrence C Paulson, 2004
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
     5
*)
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
     6
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
     7
section \<open>Differentiation (Nonstandard)\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
     8
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
     9
theory HDeriv
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    10
  imports HLim
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    11
begin
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    12
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    13
text \<open>Nonstandard Definitions.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    14
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    15
definition nsderiv :: "['a::real_normed_field \<Rightarrow> 'a, 'a, 'a] \<Rightarrow> bool"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    16
    ("(NSDERIV (_)/ (_)/ :> (_))" [1000, 1000, 60] 60)
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    17
  where "NSDERIV f x :> D \<longleftrightarrow>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    18
    (\<forall>h \<in> Infinitesimal - {0}. (( *f* f)(star_of x + h) - star_of (f x)) / h \<approx> star_of D)"
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    19
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    20
definition NSdifferentiable :: "['a::real_normed_field \<Rightarrow> 'a, 'a] \<Rightarrow> bool"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    21
    (infixl "NSdifferentiable" 60)
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    22
  where "f NSdifferentiable x \<longleftrightarrow> (\<exists>D. NSDERIV f x :> D)"
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    23
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    24
definition increment :: "(real \<Rightarrow> real) \<Rightarrow> real \<Rightarrow> hypreal \<Rightarrow> hypreal"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    25
  where "increment f x h =
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    26
    (SOME inc. f NSdifferentiable x \<and> inc = ( *f* f) (hypreal_of_real x + h) - hypreal_of_real (f x))"
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    27
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    28
61975
b4b11391c676 isabelle update_cartouches -c -t;
wenzelm
parents: 61971
diff changeset
    29
subsection \<open>Derivatives\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    30
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    31
lemma DERIV_NS_iff: "(DERIV f x :> D) \<longleftrightarrow> (\<lambda>h. (f (x + h) - f x) / h) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S D"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    32
  by (simp add: DERIV_def LIM_NSLIM_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    33
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    34
lemma NS_DERIV_D: "DERIV f x :> D \<Longrightarrow> (\<lambda>h. (f (x + h) - f x) / h) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S D"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    35
  by (simp add: DERIV_def LIM_NSLIM_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    36
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    37
lemma Infinitesimal_of_hypreal:
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    38
  "x \<in> Infinitesimal \<Longrightarrow> (( *f* of_real) x::'a::real_normed_div_algebra star) \<in> Infinitesimal"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    39
  by (metis Infinitesimal_of_hypreal_iff of_hypreal_def)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    40
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    41
lemma of_hypreal_eq_0_iff: "\<And>x. (( *f* of_real) x = (0::'a::real_algebra_1 star)) = (x = 0)"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    42
  by transfer (rule of_real_eq_0_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    43
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    44
lemma NSDeriv_unique:
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    45
  assumes "NSDERIV f x :> D" "NSDERIV f x :> E"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    46
  shows "NSDERIV f x :> D \<Longrightarrow> NSDERIV f x :> E \<Longrightarrow> D = E"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    47
proof -
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    48
  have "\<exists>s. (s::'a star) \<in> Infinitesimal - {0}"
70723
4e39d87c9737 imported new material mostly due to Sébastien Gouëzel
paulson <lp15@cam.ac.uk>
parents: 70217
diff changeset
    49
    by (metis Diff_iff HDeriv.of_hypreal_eq_0_iff Infinitesimal_epsilon Infinitesimal_of_hypreal epsilon_not_zero singletonD)
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    50
  with assms show ?thesis
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    51
    by (meson approx_trans3 nsderiv_def star_of_approx_iff)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    52
qed
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    53
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    54
text \<open>First \<open>NSDERIV\<close> in terms of \<open>NSLIM\<close>.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    55
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    56
text \<open>First equivalence.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    57
lemma NSDERIV_NSLIM_iff: "(NSDERIV f x :> D) \<longleftrightarrow> (\<lambda>h. (f (x + h) - f x) / h) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S D"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    58
  by (auto simp add: nsderiv_def NSLIM_def starfun_lambda_cancel mem_infmal_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    59
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    60
text \<open>Second equivalence.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    61
lemma NSDERIV_NSLIM_iff2: "(NSDERIV f x :> D) \<longleftrightarrow> (\<lambda>z. (f z - f x) / (z - x)) \<midarrow>x\<rightarrow>\<^sub>N\<^sub>S D"
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53755
diff changeset
    62
  by (simp add: NSDERIV_NSLIM_iff DERIV_LIM_iff LIM_NSLIM_iff [symmetric])
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    63
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    64
text \<open>While we're at it!\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    65
lemma NSDERIV_iff2:
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    66
  "(NSDERIV f x :> D) \<longleftrightarrow>
64604
2bf8cfc98c4d misc tuning and modernization;
wenzelm
parents: 64435
diff changeset
    67
    (\<forall>w. w \<noteq> star_of x \<and> w \<approx> star_of x \<longrightarrow> ( *f* (\<lambda>z. (f z - f x) / (z - x))) w \<approx> star_of D)"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    68
  by (simp add: NSDERIV_NSLIM_iff2 NSLIM_def)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    69
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    70
lemma NSDERIVD5:
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    71
  "\<lbrakk>NSDERIV f x :> D; u \<approx> hypreal_of_real x\<rbrakk> \<Longrightarrow>
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    72
     ( *f* (\<lambda>z. f z - f x)) u \<approx> hypreal_of_real D * (u - hypreal_of_real x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    73
  unfolding NSDERIV_iff2
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    74
  apply (case_tac "u = hypreal_of_real x", auto)
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    75
  by (metis (mono_tags, lifting) HFinite_star_of Infinitesimal_ratio approx_def approx_minus_iff approx_mult_subst approx_star_of_HFinite approx_sym mult_zero_right right_minus_eq)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    76
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    77
lemma NSDERIVD4:
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    78
  "\<lbrakk>NSDERIV f x :> D; h \<in> Infinitesimal\<rbrakk>
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    79
    \<Longrightarrow> ( *f* f)(hypreal_of_real x + h) - hypreal_of_real (f x) \<approx> hypreal_of_real D * h"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    80
  apply (clarsimp simp add: nsderiv_def)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    81
  apply (case_tac "h = 0", simp)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    82
  by (meson DiffI Infinitesimal_approx Infinitesimal_ratio Infinitesimal_star_of_mult2 approx_star_of_HFinite singletonD)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
    83
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
    84
text \<open>Differentiability implies continuity nice and simple "algebraic" proof.\<close>
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    85
lemma NSDERIV_isNSCont: 
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    86
  assumes "NSDERIV f x :> D" shows "isNSCont f x"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    87
  unfolding isNSCont_NSLIM_iff NSLIM_def
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    88
proof clarify
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    89
  fix x'
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    90
  assume "x' \<noteq> star_of x" "x' \<approx> star_of x"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    91
  then have m0: "x' - star_of x \<in> Infinitesimal - {0}"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    92
    using bex_Infinitesimal_iff by auto
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    93
  then have "(( *f* f) x' - star_of (f x)) / (x' - star_of x) \<approx> star_of D"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    94
    by (metis \<open>x' \<approx> star_of x\<close> add_diff_cancel_left' assms bex_Infinitesimal_iff2 nsderiv_def)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    95
  then have "(( *f* f) x' - star_of (f x)) / (x' - star_of x) \<in> HFinite"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    96
    by (metis approx_star_of_HFinite)  
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    97
  then show "( *f* f) x' \<approx> star_of (f x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    98
    by (metis (no_types) Diff_iff Infinitesimal_ratio m0 bex_Infinitesimal_iff insert_iff)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
    99
qed
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   100
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   101
text \<open>Differentiation rules for combinations of functions
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   102
  follow from clear, straightforward, algebraic manipulations.\<close>
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   103
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   104
text \<open>Constant function.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   105
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   106
(* use simple constant nslimit theorem *)
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   107
lemma NSDERIV_const [simp]: "NSDERIV (\<lambda>x. k) x :> 0"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   108
  by (simp add: NSDERIV_NSLIM_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   109
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   110
text \<open>Sum of functions- proved easily.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   111
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   112
lemma NSDERIV_add:
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   113
  assumes "NSDERIV f x :> Da" "NSDERIV g x :> Db"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   114
  shows "NSDERIV (\<lambda>x. f x + g x) x :> Da + Db"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   115
proof -
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   116
  have "((\<lambda>x. f x + g x) has_field_derivative Da + Db) (at x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   117
    using assms DERIV_NS_iff NSDERIV_NSLIM_iff field_differentiable_add by blast
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   118
  then show ?thesis
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   119
    by (simp add: DERIV_NS_iff NSDERIV_NSLIM_iff)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   120
qed
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   121
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   122
text \<open>Product of functions - Proof is simple.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   123
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   124
lemma NSDERIV_mult:
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   125
  assumes "NSDERIV g x :> Db" "NSDERIV f x :> Da"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   126
  shows "NSDERIV (\<lambda>x. f x * g x) x :> (Da * g x) + (Db * f x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   127
proof -
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   128
  have "(f has_field_derivative Da) (at x)" "(g has_field_derivative Db) (at x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   129
    using assms by (simp_all add: DERIV_NS_iff NSDERIV_NSLIM_iff)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   130
  then have "((\<lambda>a. f a * g a) has_field_derivative Da * g x + Db * f x) (at x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   131
    using DERIV_mult by blast
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   132
  then show ?thesis
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   133
    by (simp add: DERIV_NS_iff NSDERIV_NSLIM_iff)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   134
qed
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   135
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   136
text \<open>Multiplying by a constant.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   137
lemma NSDERIV_cmult: "NSDERIV f x :> D \<Longrightarrow> NSDERIV (\<lambda>x. c * f x) x :> c * D"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   138
  unfolding times_divide_eq_right [symmetric] NSDERIV_NSLIM_iff
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   139
      minus_mult_right right_diff_distrib [symmetric]
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   140
  by (erule NSLIM_const [THEN NSLIM_mult])
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   141
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   142
text \<open>Negation of function.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   143
lemma NSDERIV_minus: "NSDERIV f x :> D \<Longrightarrow> NSDERIV (\<lambda>x. - f x) x :> - D"
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   144
proof (simp add: NSDERIV_NSLIM_iff)
61971
720fa884656e more symbols;
wenzelm
parents: 59867
diff changeset
   145
  assume "(\<lambda>h. (f (x + h) - f x) / h) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S D"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   146
  then have deriv: "(\<lambda>h. - ((f(x+h) - f x) / h)) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S - D"
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   147
    by (rule NSLIM_minus)
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   148
  have "\<forall>h. - ((f (x + h) - f x) / h) = (- f (x + h) + f x) / h"
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53755
diff changeset
   149
    by (simp add: minus_divide_left)
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   150
  with deriv have "(\<lambda>h. (- f (x + h) + f x) / h) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S - D"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   151
    by simp
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   152
  then show "(\<lambda>h. (f (x + h) - f x) / h) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S D \<Longrightarrow> (\<lambda>h. (f x - f (x + h)) / h) \<midarrow>0\<rightarrow>\<^sub>N\<^sub>S - D"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   153
    by simp
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   154
qed
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   155
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   156
text \<open>Subtraction.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   157
lemma NSDERIV_add_minus:
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   158
  "NSDERIV f x :> Da \<Longrightarrow> NSDERIV g x :> Db \<Longrightarrow> NSDERIV (\<lambda>x. f x + - g x) x :> Da + - Db"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   159
  by (blast dest: NSDERIV_add NSDERIV_minus)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   160
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   161
lemma NSDERIV_diff:
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   162
  "NSDERIV f x :> Da \<Longrightarrow> NSDERIV g x :> Db \<Longrightarrow> NSDERIV (\<lambda>x. f x - g x) x :> Da - Db"
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53755
diff changeset
   163
  using NSDERIV_add_minus [of f x Da g Db] by simp
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   164
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   165
text \<open>Similarly to the above, the chain rule admits an entirely
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   166
  straightforward derivation. Compare this with Harrison's
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   167
  HOL proof of the chain rule, which proved to be trickier and
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   168
  required an alternative characterisation of differentiability-
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   169
  the so-called Carathedory derivative. Our main problem is
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   170
  manipulation of terms.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   171
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   172
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   173
subsection \<open>Lemmas\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   174
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   175
lemma NSDERIV_zero:
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   176
  "\<lbrakk>NSDERIV g x :> D; ( *f* g) (star_of x + y) = star_of (g x); y \<in> Infinitesimal; y \<noteq> 0\<rbrakk>
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   177
    \<Longrightarrow> D = 0"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   178
  by (force simp add: nsderiv_def)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   179
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   180
text \<open>Can be proved differently using \<open>NSLIM_isCont_iff\<close>.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   181
lemma NSDERIV_approx:
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   182
  "NSDERIV f x :> D \<Longrightarrow> h \<in> Infinitesimal \<Longrightarrow> h \<noteq> 0 \<Longrightarrow>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   183
    ( *f* f) (star_of x + h) - star_of (f x) \<approx> 0"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   184
  by (meson DiffI Infinitesimal_ratio approx_star_of_HFinite mem_infmal_iff nsderiv_def singletonD)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   185
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   186
text \<open>From one version of differentiability
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   187
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   188
        \<open>f x - f a\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   189
      \<open>-------------- \<approx> Db\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   190
          \<open>x - a\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   191
\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   192
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   193
lemma NSDERIVD1: 
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   194
    "\<lbrakk>NSDERIV f (g x) :> Da;
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   195
     ( *f* g) (star_of x + y) \<noteq> star_of (g x);
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   196
     ( *f* g) (star_of x + y) \<approx> star_of (g x)\<rbrakk>
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   197
    \<Longrightarrow> (( *f* f) (( *f* g) (star_of x + y)) -
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   198
         star_of (f (g x))) / (( *f* g) (star_of x + y) - star_of (g x)) \<approx>
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   199
        star_of Da"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   200
  by (auto simp add: NSDERIV_NSLIM_iff2 NSLIM_def)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   201
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   202
text \<open>From other version of differentiability
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   203
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   204
      \<open>f (x + h) - f x\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   205
     \<open>------------------ \<approx> Db\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   206
             \<open>h\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   207
\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   208
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   209
lemma NSDERIVD2: "[| NSDERIV g x :> Db; y \<in> Infinitesimal; y \<noteq> 0 |]
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   210
      ==> (( *f* g) (star_of(x) + y) - star_of(g x)) / y
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   211
          \<approx> star_of(Db)"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   212
  by (auto simp add: NSDERIV_NSLIM_iff NSLIM_def mem_infmal_iff starfun_lambda_cancel)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   213
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   214
text \<open>This proof uses both definitions of differentiability.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   215
lemma NSDERIV_chain:
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   216
  "NSDERIV f (g x) :> Da \<Longrightarrow> NSDERIV g x :> Db \<Longrightarrow> NSDERIV (f \<circ> g) x :> Da * Db"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   217
  using DERIV_NS_iff DERIV_chain NSDERIV_NSLIM_iff by blast
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   218
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   219
text \<open>Differentiation of natural number powers.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   220
lemma NSDERIV_Id [simp]: "NSDERIV (\<lambda>x. x) x :> 1"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   221
  by (simp add: NSDERIV_NSLIM_iff NSLIM_def del: divide_self_if)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   222
69064
5840724b1d71 Prefix form of infix with * on either side no longer needs special treatment
nipkow
parents: 68644
diff changeset
   223
lemma NSDERIV_cmult_Id [simp]: "NSDERIV ((*) c) x :> c"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   224
  using NSDERIV_Id [THEN NSDERIV_cmult] by simp
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   225
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   226
lemma NSDERIV_inverse:
53755
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   227
  fixes x :: "'a::real_normed_field"
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 69064
diff changeset
   228
  assumes "x \<noteq> 0" \<comment> \<open>can't get rid of \<^term>\<open>x \<noteq> 0\<close> because it isn't continuous at zero\<close>
53755
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   229
  shows "NSDERIV (\<lambda>x. inverse x) x :> - (inverse x ^ Suc (Suc 0))"
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   230
proof -
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   231
  {
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   232
    fix h :: "'a star"
53755
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   233
    assume h_Inf: "h \<in> Infinitesimal"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   234
    from this assms have not_0: "star_of x + h \<noteq> 0"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   235
      by (rule Infinitesimal_add_not_zero)
53755
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   236
    assume "h \<noteq> 0"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   237
    from h_Inf have "h * star_of x \<in> Infinitesimal"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   238
      by (rule Infinitesimal_HFinite_mult) simp
53755
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   239
    with assms have "inverse (- (h * star_of x) + - (star_of x * star_of x)) \<approx>
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   240
      inverse (- (star_of x * star_of x))"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   241
    proof -
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   242
      have "- (h * star_of x) + - (star_of x * star_of x) \<approx> - (star_of x * star_of x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   243
        using \<open>h * star_of x \<in> Infinitesimal\<close> assms bex_Infinitesimal_iff by fastforce
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   244
      then show ?thesis
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   245
        by (metis assms mult_eq_0_iff neg_equal_0_iff_equal star_of_approx_inverse star_of_minus star_of_mult)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   246
    qed
61975
b4b11391c676 isabelle update_cartouches -c -t;
wenzelm
parents: 61971
diff changeset
   247
    moreover from not_0 \<open>h \<noteq> 0\<close> assms
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   248
    have "inverse (- (h * star_of x) + - (star_of x * star_of x)) 
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   249
          = (inverse (star_of x + h) - inverse (star_of x)) / h"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   250
      by (simp add: division_ring_inverse_diff inverse_mult_distrib [symmetric]
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   251
          inverse_minus_eq [symmetric] algebra_simps)
54230
b1d955791529 more simplification rules on unary and binary minus
haftmann
parents: 53755
diff changeset
   252
    ultimately have "(inverse (star_of x + h) - inverse (star_of x)) / h \<approx>
53755
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   253
      - (inverse (star_of x) * inverse (star_of x))"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   254
      using assms by simp
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   255
  }
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   256
  then show ?thesis by (simp add: nsderiv_def)
53755
b8e62805566b tuned proofs
haftmann
parents: 51525
diff changeset
   257
qed
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   258
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   259
61975
b4b11391c676 isabelle update_cartouches -c -t;
wenzelm
parents: 61971
diff changeset
   260
subsubsection \<open>Equivalence of NS and Standard definitions\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   261
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   262
lemma divideR_eq_divide: "x /\<^sub>R y = x / y"
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   263
  by (simp add: divide_inverse mult.commute)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   264
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   265
text \<open>Now equivalence between \<open>NSDERIV\<close> and \<open>DERIV\<close>.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   266
lemma NSDERIV_DERIV_iff: "NSDERIV f x :> D \<longleftrightarrow> DERIV f x :> D"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   267
  by (simp add: DERIV_def NSDERIV_NSLIM_iff LIM_NSLIM_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   268
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   269
text \<open>NS version.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   270
lemma NSDERIV_pow: "NSDERIV (\<lambda>x. x ^ n) x :> real n * (x ^ (n - Suc 0))"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   271
  by (simp add: NSDERIV_DERIV_iff DERIV_pow)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   272
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   273
text \<open>Derivative of inverse.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   274
lemma NSDERIV_inverse_fun:
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   275
  "NSDERIV f x :> d \<Longrightarrow> f x \<noteq> 0 \<Longrightarrow>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   276
    NSDERIV (\<lambda>x. inverse (f x)) x :> (- (d * inverse (f x ^ Suc (Suc 0))))"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   277
  for x :: "'a::{real_normed_field}"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   278
  by (simp add: NSDERIV_DERIV_iff DERIV_inverse_fun del: power_Suc)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   279
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   280
text \<open>Derivative of quotient.\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   281
lemma NSDERIV_quotient:
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   282
  fixes x :: "'a::real_normed_field"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   283
  shows "NSDERIV f x :> d \<Longrightarrow> NSDERIV g x :> e \<Longrightarrow> g x \<noteq> 0 \<Longrightarrow>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   284
    NSDERIV (\<lambda>y. f y / g y) x :> (d * g x - (e * f x)) / (g x ^ Suc (Suc 0))"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   285
  by (simp add: NSDERIV_DERIV_iff DERIV_quotient del: power_Suc)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   286
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   287
lemma CARAT_NSDERIV:
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   288
  "NSDERIV f x :> l \<Longrightarrow> \<exists>g. (\<forall>z. f z - f x = g z * (z - x)) \<and> isNSCont g x \<and> g x = l"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   289
  by (simp add: CARAT_DERIV NSDERIV_DERIV_iff isNSCont_isCont_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   290
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   291
lemma hypreal_eq_minus_iff3: "x = y + z \<longleftrightarrow> x + - z = y"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   292
  for x y z :: hypreal
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   293
  by auto
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   294
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   295
lemma CARAT_DERIVD:
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   296
  assumes all: "\<forall>z. f z - f x = g z * (z - x)"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   297
    and nsc: "isNSCont g x"
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   298
  shows "NSDERIV f x :> g x"
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   299
proof -
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   300
  from nsc have "\<forall>w. w \<noteq> star_of x \<and> w \<approx> star_of x \<longrightarrow>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   301
       ( *f* g) w * (w - star_of x) / (w - star_of x) \<approx> star_of (g x)"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   302
    by (simp add: isNSCont_def)
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   303
  with all show ?thesis
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   304
    by (simp add: NSDERIV_iff2 starfun_if_eq cong: if_cong)
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   305
qed
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   306
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   307
61975
b4b11391c676 isabelle update_cartouches -c -t;
wenzelm
parents: 61971
diff changeset
   308
subsubsection \<open>Differentiability predicate\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   309
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   310
lemma NSdifferentiableD: "f NSdifferentiable x \<Longrightarrow> \<exists>D. NSDERIV f x :> D"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   311
  by (simp add: NSdifferentiable_def)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   312
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   313
lemma NSdifferentiableI: "NSDERIV f x :> D \<Longrightarrow> f NSdifferentiable x"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   314
  by (force simp add: NSdifferentiable_def)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   315
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   316
61975
b4b11391c676 isabelle update_cartouches -c -t;
wenzelm
parents: 61971
diff changeset
   317
subsection \<open>(NS) Increment\<close>
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   318
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   319
lemma incrementI:
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   320
  "f NSdifferentiable x \<Longrightarrow>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   321
    increment f x h = ( *f* f) (hypreal_of_real x + h) - hypreal_of_real (f x)"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   322
  by (simp add: increment_def)
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   323
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   324
lemma incrementI2:
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   325
  "NSDERIV f x :> D \<Longrightarrow>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   326
    increment f x h = ( *f* f) (hypreal_of_real x + h) - hypreal_of_real (f x)"
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   327
  by (erule NSdifferentiableI [THEN incrementI])
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   328
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   329
text \<open>The Increment theorem -- Keisler p. 65.\<close>
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   330
lemma increment_thm:
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   331
  assumes "NSDERIV f x :> D" "h \<in> Infinitesimal" "h \<noteq> 0"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   332
  shows "\<exists>e \<in> Infinitesimal. increment f x h = hypreal_of_real D * h + e * h"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   333
proof -
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   334
  have inc: "increment f x h = ( *f* f) (hypreal_of_real x + h) - hypreal_of_real (f x)"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   335
    using assms(1) incrementI2 by auto
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   336
  have "(( *f* f) (hypreal_of_real x + h) - hypreal_of_real (f x)) / h \<approx> hypreal_of_real D"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   337
    by (simp add: NSDERIVD2 assms)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   338
  then obtain y where "y \<in> Infinitesimal" 
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   339
    "(( *f* f) (hypreal_of_real x + h) - hypreal_of_real (f x)) / h = hypreal_of_real D + y"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   340
    by (metis bex_Infinitesimal_iff2)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   341
  then have "increment f x h / h = hypreal_of_real D + y"
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   342
    by (metis inc) 
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   343
  then show ?thesis
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   344
    by (metis (no_types) \<open>y \<in> Infinitesimal\<close> \<open>h \<noteq> 0\<close> distrib_right mult.commute nonzero_mult_div_cancel_left times_divide_eq_right)
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   345
qed
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   346
64435
c93b0e6131c3 misc tuning and modernization;
wenzelm
parents: 64240
diff changeset
   347
lemma increment_approx_zero: "NSDERIV f x :> D \<Longrightarrow> h \<approx> 0 \<Longrightarrow> h \<noteq> 0 \<Longrightarrow> increment f x h \<approx> 0"
68644
242d298526a3 de-applying and simplifying proofs
paulson <lp15@cam.ac.uk>
parents: 67399
diff changeset
   348
  by (simp add: NSDERIV_approx incrementI2 mem_infmal_iff)
27468
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   349
0783dd1dc13d move nonstandard analysis theories to NSA directory
huffman
parents:
diff changeset
   350
end