src/HOL/Nat_Int_Bij.thy
author ballarin
Wed, 19 Nov 2008 16:58:33 +0100
changeset 28849 9458d7a6388a
parent 28098 c92850d2d16c
permissions -rw-r--r--
Enable switching to new locales during session.
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28098
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     1
(*  Title:      HOL/Nat_Int_Bij.thy
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     2
    ID:         $Id$
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     3
    Author:     Stefan Richter, Tobias Nipkow
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     4
*)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     5
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     6
header{* Bijections $\mathbb{N}\to\mathbb{N}^2$ and $\mathbb{N}\to\mathbb{Z}$*}
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     7
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     8
theory Nat_Int_Bij
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
     9
imports Hilbert_Choice Presburger
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    10
begin
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    11
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    12
subsection{*  A bijection between @{text "\<nat>"} and @{text "\<nat>\<twosuperior>"} *}
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    13
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    14
text{* Definition and proofs are from \cite[page 85]{Oberschelp:1993}. *}
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    15
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    16
definition nat2_to_nat:: "(nat * nat) \<Rightarrow> nat" where
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    17
"nat2_to_nat pair = (let (n,m) = pair in (n+m) * Suc (n+m) div 2 + n)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    18
definition nat_to_nat2::  "nat \<Rightarrow> (nat * nat)" where
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    19
"nat_to_nat2 = inv nat2_to_nat"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    20
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    21
lemma dvd2_a_x_suc_a: "2 dvd a * (Suc a)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    22
proof (cases "2 dvd a")
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    23
  case True
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    24
  then show ?thesis by (rule dvd_mult2)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    25
next
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    26
  case False
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    27
  then have "Suc (a mod 2) = 2" by (simp add: dvd_eq_mod_eq_0)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    28
  then have "Suc a mod 2 = 0" by (simp add: mod_Suc)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    29
  then have "2 dvd Suc a" by (simp only:dvd_eq_mod_eq_0)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    30
  then show ?thesis by (rule dvd_mult)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    31
qed
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    32
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    33
lemma
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    34
  assumes eq: "nat2_to_nat (u,v) = nat2_to_nat (x,y)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    35
  shows nat2_to_nat_help: "u+v \<le> x+y"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    36
proof (rule classical)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    37
  assume "\<not> ?thesis"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    38
  then have contrapos: "x+y < u+v"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    39
    by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    40
  have "nat2_to_nat (x,y) < (x+y) * Suc (x+y) div 2 + Suc (x + y)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    41
    by (unfold nat2_to_nat_def) (simp add: Let_def)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    42
  also have "\<dots> = (x+y)*Suc(x+y) div 2 + 2 * Suc(x+y) div 2"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    43
    by (simp only: div_mult_self1_is_m)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    44
  also have "\<dots> = (x+y)*Suc(x+y) div 2 + 2 * Suc(x+y) div 2
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    45
    + ((x+y)*Suc(x+y) mod 2 + 2 * Suc(x+y) mod 2) div 2"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    46
  proof -
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    47
    have "2 dvd (x+y)*Suc(x+y)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    48
      by (rule dvd2_a_x_suc_a)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    49
    then have "(x+y)*Suc(x+y) mod 2 = 0"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    50
      by (simp only: dvd_eq_mod_eq_0)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    51
    also
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    52
    have "2 * Suc(x+y) mod 2 = 0"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    53
      by (rule mod_mult_self1_is_0)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    54
    ultimately have
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    55
      "((x+y)*Suc(x+y) mod 2 + 2 * Suc(x+y) mod 2) div 2 = 0"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    56
      by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    57
    then show ?thesis
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    58
      by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    59
  qed
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    60
  also have "\<dots> = ((x+y)*Suc(x+y) + 2*Suc(x+y)) div 2"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    61
    by (rule div_add1_eq [symmetric])
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    62
  also have "\<dots> = ((x+y+2)*Suc(x+y)) div 2"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    63
    by (simp only: add_mult_distrib [symmetric])
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    64
  also from contrapos have "\<dots> \<le> ((Suc(u+v))*(u+v)) div 2"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    65
    by (simp only: mult_le_mono div_le_mono)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    66
  also have "\<dots> \<le> nat2_to_nat (u,v)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    67
    by (unfold nat2_to_nat_def) (simp add: Let_def)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    68
  finally show ?thesis
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    69
    by (simp only: eq)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    70
qed
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    71
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    72
theorem nat2_to_nat_inj: "inj nat2_to_nat"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    73
proof -
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    74
  {
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    75
    fix u v x y
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    76
    assume eq1: "nat2_to_nat (u,v) = nat2_to_nat (x,y)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    77
    then have "u+v \<le> x+y" by (rule nat2_to_nat_help)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    78
    also from eq1 [symmetric] have "x+y \<le> u+v"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    79
      by (rule nat2_to_nat_help)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    80
    finally have eq2: "u+v = x+y" .
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    81
    with eq1 have ux: "u=x"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    82
      by (simp add: nat2_to_nat_def Let_def)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    83
    with eq2 have vy: "v=y" by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    84
    with ux have "(u,v) = (x,y)" by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    85
  }
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    86
  then have "\<And>x y. nat2_to_nat x = nat2_to_nat y \<Longrightarrow> x=y" by fast
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    87
  then show ?thesis unfolding inj_on_def by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    88
qed
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    89
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    90
lemma nat_to_nat2_surj: "surj nat_to_nat2"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    91
by (simp only: nat_to_nat2_def nat2_to_nat_inj inj_imp_surj_inv)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    92
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    93
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    94
lemma gauss_sum_nat_upto: "2 * (\<Sum>i\<le>n::nat. i) = n * (n + 1)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    95
using gauss_sum[where 'a = nat]
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    96
by (simp add:atLeast0AtMost setsum_shift_lb_Suc0_0 numeral_2_eq_2)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    97
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    98
lemma nat2_to_nat_surj: "surj nat2_to_nat"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
    99
proof (unfold surj_def)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   100
  {
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   101
    fix z::nat 
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   102
    def r \<equiv> "Max {r. (\<Sum>i\<le>r. i) \<le> z}" 
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   103
    def x \<equiv> "z - (\<Sum>i\<le>r. i)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   104
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   105
    hence "finite  {r. (\<Sum>i\<le>r. i) \<le> z}"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   106
      by (simp add: lessThan_Suc_atMost[symmetric] lessThan_Suc finite_less_ub)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   107
    also have "0 \<in> {r. (\<Sum>i\<le>r. i) \<le> z}"  by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   108
    hence "{r::nat. (\<Sum>i\<le>r. i) \<le> z} \<noteq> {}"  by fast
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   109
    ultimately have a: "r \<in> {r. (\<Sum>i\<le>r. i) \<le> z} \<and> (\<forall>s \<in> {r. (\<Sum>i\<le>r. i) \<le> z}. s \<le> r)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   110
      by (simp add: r_def del:mem_Collect_eq)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   111
    {
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   112
      assume "r<x"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   113
      hence "r+1\<le>x"  by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   114
      hence "(\<Sum>i\<le>r. i)+(r+1)\<le>z"  using x_def by arith
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   115
      hence "(r+1) \<in>  {r. (\<Sum>i\<le>r. i) \<le> z}"  by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   116
      with a have "(r+1)\<le>r"  by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   117
    }
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   118
    hence b: "x\<le>r"  by force
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   119
    
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   120
    def y \<equiv> "r-x"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   121
    have "2*z=2*(\<Sum>i\<le>r. i)+2*x"  using x_def a by simp arith
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   122
    also have "\<dots> = r * (r+1) + 2*x"   using gauss_sum_nat_upto by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   123
    also have "\<dots> = (x+y)*(x+y+1)+2*x" using y_def b by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   124
    also { have "2 dvd ((x+y)*(x+y+1))"	using dvd2_a_x_suc_a by simp }
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   125
    hence "\<dots> = 2 * nat2_to_nat(x,y)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   126
      using nat2_to_nat_def by (simp add: Let_def dvd_mult_div_cancel)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   127
    finally have "z=nat2_to_nat (x, y)"  by simp
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   128
  }
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   129
  thus "\<forall>y. \<exists>x. y = nat2_to_nat x"  by fast
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   130
qed
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   131
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   132
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   133
subsection{*  A bijection between @{text "\<nat>"} and @{text "\<int>"} *}
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   134
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   135
definition nat_to_int_bij :: "nat \<Rightarrow> int" where
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   136
"nat_to_int_bij n = (if 2 dvd n then int(n div 2) else -int(Suc n div 2))"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   137
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   138
definition int_to_nat_bij :: "int \<Rightarrow> nat" where
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   139
"int_to_nat_bij i = (if 0<=i then 2*nat(i) else 2*nat(-i) - 1)"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   140
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   141
lemma  i2n_n2i_id: "int_to_nat_bij (nat_to_int_bij n) = n"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   142
by (simp add: int_to_nat_bij_def nat_to_int_bij_def) presburger
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   143
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   144
lemma n2i_i2n_id: "nat_to_int_bij(int_to_nat_bij i) = i"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   145
proof -
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   146
  have "ALL m n::nat. m>0 \<longrightarrow> 2 * m - Suc 0 \<noteq> 2 * n" by presburger
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   147
  thus ?thesis
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   148
    by(simp add: nat_to_int_bij_def int_to_nat_bij_def, simp add:dvd_def)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   149
qed
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   150
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   151
lemma inv_nat_to_int_bij: "inv nat_to_int_bij = int_to_nat_bij"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   152
by (simp add: i2n_n2i_id inv_equality n2i_i2n_id)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   153
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   154
lemma inv_int_to_nat_bij: "inv int_to_nat_bij = nat_to_int_bij"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   155
by (simp add: i2n_n2i_id inv_equality n2i_i2n_id)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   156
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   157
lemma surj_nat_to_int_bij: "surj nat_to_int_bij"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   158
by (blast intro: n2i_i2n_id surjI)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   159
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   160
lemma surj_int_to_nat_bij: "surj int_to_nat_bij"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   161
by (blast intro: i2n_n2i_id surjI)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   162
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   163
lemma inj_nat_to_int_bij: "inj nat_to_int_bij"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   164
by(simp add:inv_int_to_nat_bij[symmetric] surj_int_to_nat_bij surj_imp_inj_inv)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   165
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   166
lemma inj_int_to_nat_bij: "inj int_to_nat_bij"
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   167
by(simp add:inv_nat_to_int_bij[symmetric] surj_nat_to_int_bij surj_imp_inj_inv)
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   168
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   169
c92850d2d16c Replaced Library/NatPair by Nat_Int_Bij.
nipkow
parents:
diff changeset
   170
end