Library Coq.QArith.Qpower


Require Import Zpow_facts Qfield Qreduction.

Lemma Qpower_positive_1 : forall n, Qpower_positive 1 n == 1.

Lemma Qpower_1 : forall n, 1^n == 1.

Lemma Qpower_positive_0 : forall n, Qpower_positive 0 n == 0.

Lemma Qpower_0 : forall n, (n<>0)%Z -> 0^n == 0.

Lemma Qpower_not_0_positive : forall a n, ~a==0 -> ~Qpower_positive a n == 0.

Lemma Qpower_pos_positive : forall p n, 0 <= p -> 0 <= Qpower_positive p n.

Lemma Qpower_pos : forall p n, 0 <= p -> 0 <= p^n.

Lemma Qmult_power_positive : forall a b n, Qpower_positive (a*b) n == (Qpower_positive a n)*(Qpower_positive b n).

Lemma Qmult_power : forall a b n, (a*b)^n == a^n*b^n.

Lemma Qinv_power_positive : forall a n, Qpower_positive (/a) n == /(Qpower_positive a n).

Lemma Qinv_power : forall a n, (/a)^n == /a^n.

Lemma Qdiv_power : forall a b n, (a/b)^n == (a^n/b^n).

Lemma Qinv_power_n : forall n p, (1#p)^n == /(inject_Z ('p))^n.

Lemma Qpower_plus_positive : forall a n m, Qpower_positive a (n+m) == (Qpower_positive a n)*(Qpower_positive a m).

Lemma Qpower_opp : forall a n, a^(-n) == /a^n.

Lemma Qpower_minus_positive : forall a (n m:positive),
  (m < n)%positive ->
  Qpower_positive a (n-m)%positive == (Qpower_positive a n)/(Qpower_positive a m).

Lemma Qpower_plus : forall a n m, ~a==0 -> a^(n+m) == a^n*a^m.

Lemma Qpower_plus' : forall a n m, (n+m <> 0)%Z -> a^(n+m) == a^n*a^m.

Lemma Qpower_mult_positive : forall a n m,
  Qpower_positive a (n*m) == Qpower_positive (Qpower_positive a n) m.

Lemma Qpower_mult : forall a n m, a^(n*m) == (a^n)^m.

Lemma Zpower_Qpower : forall (a n:Z), (0<=n)%Z -> inject_Z (a^n) == (inject_Z a)^n.

Lemma Qsqr_nonneg : forall a, 0 <= a^2.

Theorem Qpower_decomp p x y :
  Qpower_positive (x#y) p = x ^ Zpos p # (y ^ p).