diff options
author | Jason Gross <jgross@mit.edu> | 2016-10-04 21:14:55 -0400 |
---|---|---|
committer | Jason Gross <jgross@mit.edu> | 2016-10-04 21:14:55 -0400 |
commit | 31171415c7e9e449cac3e074dbabc6536147053f (patch) | |
tree | d7d63b6c356b3c568c197d5e3bd7ffc44ecd29e8 /src/Util/ZUtil.v | |
parent | f368dbda73ceed2dd9a0d8a21b53f31bea70ea6d (diff) |
Add ZUtil lemma
Diffstat (limited to 'src/Util/ZUtil.v')
-rw-r--r-- | src/Util/ZUtil.v | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/src/Util/ZUtil.v b/src/Util/ZUtil.v index 236cf61d3..464a6c44d 100644 --- a/src/Util/ZUtil.v +++ b/src/Util/ZUtil.v @@ -1785,6 +1785,27 @@ Module Z. Hint Rewrite shiftr_sub using zutil_arith : push_Zshift. Hint Rewrite <- shiftr_sub using zutil_arith : pull_Zshift. + Lemma shl_shr_lt x y n m (Hx : 0 <= x < 2^n) (Hy : 0 <= y < 2^n) (Hm : 0 <= m <= n) + : 0 <= (x >> (n - m)) + ((y << m) mod 2^n) < 2^n. + Proof. + cut (0 <= (x >> (n - m)) + ((y << m) mod 2^n) <= 2^n - 1); [ omega | ]. + assert (0 <= x <= 2^n - 1) by omega. + assert (0 <= y <= 2^n - 1) by omega. + assert (0 < 2 ^ (n - m)) by auto with zarith. + assert (0 <= y mod 2 ^ (n - m) < 2^(n-m)) by auto with zarith. + assert (0 <= y mod 2 ^ (n - m) <= 2 ^ (n - m) - 1) by omega. + assert (0 <= (y mod 2 ^ (n - m)) * 2^m <= (2^(n-m) - 1)*2^m) by auto with zarith. + assert (0 <= x / 2^(n-m) < 2^n / 2^(n-m)). + { split; zero_bounds. + apply Z.div_lt_upper_bound; autorewrite with pull_Zpow zsimplify; nia. } + autorewrite with Zshift_to_pow. + split; Z.zero_bounds. + replace (2^n) with (2^(n-m) * 2^m) by (autorewrite with pull_Zpow; f_equal; omega). + rewrite Zmult_mod_distr_r. + autorewrite with pull_Zpow zsimplify push_Zmul in * |- . + nia. + Qed. + Lemma lt_pow_2_shiftr : forall a n, 0 <= a < 2 ^ n -> a >> n = 0. Proof. intros. |