diff options
Diffstat (limited to 'vendor/bitmaps')
-rw-r--r-- | vendor/bitmaps/.cargo-checksum.json | 1 | ||||
-rw-r--r-- | vendor/bitmaps/CHANGELOG.md | 34 | ||||
-rw-r--r-- | vendor/bitmaps/CODE_OF_CONDUCT.md | 73 | ||||
-rw-r--r-- | vendor/bitmaps/Cargo.toml | 35 | ||||
-rw-r--r-- | vendor/bitmaps/LICENCE.md | 355 | ||||
-rw-r--r-- | vendor/bitmaps/README.md | 50 | ||||
-rw-r--r-- | vendor/bitmaps/src/bitmap.rs | 510 | ||||
-rw-r--r-- | vendor/bitmaps/src/lib.rs | 62 | ||||
-rw-r--r-- | vendor/bitmaps/src/types.rs | 1337 |
9 files changed, 2457 insertions, 0 deletions
diff --git a/vendor/bitmaps/.cargo-checksum.json b/vendor/bitmaps/.cargo-checksum.json new file mode 100644 index 000000000..c4fef18fd --- /dev/null +++ b/vendor/bitmaps/.cargo-checksum.json @@ -0,0 +1 @@ +{"files":{"CHANGELOG.md":"89d0a9d3c8ca98cc07dbc58f0e93db9dd394810cb86c26e861b7f3bb038d4ac6","CODE_OF_CONDUCT.md":"3db9f112c815ffef9a6f51eef2f5f6a3f3c2900510c243f26ad890321b888473","Cargo.toml":"1bd6392685eeb14ba5bcc4bde063106fe401136a8095c1f358dcf5a82eff46c0","LICENCE.md":"e6b6566f085df5746515c6d7e2edcaec0d2b77d527ac40d91409d783fb6c8508","README.md":"300425e459548ede41886b7f6f26634e09c8f5be38baf3ca1dd3bce1cbf3280f","src/bitmap.rs":"859a7761db424fdca38cbf8c9ec24b68006857a09f7dccbd86c66d979210aa7f","src/lib.rs":"f985e579e0d173e1fe4a0495fa596e30c1f674d5a76de6eb87eb5d73cc73a9d4","src/types.rs":"1819e3cc21a80537091339c7bea1bdea922ff84f856ccaabd8795ac9827b945e"},"package":"031043d04099746d8db04daf1fa424b2bc8bd69d92b25962dcde24da39ab64a2"}
\ No newline at end of file diff --git a/vendor/bitmaps/CHANGELOG.md b/vendor/bitmaps/CHANGELOG.md new file mode 100644 index 000000000..f9d9b038b --- /dev/null +++ b/vendor/bitmaps/CHANGELOG.md @@ -0,0 +1,34 @@ +# Changelog + +All notable changes to this project will be documented in this file. + +The format is based on [Keep a Changelog](http://keepachangelog.com/en/1.0.0/) and this project +adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html). + +## [2.1.0] - 2020-03-26 + +### ADDED + +- There is now a `std` feature flag, on by default, which you can disable to get a `no_std` crate. + +## [2.0.0] - 2019-09-09 + +### CHANGED + +- `Bits` now does a lot less work, which is now being done instead by the `BitOps` trait on its + storage type. This turns out to improve compilation time quite considerably. If you were using + methods on `Bits` directly, they will have moved to `BitOps`. +- `Debug` now prints a single hex value for the entire bitmap, rather than deferring to the + storage type. +- `Iter` now takes a reference instead of a copy, which is more sensible for larger bitmaps. + +### ADDED + +- `Bitmap` now implements `BitAnd`, `BitOr`, `BitXor`, their equivalent assignation traits, and + `Not`, meaning you can now use bitwise operators on them, even the very big array-of-u128 ones. +- A `Bitmap::mask()` constructor has been added, to construct bitmasks more efficiently, now that + there are bitwise operators to use them with. + +## [1.0.0] - 2019-09-06 + +Initial release. diff --git a/vendor/bitmaps/CODE_OF_CONDUCT.md b/vendor/bitmaps/CODE_OF_CONDUCT.md new file mode 100644 index 000000000..02a086970 --- /dev/null +++ b/vendor/bitmaps/CODE_OF_CONDUCT.md @@ -0,0 +1,73 @@ +# Contributor Covenant Code of Conduct + +## Our Pledge + +In the interest of fostering an open and welcoming environment, we as +contributors and maintainers pledge to making participation in our project and +our community a harassment-free experience for everyone, regardless of age, body +size, disability, ethnicity, gender identity and expression, level of experience, +education, socio-economic status, nationality, personal appearance, race, +religion, or sexual identity and orientation. + +## Our Standards + +Examples of behavior that contributes to creating a positive environment +include: + +* Using welcoming and inclusive language +* Being respectful of differing viewpoints and experiences +* Gracefully accepting constructive criticism +* Focusing on what is best for the community +* Showing empathy towards other community members + +Examples of unacceptable behavior by participants include: + +* The use of sexualized language or imagery and unwelcome sexual attention or + advances +* Trolling, insulting/derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or electronic + address, without explicit permission +* Other conduct which could reasonably be considered inappropriate in a + professional setting + +## Our Responsibilities + +Project maintainers are responsible for clarifying the standards of acceptable +behavior and are expected to take appropriate and fair corrective action in +response to any instances of unacceptable behavior. + +Project maintainers have the right and responsibility to remove, edit, or +reject comments, commits, code, wiki edits, issues, and other contributions +that are not aligned to this Code of Conduct, or to ban temporarily or +permanently any contributor for other behaviors that they deem inappropriate, +threatening, offensive, or harmful. + +## Scope + +This Code of Conduct applies both within project spaces and in public spaces +when an individual is representing the project or its community. Examples of +representing a project or community include using an official project e-mail +address, posting via an official social media account, or acting as an appointed +representative at an online or offline event. Representation of a project may be +further defined and clarified by project maintainers. + +## Enforcement + +Instances of abusive, harassing, or otherwise unacceptable behavior may be +reported by contacting the project team at admin@immutable.rs. All +complaints will be reviewed and investigated and will result in a response that +is deemed necessary and appropriate to the circumstances. The project team is +obligated to maintain confidentiality with regard to the reporter of an incident. +Further details of specific enforcement policies may be posted separately. + +Project maintainers who do not follow or enforce the Code of Conduct in good +faith may face temporary or permanent repercussions as determined by other +members of the project's leadership. + +## Attribution + +This Code of Conduct is adapted from the [Contributor Covenant][homepage], version 1.4, +available at https://www.contributor-covenant.org/version/1/4/code-of-conduct.html + +[homepage]: https://www.contributor-covenant.org diff --git a/vendor/bitmaps/Cargo.toml b/vendor/bitmaps/Cargo.toml new file mode 100644 index 000000000..271365032 --- /dev/null +++ b/vendor/bitmaps/Cargo.toml @@ -0,0 +1,35 @@ +# THIS FILE IS AUTOMATICALLY GENERATED BY CARGO +# +# When uploading crates to the registry Cargo will automatically +# "normalize" Cargo.toml files for maximal compatibility +# with all versions of Cargo and also rewrite `path` dependencies +# to registry (e.g., crates.io) dependencies +# +# If you believe there's an error in this file please file an +# issue against the rust-lang/cargo repository. If you're +# editing this file be aware that the upstream Cargo.toml +# will likely look very different (and much more reasonable) + +[package] +edition = "2018" +name = "bitmaps" +version = "2.1.0" +authors = ["Bodil Stokke <bodil@bodil.org>"] +exclude = ["release.toml", "proptest-regressions/**"] +description = "Fixed size boolean arrays" +documentation = "http://docs.rs/bitmaps" +readme = "./README.md" +categories = ["data-structures"] +license = "MPL-2.0+" +repository = "https://github.com/bodil/bitmaps" +[dependencies.typenum] +version = "1.10.0" +[dev-dependencies.proptest] +version = "0.9.1" + +[dev-dependencies.proptest-derive] +version = "0.1.0" + +[features] +default = ["std"] +std = [] diff --git a/vendor/bitmaps/LICENCE.md b/vendor/bitmaps/LICENCE.md new file mode 100644 index 000000000..cd44203cd --- /dev/null +++ b/vendor/bitmaps/LICENCE.md @@ -0,0 +1,355 @@ +Mozilla Public License Version 2.0 +================================== + +### 1. Definitions + +**1.1. “Contributor”** + means each individual or legal entity that creates, contributes to + the creation of, or owns Covered Software. + +**1.2. “Contributor Version”** + means the combination of the Contributions of others (if any) used + by a Contributor and that particular Contributor's Contribution. + +**1.3. “Contribution”** + means Covered Software of a particular Contributor. + +**1.4. “Covered Software”** + means Source Code Form to which the initial Contributor has attached + the notice in Exhibit A, the Executable Form of such Source Code + Form, and Modifications of such Source Code Form, in each case + including portions thereof. + +**1.5. “Incompatible With Secondary Licenses”** + means + +* **(a)** that the initial Contributor has attached the notice described + in Exhibit B to the Covered Software; or +* **(b)** that the Covered Software was made available under the terms of + version 1.1 or earlier of the License, but not also under the + terms of a Secondary License. + +**1.6. “Executable Form”** + means any form of the work other than Source Code Form. + +**1.7. “Larger Work”** + means a work that combines Covered Software with other material, in + a separate file or files, that is not Covered Software. + +**1.8. “License”** + means this document. + +**1.9. “Licensable”** + means having the right to grant, to the maximum extent possible, + whether at the time of the initial grant or subsequently, any and + all of the rights conveyed by this License. + +**1.10. “Modifications”** + means any of the following: + +* **(a)** any file in Source Code Form that results from an addition to, + deletion from, or modification of the contents of Covered + Software; or +* **(b)** any new file in Source Code Form that contains any Covered + Software. + +**1.11. “Patent Claims” of a Contributor** + means any patent claim(s), including without limitation, method, + process, and apparatus claims, in any patent Licensable by such + Contributor that would be infringed, but for the grant of the + License, by the making, using, selling, offering for sale, having + made, import, or transfer of either its Contributions or its + Contributor Version. + +**1.12. “Secondary License”** + means either the GNU General Public License, Version 2.0, the GNU + Lesser General Public License, Version 2.1, the GNU Affero General + Public License, Version 3.0, or any later versions of those + licenses. + +**1.13. “Source Code Form”** + means the form of the work preferred for making modifications. + +**1.14. “You” (or “Your”)** + means an individual or a legal entity exercising rights under this + License. For legal entities, “You” includes any entity that + controls, is controlled by, or is under common control with You. For + purposes of this definition, “control” means **(a)** the power, direct + or indirect, to cause the direction or management of such entity, + whether by contract or otherwise, or **(b)** ownership of more than + fifty percent (50%) of the outstanding shares or beneficial + ownership of such entity. + + +### 2. License Grants and Conditions + +#### 2.1. Grants + +Each Contributor hereby grants You a world-wide, royalty-free, +non-exclusive license: + +* **(a)** under intellectual property rights (other than patent or trademark) + Licensable by such Contributor to use, reproduce, make available, + modify, display, perform, distribute, and otherwise exploit its + Contributions, either on an unmodified basis, with Modifications, or + as part of a Larger Work; and +* **(b)** under Patent Claims of such Contributor to make, use, sell, offer + for sale, have made, import, and otherwise transfer either its + Contributions or its Contributor Version. + +#### 2.2. Effective Date + +The licenses granted in Section 2.1 with respect to any Contribution +become effective for each Contribution on the date the Contributor first +distributes such Contribution. + +#### 2.3. Limitations on Grant Scope + +The licenses granted in this Section 2 are the only rights granted under +this License. No additional rights or licenses will be implied from the +distribution or licensing of Covered Software under this License. +Notwithstanding Section 2.1(b) above, no patent license is granted by a +Contributor: + +* **(a)** for any code that a Contributor has removed from Covered Software; + or +* **(b)** for infringements caused by: **(i)** Your and any other third party's + modifications of Covered Software, or **(ii)** the combination of its + Contributions with other software (except as part of its Contributor + Version); or +* **(c)** under Patent Claims infringed by Covered Software in the absence of + its Contributions. + +This License does not grant any rights in the trademarks, service marks, +or logos of any Contributor (except as may be necessary to comply with +the notice requirements in Section 3.4). + +#### 2.4. Subsequent Licenses + +No Contributor makes additional grants as a result of Your choice to +distribute the Covered Software under a subsequent version of this +License (see Section 10.2) or under the terms of a Secondary License (if +permitted under the terms of Section 3.3). + +#### 2.5. Representation + +Each Contributor represents that the Contributor believes its +Contributions are its original creation(s) or it has sufficient rights +to grant the rights to its Contributions conveyed by this License. + +#### 2.6. Fair Use + +This License is not intended to limit any rights You have under +applicable copyright doctrines of fair use, fair dealing, or other +equivalents. + +#### 2.7. Conditions + +Sections 3.1, 3.2, 3.3, and 3.4 are conditions of the licenses granted +in Section 2.1. + + +### 3. Responsibilities + +#### 3.1. Distribution of Source Form + +All distribution of Covered Software in Source Code Form, including any +Modifications that You create or to which You contribute, must be under +the terms of this License. You must inform recipients that the Source +Code Form of the Covered Software is governed by the terms of this +License, and how they can obtain a copy of this License. You may not +attempt to alter or restrict the recipients' rights in the Source Code +Form. + +#### 3.2. Distribution of Executable Form + +If You distribute Covered Software in Executable Form then: + +* **(a)** such Covered Software must also be made available in Source Code + Form, as described in Section 3.1, and You must inform recipients of + the Executable Form how they can obtain a copy of such Source Code + Form by reasonable means in a timely manner, at a charge no more + than the cost of distribution to the recipient; and + +* **(b)** You may distribute such Executable Form under the terms of this + License, or sublicense it under different terms, provided that the + license for the Executable Form does not attempt to limit or alter + the recipients' rights in the Source Code Form under this License. + +#### 3.3. Distribution of a Larger Work + +You may create and distribute a Larger Work under terms of Your choice, +provided that You also comply with the requirements of this License for +the Covered Software. If the Larger Work is a combination of Covered +Software with a work governed by one or more Secondary Licenses, and the +Covered Software is not Incompatible With Secondary Licenses, this +License permits You to additionally distribute such Covered Software +under the terms of such Secondary License(s), so that the recipient of +the Larger Work may, at their option, further distribute the Covered +Software under the terms of either this License or such Secondary +License(s). + +#### 3.4. Notices + +You may not remove or alter the substance of any license notices +(including copyright notices, patent notices, disclaimers of warranty, +or limitations of liability) contained within the Source Code Form of +the Covered Software, except that You may alter any license notices to +the extent required to remedy known factual inaccuracies. + +#### 3.5. Application of Additional Terms + +You may choose to offer, and to charge a fee for, warranty, support, +indemnity or liability obligations to one or more recipients of Covered +Software. However, You may do so only on Your own behalf, and not on +behalf of any Contributor. You must make it absolutely clear that any +such warranty, support, indemnity, or liability obligation is offered by +You alone, and You hereby agree to indemnify every Contributor for any +liability incurred by such Contributor as a result of warranty, support, +indemnity or liability terms You offer. You may include additional +disclaimers of warranty and limitations of liability specific to any +jurisdiction. + + +### 4. Inability to Comply Due to Statute or Regulation + +If it is impossible for You to comply with any of the terms of this +License with respect to some or all of the Covered Software due to +statute, judicial order, or regulation then You must: **(a)** comply with +the terms of this License to the maximum extent possible; and **(b)** +describe the limitations and the code they affect. Such description must +be placed in a text file included with all distributions of the Covered +Software under this License. Except to the extent prohibited by statute +or regulation, such description must be sufficiently detailed for a +recipient of ordinary skill to be able to understand it. + + +### 5. Termination + +**5.1.** The rights granted under this License will terminate automatically +if You fail to comply with any of its terms. However, if You become +compliant, then the rights granted under this License from a particular +Contributor are reinstated **(a)** provisionally, unless and until such +Contributor explicitly and finally terminates Your grants, and **(b)** on an +ongoing basis, if such Contributor fails to notify You of the +non-compliance by some reasonable means prior to 60 days after You have +come back into compliance. Moreover, Your grants from a particular +Contributor are reinstated on an ongoing basis if such Contributor +notifies You of the non-compliance by some reasonable means, this is the +first time You have received notice of non-compliance with this License +from such Contributor, and You become compliant prior to 30 days after +Your receipt of the notice. + +**5.2.** If You initiate litigation against any entity by asserting a patent +infringement claim (excluding declaratory judgment actions, +counter-claims, and cross-claims) alleging that a Contributor Version +directly or indirectly infringes any patent, then the rights granted to +You by any and all Contributors for the Covered Software under Section +2.1 of this License shall terminate. + +**5.3.** In the event of termination under Sections 5.1 or 5.2 above, all +end user license agreements (excluding distributors and resellers) which +have been validly granted by You or Your distributors under this License +prior to termination shall survive termination. + + +### 6. Disclaimer of Warranty + +> Covered Software is provided under this License on an “as is” +> basis, without warranty of any kind, either expressed, implied, or +> statutory, including, without limitation, warranties that the +> Covered Software is free of defects, merchantable, fit for a +> particular purpose or non-infringing. The entire risk as to the +> quality and performance of the Covered Software is with You. +> Should any Covered Software prove defective in any respect, You +> (not any Contributor) assume the cost of any necessary servicing, +> repair, or correction. This disclaimer of warranty constitutes an +> essential part of this License. No use of any Covered Software is +> authorized under this License except under this disclaimer. + +### 7. Limitation of Liability + +> Under no circumstances and under no legal theory, whether tort +> (including negligence), contract, or otherwise, shall any +> Contributor, or anyone who distributes Covered Software as +> permitted above, be liable to You for any direct, indirect, +> special, incidental, or consequential damages of any character +> including, without limitation, damages for lost profits, loss of +> goodwill, work stoppage, computer failure or malfunction, or any +> and all other commercial damages or losses, even if such party +> shall have been informed of the possibility of such damages. This +> limitation of liability shall not apply to liability for death or +> personal injury resulting from such party's negligence to the +> extent applicable law prohibits such limitation. Some +> jurisdictions do not allow the exclusion or limitation of +> incidental or consequential damages, so this exclusion and +> limitation may not apply to You. + + +### 8. Litigation + +Any litigation relating to this License may be brought only in the +courts of a jurisdiction where the defendant maintains its principal +place of business and such litigation shall be governed by laws of that +jurisdiction, without reference to its conflict-of-law provisions. +Nothing in this Section shall prevent a party's ability to bring +cross-claims or counter-claims. + + +### 9. Miscellaneous + +This License represents the complete agreement concerning the subject +matter hereof. If any provision of this License is held to be +unenforceable, such provision shall be reformed only to the extent +necessary to make it enforceable. Any law or regulation which provides +that the language of a contract shall be construed against the drafter +shall not be used to construe this License against a Contributor. + + +### 10. Versions of the License + +#### 10.1. New Versions + +Mozilla Foundation is the license steward. Except as provided in Section +10.3, no one other than the license steward has the right to modify or +publish new versions of this License. Each version will be given a +distinguishing version number. + +#### 10.2. Effect of New Versions + +You may distribute the Covered Software under the terms of the version +of the License under which You originally received the Covered Software, +or under the terms of any subsequent version published by the license +steward. + +#### 10.3. Modified Versions + +If you create software not governed by this License, and you want to +create a new license for such software, you may create and use a +modified version of this License if you rename the license and remove +any references to the name of the license steward (except to note that +such modified license differs from this License). + +#### 10.4. Distributing Source Code Form that is Incompatible With Secondary Licenses + +If You choose to distribute Source Code Form that is Incompatible With +Secondary Licenses under the terms of this version of the License, the +notice described in Exhibit B of this License must be attached. + +## Exhibit A - Source Code Form License Notice + + This Source Code Form is subject to the terms of the Mozilla Public + License, v. 2.0. If a copy of the MPL was not distributed with this + file, You can obtain one at http://mozilla.org/MPL/2.0/. + +If it is not possible or desirable to put the notice in a particular +file, then You may include the notice in a location (such as a LICENSE +file in a relevant directory) where a recipient would be likely to look +for such a notice. + +You may add additional accurate notices of copyright ownership. + +## Exhibit B - “Incompatible With Secondary Licenses” Notice + + This Source Code Form is "Incompatible With Secondary Licenses", as + defined by the Mozilla Public License, v. 2.0. diff --git a/vendor/bitmaps/README.md b/vendor/bitmaps/README.md new file mode 100644 index 000000000..7d9d4b8b9 --- /dev/null +++ b/vendor/bitmaps/README.md @@ -0,0 +1,50 @@ +# bitmaps + +A fixed size compact boolean array in Rust. + +## Overview + +This crate provides a convenient and efficient way of declaring and working with +fixed size bitmaps in Rust. It was originally split out from the [sized-chunks] +crate and its primary purpose is to support it, but the `Bitmap` type has proven +to be generally useful enough that it was split off into a separate crate. + +## Example + +```rust +use bitmaps::Bitmap; +use typenum::U10; + +fn main() { + let mut bitmap = Bitmap::<U10>::new(); + assert_eq!(bitmap.set(5, true), false); + assert_eq!(bitmap.set(5, true), true); + assert_eq!(bitmap.get(5), true); + assert_eq!(bitmap.get(6), false); + assert_eq!(bitmap.len(), 1); + assert_eq!(bitmap.set(3, true), false); + assert_eq!(bitmap.len(), 2); + assert_eq!(bitmap.first_index(), Some(3)); +} +``` + +## Documentation + +* [API docs](https://docs.rs/bitmaps) + +## Licence + +Copyright 2019 Bodil Stokke + +This software is subject to the terms of the Mozilla Public +License, v. 2.0. If a copy of the MPL was not distributed with this +file, You can obtain one at http://mozilla.org/MPL/2.0/. + +## Code of Conduct + +Please note that this project is released with a [Contributor Code of +Conduct][coc]. By participating in this project you agree to abide by its +terms. + +[sized-chunks]: https://github.com/bodil/sized-chunks +[coc]: https://github.com/bodil/bitmaps/blob/master/CODE_OF_CONDUCT.md diff --git a/vendor/bitmaps/src/bitmap.rs b/vendor/bitmaps/src/bitmap.rs new file mode 100644 index 000000000..483ca1485 --- /dev/null +++ b/vendor/bitmaps/src/bitmap.rs @@ -0,0 +1,510 @@ +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +use core::ops::*; + +use typenum::*; + +use crate::types::{BitOps, Bits}; + +#[cfg(feature = "std")] +use std::fmt::{Debug, Error, Formatter}; + +/// A compact array of bits. +/// +/// The type used to store the bitmap will be the minimum unsigned integer type +/// required to fit the number of bits, from `u8` to `u128`. If the size is 1, +/// `bool` is used. If the size exceeds 128, an array of `u128` will be used, +/// sized as appropriately. The maximum supported size is currently 1024, +/// represented by an array `[u128; 8]`. +pub struct Bitmap<Size: Bits> { + pub(crate) data: Size::Store, +} + +impl<Size: Bits> Clone for Bitmap<Size> { + fn clone(&self) -> Self { + Bitmap { data: self.data } + } +} + +impl<Size: Bits> Copy for Bitmap<Size> {} + +impl<Size: Bits> Default for Bitmap<Size> { + fn default() -> Self { + Bitmap { + data: Size::Store::default(), + } + } +} + +impl<Size: Bits> PartialEq for Bitmap<Size> { + fn eq(&self, other: &Self) -> bool { + self.data == other.data + } +} + +#[cfg(feature = "std")] +impl<Size: Bits> Debug for Bitmap<Size> { + fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error> { + write!(f, "{}", Size::Store::to_hex(&self.data)) + } +} + +impl<Size: Bits> Bitmap<Size> { + /// Construct a bitmap with every bit set to `false`. + #[inline] + pub fn new() -> Self { + Self::default() + } + + /// Construct a bitmap where every bit with index less than `bits` is + /// `true`, and every other bit is `false`. + #[inline] + pub fn mask(bits: usize) -> Self { + debug_assert!(bits < Size::USIZE); + Self { + data: Size::Store::make_mask(bits), + } + } + + /// Construct a bitmap from a value of the same type as its backing store. + #[inline] + pub fn from_value(data: Size::Store) -> Self { + Self { data } + } + + /// Convert this bitmap into a value of the type of its backing store. + #[inline] + pub fn into_value(self) -> Size::Store { + self.data + } + + /// Count the number of `true` bits in the bitmap. + #[inline] + pub fn len(self) -> usize { + Size::Store::len(&self.data) + } + + /// Test if the bitmap contains only `false` bits. + #[inline] + pub fn is_empty(self) -> bool { + self.first_index().is_none() + } + + /// Get the value of the bit at a given index. + #[inline] + pub fn get(self, index: usize) -> bool { + debug_assert!(index < Size::USIZE); + Size::Store::get(&self.data, index) + } + + /// Set the value of the bit at a given index. + /// + /// Returns the previous value of the bit. + #[inline] + pub fn set(&mut self, index: usize, value: bool) -> bool { + debug_assert!(index < Size::USIZE); + Size::Store::set(&mut self.data, index, value) + } + + /// Find the index of the first `true` bit in the bitmap. + #[inline] + pub fn first_index(self) -> Option<usize> { + Size::Store::first_index(&self.data) + } + + /// Invert all the bits in the bitmap. + #[inline] + pub fn invert(&mut self) { + Size::Store::invert(&mut self.data); + } +} + +impl<'a, Size: Bits> IntoIterator for &'a Bitmap<Size> { + type Item = usize; + type IntoIter = Iter<'a, Size>; + + fn into_iter(self) -> Self::IntoIter { + Iter { + index: 0, + data: self, + } + } +} + +impl<Size: Bits> BitAnd for Bitmap<Size> { + type Output = Self; + fn bitand(mut self, rhs: Self) -> Self::Output { + Size::Store::bit_and(&mut self.data, &rhs.data); + self + } +} + +impl<Size: Bits> BitOr for Bitmap<Size> { + type Output = Self; + fn bitor(mut self, rhs: Self) -> Self::Output { + Size::Store::bit_or(&mut self.data, &rhs.data); + self + } +} + +impl<Size: Bits> BitXor for Bitmap<Size> { + type Output = Self; + fn bitxor(mut self, rhs: Self) -> Self::Output { + Size::Store::bit_xor(&mut self.data, &rhs.data); + self + } +} + +impl<Size: Bits> Not for Bitmap<Size> { + type Output = Self; + fn not(mut self) -> Self::Output { + Size::Store::invert(&mut self.data); + self + } +} + +impl<Size: Bits> BitAndAssign for Bitmap<Size> { + fn bitand_assign(&mut self, rhs: Self) { + Size::Store::bit_and(&mut self.data, &rhs.data); + } +} + +impl<Size: Bits> BitOrAssign for Bitmap<Size> { + fn bitor_assign(&mut self, rhs: Self) { + Size::Store::bit_or(&mut self.data, &rhs.data); + } +} + +impl<Size: Bits> BitXorAssign for Bitmap<Size> { + fn bitxor_assign(&mut self, rhs: Self) { + Size::Store::bit_xor(&mut self.data, &rhs.data); + } +} + +impl From<[u128; 2]> for Bitmap<U256> { + fn from(data: [u128; 2]) -> Self { + Bitmap { data } + } +} + +impl From<[u128; 3]> for Bitmap<U384> { + fn from(data: [u128; 3]) -> Self { + Bitmap { data } + } +} + +impl From<[u128; 4]> for Bitmap<U512> { + fn from(data: [u128; 4]) -> Self { + Bitmap { data } + } +} + +impl From<[u128; 5]> for Bitmap<U640> { + fn from(data: [u128; 5]) -> Self { + Bitmap { data } + } +} + +impl From<[u128; 6]> for Bitmap<U768> { + fn from(data: [u128; 6]) -> Self { + Bitmap { data } + } +} + +impl From<[u128; 7]> for Bitmap<U896> { + fn from(data: [u128; 7]) -> Self { + Bitmap { data } + } +} + +impl From<[u128; 8]> for Bitmap<U1024> { + fn from(data: [u128; 8]) -> Self { + Bitmap { data } + } +} + +impl Into<[u128; 2]> for Bitmap<U256> { + fn into(self) -> [u128; 2] { + self.data + } +} + +impl Into<[u128; 3]> for Bitmap<U384> { + fn into(self) -> [u128; 3] { + self.data + } +} + +impl Into<[u128; 4]> for Bitmap<U512> { + fn into(self) -> [u128; 4] { + self.data + } +} + +impl Into<[u128; 5]> for Bitmap<U640> { + fn into(self) -> [u128; 5] { + self.data + } +} + +impl Into<[u128; 6]> for Bitmap<U768> { + fn into(self) -> [u128; 6] { + self.data + } +} + +impl Into<[u128; 7]> for Bitmap<U896> { + fn into(self) -> [u128; 7] { + self.data + } +} + +impl Into<[u128; 8]> for Bitmap<U1024> { + fn into(self) -> [u128; 8] { + self.data + } +} + +/// An iterator over the indices in a bitmap which are `true`. +/// +/// This yields a sequence of `usize` indices, not their contents (which are +/// always `true` anyway, by definition). +/// +/// # Examples +/// +/// ```rust +/// # use bitmaps::Bitmap; +/// # use typenum::U10; +/// let mut bitmap: Bitmap<U10> = Bitmap::new(); +/// bitmap.set(3, true); +/// bitmap.set(5, true); +/// bitmap.set(8, true); +/// let true_indices: Vec<usize> = bitmap.into_iter().collect(); +/// assert_eq!(vec![3, 5, 8], true_indices); +/// ``` +pub struct Iter<'a, Size: Bits> { + index: usize, + data: &'a Bitmap<Size>, +} + +impl<'a, Size: Bits> Iterator for Iter<'a, Size> { + type Item = usize; + + fn next(&mut self) -> Option<Self::Item> { + if self.index >= Size::USIZE { + return None; + } + if self.data.get(self.index) { + self.index += 1; + Some(self.index - 1) + } else { + self.index += 1; + self.next() + } + } +} + +#[cfg(any(target_arch = "x86", target_arch = "x86_64"))] +#[allow(clippy::cast_ptr_alignment)] +mod x86_arch { + use super::*; + #[cfg(target_arch = "x86")] + use core::arch::x86::*; + #[cfg(target_arch = "x86_64")] + use core::arch::x86_64::*; + + impl Bitmap<U128> { + #[target_feature(enable = "sse2")] + pub unsafe fn load_m128i(&self) -> __m128i { + _mm_loadu_si128(&self.data as *const _ as *const __m128i) + } + } + + impl Bitmap<U256> { + #[target_feature(enable = "sse2")] + pub unsafe fn load_m128i(&self) -> [__m128i; 2] { + let ptr = &self.data as *const _ as *const __m128i; + [_mm_loadu_si128(ptr), _mm_loadu_si128(ptr.add(1))] + } + + #[target_feature(enable = "avx")] + pub unsafe fn load_m256i(&self) -> __m256i { + _mm256_loadu_si256(&self.data as *const _ as *const __m256i) + } + } + + impl Bitmap<U512> { + #[target_feature(enable = "sse2")] + pub unsafe fn load_m128i(&self) -> [__m128i; 4] { + let ptr = &self.data as *const _ as *const __m128i; + [ + _mm_loadu_si128(ptr), + _mm_loadu_si128(ptr.add(1)), + _mm_loadu_si128(ptr.add(2)), + _mm_loadu_si128(ptr.add(3)), + ] + } + + #[target_feature(enable = "avx")] + pub unsafe fn load_m256i(&self) -> [__m256i; 2] { + let ptr = &self.data as *const _ as *const __m256i; + [_mm256_loadu_si256(ptr), _mm256_loadu_si256(ptr.add(1))] + } + } + + impl Bitmap<U768> { + #[target_feature(enable = "sse2")] + pub unsafe fn load_m128i(&self) -> [__m128i; 6] { + let ptr = &self.data as *const _ as *const __m128i; + [ + _mm_loadu_si128(ptr), + _mm_loadu_si128(ptr.add(1)), + _mm_loadu_si128(ptr.add(2)), + _mm_loadu_si128(ptr.add(3)), + _mm_loadu_si128(ptr.add(4)), + _mm_loadu_si128(ptr.add(5)), + ] + } + + #[target_feature(enable = "avx")] + pub unsafe fn load_m256i(&self) -> [__m256i; 3] { + let ptr = &self.data as *const _ as *const __m256i; + [ + _mm256_loadu_si256(ptr), + _mm256_loadu_si256(ptr.add(1)), + _mm256_loadu_si256(ptr.add(2)), + ] + } + } + + impl Bitmap<U1024> { + #[target_feature(enable = "sse2")] + pub unsafe fn load_m128i(&self) -> [__m128i; 8] { + let ptr = &self.data as *const _ as *const __m128i; + [ + _mm_loadu_si128(ptr), + _mm_loadu_si128(ptr.add(1)), + _mm_loadu_si128(ptr.add(2)), + _mm_loadu_si128(ptr.add(3)), + _mm_loadu_si128(ptr.add(4)), + _mm_loadu_si128(ptr.add(5)), + _mm_loadu_si128(ptr.add(6)), + _mm_loadu_si128(ptr.add(7)), + ] + } + + #[target_feature(enable = "avx")] + pub unsafe fn load_m256i(&self) -> [__m256i; 4] { + let ptr = &self.data as *const _ as *const __m256i; + [ + _mm256_loadu_si256(ptr), + _mm256_loadu_si256(ptr.add(1)), + _mm256_loadu_si256(ptr.add(2)), + _mm256_loadu_si256(ptr.add(3)), + ] + } + } + + impl From<__m128i> for Bitmap<U128> { + fn from(data: __m128i) -> Self { + Self { + data: unsafe { core::mem::transmute(data) }, + } + } + } + + impl From<__m256i> for Bitmap<U256> { + fn from(data: __m256i) -> Self { + Self { + data: unsafe { core::mem::transmute(data) }, + } + } + } + + impl Into<__m128i> for Bitmap<U128> { + fn into(self) -> __m128i { + unsafe { self.load_m128i() } + } + } + + impl Into<__m256i> for Bitmap<U256> { + fn into(self) -> __m256i { + unsafe { self.load_m256i() } + } + } + + #[cfg(test)] + mod test { + use super::*; + + struct AlignmentTester<B> + where + B: Bits, + { + _byte: u8, + bits: Bitmap<B>, + } + + #[test] + fn load_128() { + let mut t: AlignmentTester<U128> = AlignmentTester { + _byte: 0, + bits: Bitmap::new(), + }; + t.bits.set(5, true); + let m = unsafe { t.bits.load_m128i() }; + let mut bits: Bitmap<U128> = m.into(); + assert!(bits.set(5, false)); + assert!(bits.is_empty()); + } + + #[test] + fn load_256() { + let mut t: AlignmentTester<U256> = AlignmentTester { + _byte: 0, + bits: Bitmap::new(), + }; + t.bits.set(5, true); + let m = unsafe { t.bits.load_m256i() }; + let mut bits: Bitmap<U256> = m.into(); + assert!(bits.set(5, false)); + assert!(bits.is_empty()); + } + } +} + +#[cfg(test)] +mod test { + use super::*; + use proptest::collection::btree_set; + use proptest::proptest; + use typenum::{U1024, U64}; + + proptest! { + #[test] + fn get_set_and_iter_64(bits in btree_set(0..64usize, 0..64)) { + let mut bitmap = Bitmap::<U64>::new(); + for i in &bits { + bitmap.set(*i, true); + } + for i in 0..64 { + assert_eq!(bitmap.get(i), bits.contains(&i)); + } + assert!(bitmap.into_iter().eq(bits.into_iter())); + } + + #[test] + fn get_set_and_iter_1024(bits in btree_set(0..1024usize, 0..1024)) { + let mut bitmap = Bitmap::<U1024>::new(); + for i in &bits { + bitmap.set(*i, true); + } + for i in 0..1024 { + assert_eq!(bitmap.get(i), bits.contains(&i)); + } + assert!(bitmap.into_iter().eq(bits.into_iter())); + } + } +} diff --git a/vendor/bitmaps/src/lib.rs b/vendor/bitmaps/src/lib.rs new file mode 100644 index 000000000..611fb3705 --- /dev/null +++ b/vendor/bitmaps/src/lib.rs @@ -0,0 +1,62 @@ +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +#![forbid(rust_2018_idioms)] +#![deny(nonstandard_style)] +#![warn(unreachable_pub)] +#![allow(clippy::missing_safety_doc)] +#![cfg_attr(not(feature = "std"), no_std)] + +//! This crate provides the [`Bitmap`][Bitmap] type as a convenient and +//! efficient way of declaring and working with fixed size bitmaps in Rust. +//! +//! # Examples +//! +//! ```rust +//! # #[macro_use] extern crate bitmaps; +//! # use bitmaps::Bitmap; +//! # use typenum::U10; +//! let mut bitmap: Bitmap<U10> = Bitmap::new(); +//! assert_eq!(bitmap.set(5, true), false); +//! assert_eq!(bitmap.set(5, true), true); +//! assert_eq!(bitmap.get(5), true); +//! assert_eq!(bitmap.get(6), false); +//! assert_eq!(bitmap.len(), 1); +//! assert_eq!(bitmap.set(3, true), false); +//! assert_eq!(bitmap.len(), 2); +//! assert_eq!(bitmap.first_index(), Some(3)); +//! ``` +//! +//! # X86 Arch Support +//! +//! On `x86` and `x86_64` architectures, [`Bitmap`][Bitmap]s of size 256, 512, +//! 768 and 1024 gain the [`load_m256i()`][load_m256i] method, which reads the +//! bitmap into an [`__m256i`][m256i] or an array of [`__m256i`][m256i] using +//! [`_mm256_loadu_si256()`][loadu_si256]. [`Bitmap`][Bitmap]s of size 128 as +//! well as the previous gain the [`load_m128i()`][load_m128i] method, which +//! does the same for [`__m128i`][m128i]. +//! +//! In addition, [`Bitmap<U128>`][Bitmap] and [`Bitmap<U256>`][Bitmap] will have +//! `From` and `Into` implementations for [`__m128i`][m128i] and +//! [`__m256i`][m256i] respectively. +//! +//! Note that alignment is unaffected - your bitmaps will be aligned +//! appropriately for `u128`, not [`__m128i`][m128i] or [`__m256i`][m256i], +//! unless you arrange for it to be otherwise. This may affect the performance +//! of SIMD instructions. +//! +//! [Bitmap]: struct.Bitmap.html +//! [load_m128i]: struct.Bitmap.html#method.load_m128i +//! [load_m256i]: struct.Bitmap.html#method.load_m256i +//! [m128i]: https://doc.rust-lang.org/core/arch/x86_64/struct.__m128i.html +//! [m256i]: https://doc.rust-lang.org/core/arch/x86_64/struct.__m256i.html +//! [loadu_si256]: https://doc.rust-lang.org/core/arch/x86_64/fn._mm256_loadu_si256.html + +mod bitmap; +mod types; + +#[doc(inline)] +pub use crate::bitmap::{Bitmap, Iter}; +#[doc(inline)] +pub use crate::types::{BitOps, Bits}; diff --git a/vendor/bitmaps/src/types.rs b/vendor/bitmaps/src/types.rs new file mode 100644 index 000000000..981bb91c6 --- /dev/null +++ b/vendor/bitmaps/src/types.rs @@ -0,0 +1,1337 @@ +// This Source Code Form is subject to the terms of the Mozilla Public +// License, v. 2.0. If a copy of the MPL was not distributed with this +// file, You can obtain one at http://mozilla.org/MPL/2.0/. + +use core::fmt::Debug; + +use typenum::*; + +/// A trait that defines generalised operations on a `Bits::Store` type. +pub trait BitOps { + fn get(bits: &Self, index: usize) -> bool; + fn set(bits: &mut Self, index: usize, value: bool) -> bool; + fn len(bits: &Self) -> usize; + fn first_index(bits: &Self) -> Option<usize>; + fn bit_and(bits: &mut Self, other_bits: &Self); + fn bit_or(bits: &mut Self, other_bits: &Self); + fn bit_xor(bits: &mut Self, other_bits: &Self); + fn invert(bits: &mut Self); + fn make_mask(shift: usize) -> Self; + #[cfg(feature = "std")] + fn to_hex(bits: &Self) -> String; +} + +impl BitOps for bool { + #[inline] + fn get(bits: &Self, index: usize) -> bool { + debug_assert!(index == 0); + *bits + } + + #[inline] + fn set(bits: &mut Self, index: usize, value: bool) -> bool { + debug_assert!(index == 0); + core::mem::replace(bits, value) + } + + #[inline] + fn len(bits: &Self) -> usize { + if *bits { + 1 + } else { + 0 + } + } + + #[inline] + fn first_index(bits: &Self) -> Option<usize> { + if *bits { + Some(0) + } else { + None + } + } + + #[inline] + fn bit_and(bits: &mut Self, other_bits: &Self) { + *bits &= *other_bits; + } + + #[inline] + fn bit_or(bits: &mut Self, other_bits: &Self) { + *bits |= *other_bits; + } + + #[inline] + fn bit_xor(bits: &mut Self, other_bits: &Self) { + *bits ^= *other_bits; + } + + #[inline] + fn invert(bits: &mut Self) { + *bits = !*bits; + } + + #[inline] + fn make_mask(shift: usize) -> Self { + shift > 0 + } + + #[cfg(feature = "std")] + fn to_hex(bits: &Self) -> String { + if *bits { + "1".to_owned() + } else { + "0".to_owned() + } + } +} + +macro_rules! bitops_for { + ($target:ty) => { + impl BitOps for $target { + #[inline] + fn get(bits: &Self, index: usize) -> bool { + bits & (1 << index) != 0 + } + + #[inline] + fn set(bits: &mut Self, index: usize, value: bool) -> bool { + let mask = 1 << index; + let prev = *bits & mask; + if value { + *bits |= mask; + } else { + *bits &= !mask; + } + prev != 0 + } + + #[inline] + fn len(bits: &Self) -> usize { + bits.count_ones() as usize + } + + #[inline] + fn first_index(bits: &Self) -> Option<usize> { + if *bits == 0 { + None + } else { + Some(bits.trailing_zeros() as usize) + } + } + + #[inline] + fn bit_and(bits: &mut Self, other_bits: &Self) { + *bits &= *other_bits; + } + + #[inline] + fn bit_or(bits: &mut Self, other_bits: &Self) { + *bits |= *other_bits; + } + + #[inline] + fn bit_xor(bits: &mut Self, other_bits: &Self) { + *bits ^= *other_bits; + } + + #[inline] + fn invert(bits: &mut Self) { + *bits = !*bits; + } + + #[inline] + fn make_mask(shift: usize) -> Self { + (1 << shift) - 1 + } + + #[cfg(feature = "std")] + fn to_hex(bits: &Self) -> String { + format!("{:x}", bits) + } + } + }; +} + +macro_rules! bitops_for_big { + ($words:expr) => { + impl BitOps for [u128; $words] { + #[inline] + fn get(bits: &Self, index: usize) -> bool { + let word_index = index / 128; + let index = index & 127; + bits[word_index] & (1 << index) != 0 + } + + #[inline] + fn set(bits: &mut Self, index: usize, value: bool) -> bool { + let word_index = index / 128; + let index = index & 127; + + let mask = 1 << (index & 127); + let bits = &mut bits[word_index]; + let prev = *bits & mask; + if value { + *bits |= mask; + } else { + *bits &= !mask; + } + prev != 0 + } + + fn make_mask(shift: usize) -> Self { + let word_index = shift / 128; + let index = shift & 127; + let mut out = [0; $words]; + for (chunk_index, chunk) in out.iter_mut().enumerate() { + if chunk_index < word_index { + *chunk = !0u128; + } else if chunk_index == word_index { + *chunk = (1 << index) - 1; + } else { + return out; + } + } + out + } + + #[inline] + fn len(bits: &Self) -> usize { + bits.iter().fold(0, |acc, next| acc + next.count_ones()) as usize + } + + #[inline] + fn first_index(bits: &Self) -> Option<usize> { + for (index, part) in bits.iter().enumerate() { + if *part != 0u128 { + return Some(part.trailing_zeros() as usize + (128 * index)); + } + } + None + } + + #[inline] + fn bit_and(bits: &mut Self, other_bits: &Self) { + for (left, right) in bits.iter_mut().zip(other_bits.iter()) { + *left &= *right; + } + } + + #[inline] + fn bit_or(bits: &mut Self, other_bits: &Self) { + for (left, right) in bits.iter_mut().zip(other_bits.iter()) { + *left |= *right; + } + } + + #[inline] + fn bit_xor(bits: &mut Self, other_bits: &Self) { + for (left, right) in bits.iter_mut().zip(other_bits.iter()) { + *left ^= *right; + } + } + + #[inline] + fn invert(bits: &mut Self) { + for chunk in bits.iter_mut() { + *chunk = !*chunk; + } + } + + #[cfg(feature = "std")] + fn to_hex(bits: &Self) -> String { + let mut out = String::new(); + for chunk in bits { + out += &format!("{:x}", chunk); + } + out + } + } + }; +} + +bitops_for!(u8); +bitops_for!(u16); +bitops_for!(u32); +bitops_for!(u64); +bitops_for!(u128); + +bitops_for_big!(2); +bitops_for_big!(3); +bitops_for_big!(4); +bitops_for_big!(5); +bitops_for_big!(6); +bitops_for_big!(7); +bitops_for_big!(8); + +/// A type level number signifying the number of bits in a bitmap. +/// +/// This trait is implemented for type level numbers from `U1` to `U1024`. +/// +/// # Examples +/// +/// ```rust +/// # #[macro_use] extern crate bitmaps; +/// # use bitmaps::Bits; +/// # use typenum::U10; +/// assert_eq!( +/// std::mem::size_of::<<U10 as Bits>::Store>(), +/// std::mem::size_of::<u16>() +/// ); +/// ``` +pub trait Bits: Unsigned { + /// A primitive integer type suitable for storing this many bits. + type Store: BitOps + Default + Copy + PartialEq + Debug; +} + +impl Bits for U1 { + type Store = bool; +} + +macro_rules! bits_for { + ($num:ty, $result:ty) => { + impl Bits for $num { + type Store = $result; + } + }; +} + +macro_rules! bits_for_big { + ($num:ty, $words:expr) => { + impl Bits for $num { + type Store = [u128; $words]; + } + }; +} + +bits_for!(U2, u8); +bits_for!(U3, u8); +bits_for!(U4, u8); +bits_for!(U5, u8); +bits_for!(U6, u8); +bits_for!(U7, u8); +bits_for!(U8, u8); +bits_for!(U9, u16); +bits_for!(U10, u16); +bits_for!(U11, u16); +bits_for!(U12, u16); +bits_for!(U13, u16); +bits_for!(U14, u16); +bits_for!(U15, u16); +bits_for!(U16, u16); +bits_for!(U17, u32); +bits_for!(U18, u32); +bits_for!(U19, u32); +bits_for!(U20, u32); +bits_for!(U21, u32); +bits_for!(U22, u32); +bits_for!(U23, u32); +bits_for!(U24, u32); +bits_for!(U25, u32); +bits_for!(U26, u32); +bits_for!(U27, u32); +bits_for!(U28, u32); +bits_for!(U29, u32); +bits_for!(U30, u32); +bits_for!(U31, u32); +bits_for!(U32, u32); +bits_for!(U33, u64); +bits_for!(U34, u64); +bits_for!(U35, u64); +bits_for!(U36, u64); +bits_for!(U37, u64); +bits_for!(U38, u64); +bits_for!(U39, u64); +bits_for!(U40, u64); +bits_for!(U41, u64); +bits_for!(U42, u64); +bits_for!(U43, u64); +bits_for!(U44, u64); +bits_for!(U45, u64); +bits_for!(U46, u64); +bits_for!(U47, u64); +bits_for!(U48, u64); +bits_for!(U49, u64); +bits_for!(U50, u64); +bits_for!(U51, u64); +bits_for!(U52, u64); +bits_for!(U53, u64); +bits_for!(U54, u64); +bits_for!(U55, u64); +bits_for!(U56, u64); +bits_for!(U57, u64); +bits_for!(U58, u64); +bits_for!(U59, u64); +bits_for!(U60, u64); +bits_for!(U61, u64); +bits_for!(U62, u64); +bits_for!(U63, u64); +bits_for!(U64, u64); +bits_for!(U65, u128); +bits_for!(U66, u128); +bits_for!(U67, u128); +bits_for!(U68, u128); +bits_for!(U69, u128); +bits_for!(U70, u128); +bits_for!(U71, u128); +bits_for!(U72, u128); +bits_for!(U73, u128); +bits_for!(U74, u128); +bits_for!(U75, u128); +bits_for!(U76, u128); +bits_for!(U77, u128); +bits_for!(U78, u128); +bits_for!(U79, u128); +bits_for!(U80, u128); +bits_for!(U81, u128); +bits_for!(U82, u128); +bits_for!(U83, u128); +bits_for!(U84, u128); +bits_for!(U85, u128); +bits_for!(U86, u128); +bits_for!(U87, u128); +bits_for!(U88, u128); +bits_for!(U89, u128); +bits_for!(U90, u128); +bits_for!(U91, u128); +bits_for!(U92, u128); +bits_for!(U93, u128); +bits_for!(U94, u128); +bits_for!(U95, u128); +bits_for!(U96, u128); +bits_for!(U97, u128); +bits_for!(U98, u128); +bits_for!(U99, u128); +bits_for!(U100, u128); +bits_for!(U101, u128); +bits_for!(U102, u128); +bits_for!(U103, u128); +bits_for!(U104, u128); +bits_for!(U105, u128); +bits_for!(U106, u128); +bits_for!(U107, u128); +bits_for!(U108, u128); +bits_for!(U109, u128); +bits_for!(U110, u128); +bits_for!(U111, u128); +bits_for!(U112, u128); +bits_for!(U113, u128); +bits_for!(U114, u128); +bits_for!(U115, u128); +bits_for!(U116, u128); +bits_for!(U117, u128); +bits_for!(U118, u128); +bits_for!(U119, u128); +bits_for!(U120, u128); +bits_for!(U121, u128); +bits_for!(U122, u128); +bits_for!(U123, u128); +bits_for!(U124, u128); +bits_for!(U125, u128); +bits_for!(U126, u128); +bits_for!(U127, u128); +bits_for!(U128, u128); + +bits_for_big!(U129, 2); +bits_for_big!(U130, 2); +bits_for_big!(U131, 2); +bits_for_big!(U132, 2); +bits_for_big!(U133, 2); +bits_for_big!(U134, 2); +bits_for_big!(U135, 2); +bits_for_big!(U136, 2); +bits_for_big!(U137, 2); +bits_for_big!(U138, 2); +bits_for_big!(U139, 2); +bits_for_big!(U140, 2); +bits_for_big!(U141, 2); +bits_for_big!(U142, 2); +bits_for_big!(U143, 2); +bits_for_big!(U144, 2); +bits_for_big!(U145, 2); +bits_for_big!(U146, 2); +bits_for_big!(U147, 2); +bits_for_big!(U148, 2); +bits_for_big!(U149, 2); +bits_for_big!(U150, 2); +bits_for_big!(U151, 2); +bits_for_big!(U152, 2); +bits_for_big!(U153, 2); +bits_for_big!(U154, 2); +bits_for_big!(U155, 2); +bits_for_big!(U156, 2); +bits_for_big!(U157, 2); +bits_for_big!(U158, 2); +bits_for_big!(U159, 2); +bits_for_big!(U160, 2); +bits_for_big!(U161, 2); +bits_for_big!(U162, 2); +bits_for_big!(U163, 2); +bits_for_big!(U164, 2); +bits_for_big!(U165, 2); +bits_for_big!(U166, 2); +bits_for_big!(U167, 2); +bits_for_big!(U168, 2); +bits_for_big!(U169, 2); +bits_for_big!(U170, 2); +bits_for_big!(U171, 2); +bits_for_big!(U172, 2); +bits_for_big!(U173, 2); +bits_for_big!(U174, 2); +bits_for_big!(U175, 2); +bits_for_big!(U176, 2); +bits_for_big!(U177, 2); +bits_for_big!(U178, 2); +bits_for_big!(U179, 2); +bits_for_big!(U180, 2); +bits_for_big!(U181, 2); +bits_for_big!(U182, 2); +bits_for_big!(U183, 2); +bits_for_big!(U184, 2); +bits_for_big!(U185, 2); +bits_for_big!(U186, 2); +bits_for_big!(U187, 2); +bits_for_big!(U188, 2); +bits_for_big!(U189, 2); +bits_for_big!(U190, 2); +bits_for_big!(U191, 2); +bits_for_big!(U192, 2); +bits_for_big!(U193, 2); +bits_for_big!(U194, 2); +bits_for_big!(U195, 2); +bits_for_big!(U196, 2); +bits_for_big!(U197, 2); +bits_for_big!(U198, 2); +bits_for_big!(U199, 2); +bits_for_big!(U200, 2); +bits_for_big!(U201, 2); +bits_for_big!(U202, 2); +bits_for_big!(U203, 2); +bits_for_big!(U204, 2); +bits_for_big!(U205, 2); +bits_for_big!(U206, 2); +bits_for_big!(U207, 2); +bits_for_big!(U208, 2); +bits_for_big!(U209, 2); +bits_for_big!(U210, 2); +bits_for_big!(U211, 2); +bits_for_big!(U212, 2); +bits_for_big!(U213, 2); +bits_for_big!(U214, 2); +bits_for_big!(U215, 2); +bits_for_big!(U216, 2); +bits_for_big!(U217, 2); +bits_for_big!(U218, 2); +bits_for_big!(U219, 2); +bits_for_big!(U220, 2); +bits_for_big!(U221, 2); +bits_for_big!(U222, 2); +bits_for_big!(U223, 2); +bits_for_big!(U224, 2); +bits_for_big!(U225, 2); +bits_for_big!(U226, 2); +bits_for_big!(U227, 2); +bits_for_big!(U228, 2); +bits_for_big!(U229, 2); +bits_for_big!(U230, 2); +bits_for_big!(U231, 2); +bits_for_big!(U232, 2); +bits_for_big!(U233, 2); +bits_for_big!(U234, 2); +bits_for_big!(U235, 2); +bits_for_big!(U236, 2); +bits_for_big!(U237, 2); +bits_for_big!(U238, 2); +bits_for_big!(U239, 2); +bits_for_big!(U240, 2); +bits_for_big!(U241, 2); +bits_for_big!(U242, 2); +bits_for_big!(U243, 2); +bits_for_big!(U244, 2); +bits_for_big!(U245, 2); +bits_for_big!(U246, 2); +bits_for_big!(U247, 2); +bits_for_big!(U248, 2); +bits_for_big!(U249, 2); +bits_for_big!(U250, 2); +bits_for_big!(U251, 2); +bits_for_big!(U252, 2); +bits_for_big!(U253, 2); +bits_for_big!(U254, 2); +bits_for_big!(U255, 2); +bits_for_big!(U256, 2); + +bits_for_big!(U257, 3); +bits_for_big!(U258, 3); +bits_for_big!(U259, 3); +bits_for_big!(U260, 3); +bits_for_big!(U261, 3); +bits_for_big!(U262, 3); +bits_for_big!(U263, 3); +bits_for_big!(U264, 3); +bits_for_big!(U265, 3); +bits_for_big!(U266, 3); +bits_for_big!(U267, 3); +bits_for_big!(U268, 3); +bits_for_big!(U269, 3); +bits_for_big!(U270, 3); +bits_for_big!(U271, 3); +bits_for_big!(U272, 3); +bits_for_big!(U273, 3); +bits_for_big!(U274, 3); +bits_for_big!(U275, 3); +bits_for_big!(U276, 3); +bits_for_big!(U277, 3); +bits_for_big!(U278, 3); +bits_for_big!(U279, 3); +bits_for_big!(U280, 3); +bits_for_big!(U281, 3); +bits_for_big!(U282, 3); +bits_for_big!(U283, 3); +bits_for_big!(U284, 3); +bits_for_big!(U285, 3); +bits_for_big!(U286, 3); +bits_for_big!(U287, 3); +bits_for_big!(U288, 3); +bits_for_big!(U289, 3); +bits_for_big!(U290, 3); +bits_for_big!(U291, 3); +bits_for_big!(U292, 3); +bits_for_big!(U293, 3); +bits_for_big!(U294, 3); +bits_for_big!(U295, 3); +bits_for_big!(U296, 3); +bits_for_big!(U297, 3); +bits_for_big!(U298, 3); +bits_for_big!(U299, 3); +bits_for_big!(U300, 3); +bits_for_big!(U301, 3); +bits_for_big!(U302, 3); +bits_for_big!(U303, 3); +bits_for_big!(U304, 3); +bits_for_big!(U305, 3); +bits_for_big!(U306, 3); +bits_for_big!(U307, 3); +bits_for_big!(U308, 3); +bits_for_big!(U309, 3); +bits_for_big!(U310, 3); +bits_for_big!(U311, 3); +bits_for_big!(U312, 3); +bits_for_big!(U313, 3); +bits_for_big!(U314, 3); +bits_for_big!(U315, 3); +bits_for_big!(U316, 3); +bits_for_big!(U317, 3); +bits_for_big!(U318, 3); +bits_for_big!(U319, 3); +bits_for_big!(U320, 3); +bits_for_big!(U321, 3); +bits_for_big!(U322, 3); +bits_for_big!(U323, 3); +bits_for_big!(U324, 3); +bits_for_big!(U325, 3); +bits_for_big!(U326, 3); +bits_for_big!(U327, 3); +bits_for_big!(U328, 3); +bits_for_big!(U329, 3); +bits_for_big!(U330, 3); +bits_for_big!(U331, 3); +bits_for_big!(U332, 3); +bits_for_big!(U333, 3); +bits_for_big!(U334, 3); +bits_for_big!(U335, 3); +bits_for_big!(U336, 3); +bits_for_big!(U337, 3); +bits_for_big!(U338, 3); +bits_for_big!(U339, 3); +bits_for_big!(U340, 3); +bits_for_big!(U341, 3); +bits_for_big!(U342, 3); +bits_for_big!(U343, 3); +bits_for_big!(U344, 3); +bits_for_big!(U345, 3); +bits_for_big!(U346, 3); +bits_for_big!(U347, 3); +bits_for_big!(U348, 3); +bits_for_big!(U349, 3); +bits_for_big!(U350, 3); +bits_for_big!(U351, 3); +bits_for_big!(U352, 3); +bits_for_big!(U353, 3); +bits_for_big!(U354, 3); +bits_for_big!(U355, 3); +bits_for_big!(U356, 3); +bits_for_big!(U357, 3); +bits_for_big!(U358, 3); +bits_for_big!(U359, 3); +bits_for_big!(U360, 3); +bits_for_big!(U361, 3); +bits_for_big!(U362, 3); +bits_for_big!(U363, 3); +bits_for_big!(U364, 3); +bits_for_big!(U365, 3); +bits_for_big!(U366, 3); +bits_for_big!(U367, 3); +bits_for_big!(U368, 3); +bits_for_big!(U369, 3); +bits_for_big!(U370, 3); +bits_for_big!(U371, 3); +bits_for_big!(U372, 3); +bits_for_big!(U373, 3); +bits_for_big!(U374, 3); +bits_for_big!(U375, 3); +bits_for_big!(U376, 3); +bits_for_big!(U377, 3); +bits_for_big!(U378, 3); +bits_for_big!(U379, 3); +bits_for_big!(U380, 3); +bits_for_big!(U381, 3); +bits_for_big!(U382, 3); +bits_for_big!(U383, 3); +bits_for_big!(U384, 3); + +bits_for_big!(U385, 4); +bits_for_big!(U386, 4); +bits_for_big!(U387, 4); +bits_for_big!(U388, 4); +bits_for_big!(U389, 4); +bits_for_big!(U390, 4); +bits_for_big!(U391, 4); +bits_for_big!(U392, 4); +bits_for_big!(U393, 4); +bits_for_big!(U394, 4); +bits_for_big!(U395, 4); +bits_for_big!(U396, 4); +bits_for_big!(U397, 4); +bits_for_big!(U398, 4); +bits_for_big!(U399, 4); +bits_for_big!(U400, 4); +bits_for_big!(U401, 4); +bits_for_big!(U402, 4); +bits_for_big!(U403, 4); +bits_for_big!(U404, 4); +bits_for_big!(U405, 4); +bits_for_big!(U406, 4); +bits_for_big!(U407, 4); +bits_for_big!(U408, 4); +bits_for_big!(U409, 4); +bits_for_big!(U410, 4); +bits_for_big!(U411, 4); +bits_for_big!(U412, 4); +bits_for_big!(U413, 4); +bits_for_big!(U414, 4); +bits_for_big!(U415, 4); +bits_for_big!(U416, 4); +bits_for_big!(U417, 4); +bits_for_big!(U418, 4); +bits_for_big!(U419, 4); +bits_for_big!(U420, 4); +bits_for_big!(U421, 4); +bits_for_big!(U422, 4); +bits_for_big!(U423, 4); +bits_for_big!(U424, 4); +bits_for_big!(U425, 4); +bits_for_big!(U426, 4); +bits_for_big!(U427, 4); +bits_for_big!(U428, 4); +bits_for_big!(U429, 4); +bits_for_big!(U430, 4); +bits_for_big!(U431, 4); +bits_for_big!(U432, 4); +bits_for_big!(U433, 4); +bits_for_big!(U434, 4); +bits_for_big!(U435, 4); +bits_for_big!(U436, 4); +bits_for_big!(U437, 4); +bits_for_big!(U438, 4); +bits_for_big!(U439, 4); +bits_for_big!(U440, 4); +bits_for_big!(U441, 4); +bits_for_big!(U442, 4); +bits_for_big!(U443, 4); +bits_for_big!(U444, 4); +bits_for_big!(U445, 4); +bits_for_big!(U446, 4); +bits_for_big!(U447, 4); +bits_for_big!(U448, 4); +bits_for_big!(U449, 4); +bits_for_big!(U450, 4); +bits_for_big!(U451, 4); +bits_for_big!(U452, 4); +bits_for_big!(U453, 4); +bits_for_big!(U454, 4); +bits_for_big!(U455, 4); +bits_for_big!(U456, 4); +bits_for_big!(U457, 4); +bits_for_big!(U458, 4); +bits_for_big!(U459, 4); +bits_for_big!(U460, 4); +bits_for_big!(U461, 4); +bits_for_big!(U462, 4); +bits_for_big!(U463, 4); +bits_for_big!(U464, 4); +bits_for_big!(U465, 4); +bits_for_big!(U466, 4); +bits_for_big!(U467, 4); +bits_for_big!(U468, 4); +bits_for_big!(U469, 4); +bits_for_big!(U470, 4); +bits_for_big!(U471, 4); +bits_for_big!(U472, 4); +bits_for_big!(U473, 4); +bits_for_big!(U474, 4); +bits_for_big!(U475, 4); +bits_for_big!(U476, 4); +bits_for_big!(U477, 4); +bits_for_big!(U478, 4); +bits_for_big!(U479, 4); +bits_for_big!(U480, 4); +bits_for_big!(U481, 4); +bits_for_big!(U482, 4); +bits_for_big!(U483, 4); +bits_for_big!(U484, 4); +bits_for_big!(U485, 4); +bits_for_big!(U486, 4); +bits_for_big!(U487, 4); +bits_for_big!(U488, 4); +bits_for_big!(U489, 4); +bits_for_big!(U490, 4); +bits_for_big!(U491, 4); +bits_for_big!(U492, 4); +bits_for_big!(U493, 4); +bits_for_big!(U494, 4); +bits_for_big!(U495, 4); +bits_for_big!(U496, 4); +bits_for_big!(U497, 4); +bits_for_big!(U498, 4); +bits_for_big!(U499, 4); +bits_for_big!(U500, 4); +bits_for_big!(U501, 4); +bits_for_big!(U502, 4); +bits_for_big!(U503, 4); +bits_for_big!(U504, 4); +bits_for_big!(U505, 4); +bits_for_big!(U506, 4); +bits_for_big!(U507, 4); +bits_for_big!(U508, 4); +bits_for_big!(U509, 4); +bits_for_big!(U510, 4); +bits_for_big!(U511, 4); +bits_for_big!(U512, 4); + +bits_for_big!(U513, 5); +bits_for_big!(U514, 5); +bits_for_big!(U515, 5); +bits_for_big!(U516, 5); +bits_for_big!(U517, 5); +bits_for_big!(U518, 5); +bits_for_big!(U519, 5); +bits_for_big!(U520, 5); +bits_for_big!(U521, 5); +bits_for_big!(U522, 5); +bits_for_big!(U523, 5); +bits_for_big!(U524, 5); +bits_for_big!(U525, 5); +bits_for_big!(U526, 5); +bits_for_big!(U527, 5); +bits_for_big!(U528, 5); +bits_for_big!(U529, 5); +bits_for_big!(U530, 5); +bits_for_big!(U531, 5); +bits_for_big!(U532, 5); +bits_for_big!(U533, 5); +bits_for_big!(U534, 5); +bits_for_big!(U535, 5); +bits_for_big!(U536, 5); +bits_for_big!(U537, 5); +bits_for_big!(U538, 5); +bits_for_big!(U539, 5); +bits_for_big!(U540, 5); +bits_for_big!(U541, 5); +bits_for_big!(U542, 5); +bits_for_big!(U543, 5); +bits_for_big!(U544, 5); +bits_for_big!(U545, 5); +bits_for_big!(U546, 5); +bits_for_big!(U547, 5); +bits_for_big!(U548, 5); +bits_for_big!(U549, 5); +bits_for_big!(U550, 5); +bits_for_big!(U551, 5); +bits_for_big!(U552, 5); +bits_for_big!(U553, 5); +bits_for_big!(U554, 5); +bits_for_big!(U555, 5); +bits_for_big!(U556, 5); +bits_for_big!(U557, 5); +bits_for_big!(U558, 5); +bits_for_big!(U559, 5); +bits_for_big!(U560, 5); +bits_for_big!(U561, 5); +bits_for_big!(U562, 5); +bits_for_big!(U563, 5); +bits_for_big!(U564, 5); +bits_for_big!(U565, 5); +bits_for_big!(U566, 5); +bits_for_big!(U567, 5); +bits_for_big!(U568, 5); +bits_for_big!(U569, 5); +bits_for_big!(U570, 5); +bits_for_big!(U571, 5); +bits_for_big!(U572, 5); +bits_for_big!(U573, 5); +bits_for_big!(U574, 5); +bits_for_big!(U575, 5); +bits_for_big!(U576, 5); +bits_for_big!(U577, 5); +bits_for_big!(U578, 5); +bits_for_big!(U579, 5); +bits_for_big!(U580, 5); +bits_for_big!(U581, 5); +bits_for_big!(U582, 5); +bits_for_big!(U583, 5); +bits_for_big!(U584, 5); +bits_for_big!(U585, 5); +bits_for_big!(U586, 5); +bits_for_big!(U587, 5); +bits_for_big!(U588, 5); +bits_for_big!(U589, 5); +bits_for_big!(U590, 5); +bits_for_big!(U591, 5); +bits_for_big!(U592, 5); +bits_for_big!(U593, 5); +bits_for_big!(U594, 5); +bits_for_big!(U595, 5); +bits_for_big!(U596, 5); +bits_for_big!(U597, 5); +bits_for_big!(U598, 5); +bits_for_big!(U599, 5); +bits_for_big!(U600, 5); +bits_for_big!(U601, 5); +bits_for_big!(U602, 5); +bits_for_big!(U603, 5); +bits_for_big!(U604, 5); +bits_for_big!(U605, 5); +bits_for_big!(U606, 5); +bits_for_big!(U607, 5); +bits_for_big!(U608, 5); +bits_for_big!(U609, 5); +bits_for_big!(U610, 5); +bits_for_big!(U611, 5); +bits_for_big!(U612, 5); +bits_for_big!(U613, 5); +bits_for_big!(U614, 5); +bits_for_big!(U615, 5); +bits_for_big!(U616, 5); +bits_for_big!(U617, 5); +bits_for_big!(U618, 5); +bits_for_big!(U619, 5); +bits_for_big!(U620, 5); +bits_for_big!(U621, 5); +bits_for_big!(U622, 5); +bits_for_big!(U623, 5); +bits_for_big!(U624, 5); +bits_for_big!(U625, 5); +bits_for_big!(U626, 5); +bits_for_big!(U627, 5); +bits_for_big!(U628, 5); +bits_for_big!(U629, 5); +bits_for_big!(U630, 5); +bits_for_big!(U631, 5); +bits_for_big!(U632, 5); +bits_for_big!(U633, 5); +bits_for_big!(U634, 5); +bits_for_big!(U635, 5); +bits_for_big!(U636, 5); +bits_for_big!(U637, 5); +bits_for_big!(U638, 5); +bits_for_big!(U639, 5); +bits_for_big!(U640, 5); + +bits_for_big!(U641, 6); +bits_for_big!(U642, 6); +bits_for_big!(U643, 6); +bits_for_big!(U644, 6); +bits_for_big!(U645, 6); +bits_for_big!(U646, 6); +bits_for_big!(U647, 6); +bits_for_big!(U648, 6); +bits_for_big!(U649, 6); +bits_for_big!(U650, 6); +bits_for_big!(U651, 6); +bits_for_big!(U652, 6); +bits_for_big!(U653, 6); +bits_for_big!(U654, 6); +bits_for_big!(U655, 6); +bits_for_big!(U656, 6); +bits_for_big!(U657, 6); +bits_for_big!(U658, 6); +bits_for_big!(U659, 6); +bits_for_big!(U660, 6); +bits_for_big!(U661, 6); +bits_for_big!(U662, 6); +bits_for_big!(U663, 6); +bits_for_big!(U664, 6); +bits_for_big!(U665, 6); +bits_for_big!(U666, 6); +bits_for_big!(U667, 6); +bits_for_big!(U668, 6); +bits_for_big!(U669, 6); +bits_for_big!(U670, 6); +bits_for_big!(U671, 6); +bits_for_big!(U672, 6); +bits_for_big!(U673, 6); +bits_for_big!(U674, 6); +bits_for_big!(U675, 6); +bits_for_big!(U676, 6); +bits_for_big!(U677, 6); +bits_for_big!(U678, 6); +bits_for_big!(U679, 6); +bits_for_big!(U680, 6); +bits_for_big!(U681, 6); +bits_for_big!(U682, 6); +bits_for_big!(U683, 6); +bits_for_big!(U684, 6); +bits_for_big!(U685, 6); +bits_for_big!(U686, 6); +bits_for_big!(U687, 6); +bits_for_big!(U688, 6); +bits_for_big!(U689, 6); +bits_for_big!(U690, 6); +bits_for_big!(U691, 6); +bits_for_big!(U692, 6); +bits_for_big!(U693, 6); +bits_for_big!(U694, 6); +bits_for_big!(U695, 6); +bits_for_big!(U696, 6); +bits_for_big!(U697, 6); +bits_for_big!(U698, 6); +bits_for_big!(U699, 6); +bits_for_big!(U700, 6); +bits_for_big!(U701, 6); +bits_for_big!(U702, 6); +bits_for_big!(U703, 6); +bits_for_big!(U704, 6); +bits_for_big!(U705, 6); +bits_for_big!(U706, 6); +bits_for_big!(U707, 6); +bits_for_big!(U708, 6); +bits_for_big!(U709, 6); +bits_for_big!(U710, 6); +bits_for_big!(U711, 6); +bits_for_big!(U712, 6); +bits_for_big!(U713, 6); +bits_for_big!(U714, 6); +bits_for_big!(U715, 6); +bits_for_big!(U716, 6); +bits_for_big!(U717, 6); +bits_for_big!(U718, 6); +bits_for_big!(U719, 6); +bits_for_big!(U720, 6); +bits_for_big!(U721, 6); +bits_for_big!(U722, 6); +bits_for_big!(U723, 6); +bits_for_big!(U724, 6); +bits_for_big!(U725, 6); +bits_for_big!(U726, 6); +bits_for_big!(U727, 6); +bits_for_big!(U728, 6); +bits_for_big!(U729, 6); +bits_for_big!(U730, 6); +bits_for_big!(U731, 6); +bits_for_big!(U732, 6); +bits_for_big!(U733, 6); +bits_for_big!(U734, 6); +bits_for_big!(U735, 6); +bits_for_big!(U736, 6); +bits_for_big!(U737, 6); +bits_for_big!(U738, 6); +bits_for_big!(U739, 6); +bits_for_big!(U740, 6); +bits_for_big!(U741, 6); +bits_for_big!(U742, 6); +bits_for_big!(U743, 6); +bits_for_big!(U744, 6); +bits_for_big!(U745, 6); +bits_for_big!(U746, 6); +bits_for_big!(U747, 6); +bits_for_big!(U748, 6); +bits_for_big!(U749, 6); +bits_for_big!(U750, 6); +bits_for_big!(U751, 6); +bits_for_big!(U752, 6); +bits_for_big!(U753, 6); +bits_for_big!(U754, 6); +bits_for_big!(U755, 6); +bits_for_big!(U756, 6); +bits_for_big!(U757, 6); +bits_for_big!(U758, 6); +bits_for_big!(U759, 6); +bits_for_big!(U760, 6); +bits_for_big!(U761, 6); +bits_for_big!(U762, 6); +bits_for_big!(U763, 6); +bits_for_big!(U764, 6); +bits_for_big!(U765, 6); +bits_for_big!(U766, 6); +bits_for_big!(U767, 6); +bits_for_big!(U768, 6); + +bits_for_big!(U769, 7); +bits_for_big!(U770, 7); +bits_for_big!(U771, 7); +bits_for_big!(U772, 7); +bits_for_big!(U773, 7); +bits_for_big!(U774, 7); +bits_for_big!(U775, 7); +bits_for_big!(U776, 7); +bits_for_big!(U777, 7); +bits_for_big!(U778, 7); +bits_for_big!(U779, 7); +bits_for_big!(U780, 7); +bits_for_big!(U781, 7); +bits_for_big!(U782, 7); +bits_for_big!(U783, 7); +bits_for_big!(U784, 7); +bits_for_big!(U785, 7); +bits_for_big!(U786, 7); +bits_for_big!(U787, 7); +bits_for_big!(U788, 7); +bits_for_big!(U789, 7); +bits_for_big!(U790, 7); +bits_for_big!(U791, 7); +bits_for_big!(U792, 7); +bits_for_big!(U793, 7); +bits_for_big!(U794, 7); +bits_for_big!(U795, 7); +bits_for_big!(U796, 7); +bits_for_big!(U797, 7); +bits_for_big!(U798, 7); +bits_for_big!(U799, 7); +bits_for_big!(U800, 7); +bits_for_big!(U801, 7); +bits_for_big!(U802, 7); +bits_for_big!(U803, 7); +bits_for_big!(U804, 7); +bits_for_big!(U805, 7); +bits_for_big!(U806, 7); +bits_for_big!(U807, 7); +bits_for_big!(U808, 7); +bits_for_big!(U809, 7); +bits_for_big!(U810, 7); +bits_for_big!(U811, 7); +bits_for_big!(U812, 7); +bits_for_big!(U813, 7); +bits_for_big!(U814, 7); +bits_for_big!(U815, 7); +bits_for_big!(U816, 7); +bits_for_big!(U817, 7); +bits_for_big!(U818, 7); +bits_for_big!(U819, 7); +bits_for_big!(U820, 7); +bits_for_big!(U821, 7); +bits_for_big!(U822, 7); +bits_for_big!(U823, 7); +bits_for_big!(U824, 7); +bits_for_big!(U825, 7); +bits_for_big!(U826, 7); +bits_for_big!(U827, 7); +bits_for_big!(U828, 7); +bits_for_big!(U829, 7); +bits_for_big!(U830, 7); +bits_for_big!(U831, 7); +bits_for_big!(U832, 7); +bits_for_big!(U833, 7); +bits_for_big!(U834, 7); +bits_for_big!(U835, 7); +bits_for_big!(U836, 7); +bits_for_big!(U837, 7); +bits_for_big!(U838, 7); +bits_for_big!(U839, 7); +bits_for_big!(U840, 7); +bits_for_big!(U841, 7); +bits_for_big!(U842, 7); +bits_for_big!(U843, 7); +bits_for_big!(U844, 7); +bits_for_big!(U845, 7); +bits_for_big!(U846, 7); +bits_for_big!(U847, 7); +bits_for_big!(U848, 7); +bits_for_big!(U849, 7); +bits_for_big!(U850, 7); +bits_for_big!(U851, 7); +bits_for_big!(U852, 7); +bits_for_big!(U853, 7); +bits_for_big!(U854, 7); +bits_for_big!(U855, 7); +bits_for_big!(U856, 7); +bits_for_big!(U857, 7); +bits_for_big!(U858, 7); +bits_for_big!(U859, 7); +bits_for_big!(U860, 7); +bits_for_big!(U861, 7); +bits_for_big!(U862, 7); +bits_for_big!(U863, 7); +bits_for_big!(U864, 7); +bits_for_big!(U865, 7); +bits_for_big!(U866, 7); +bits_for_big!(U867, 7); +bits_for_big!(U868, 7); +bits_for_big!(U869, 7); +bits_for_big!(U870, 7); +bits_for_big!(U871, 7); +bits_for_big!(U872, 7); +bits_for_big!(U873, 7); +bits_for_big!(U874, 7); +bits_for_big!(U875, 7); +bits_for_big!(U876, 7); +bits_for_big!(U877, 7); +bits_for_big!(U878, 7); +bits_for_big!(U879, 7); +bits_for_big!(U880, 7); +bits_for_big!(U881, 7); +bits_for_big!(U882, 7); +bits_for_big!(U883, 7); +bits_for_big!(U884, 7); +bits_for_big!(U885, 7); +bits_for_big!(U886, 7); +bits_for_big!(U887, 7); +bits_for_big!(U888, 7); +bits_for_big!(U889, 7); +bits_for_big!(U890, 7); +bits_for_big!(U891, 7); +bits_for_big!(U892, 7); +bits_for_big!(U893, 7); +bits_for_big!(U894, 7); +bits_for_big!(U895, 7); +bits_for_big!(U896, 7); + +bits_for_big!(U897, 8); +bits_for_big!(U898, 8); +bits_for_big!(U899, 8); +bits_for_big!(U900, 8); +bits_for_big!(U901, 8); +bits_for_big!(U902, 8); +bits_for_big!(U903, 8); +bits_for_big!(U904, 8); +bits_for_big!(U905, 8); +bits_for_big!(U906, 8); +bits_for_big!(U907, 8); +bits_for_big!(U908, 8); +bits_for_big!(U909, 8); +bits_for_big!(U910, 8); +bits_for_big!(U911, 8); +bits_for_big!(U912, 8); +bits_for_big!(U913, 8); +bits_for_big!(U914, 8); +bits_for_big!(U915, 8); +bits_for_big!(U916, 8); +bits_for_big!(U917, 8); +bits_for_big!(U918, 8); +bits_for_big!(U919, 8); +bits_for_big!(U920, 8); +bits_for_big!(U921, 8); +bits_for_big!(U922, 8); +bits_for_big!(U923, 8); +bits_for_big!(U924, 8); +bits_for_big!(U925, 8); +bits_for_big!(U926, 8); +bits_for_big!(U927, 8); +bits_for_big!(U928, 8); +bits_for_big!(U929, 8); +bits_for_big!(U930, 8); +bits_for_big!(U931, 8); +bits_for_big!(U932, 8); +bits_for_big!(U933, 8); +bits_for_big!(U934, 8); +bits_for_big!(U935, 8); +bits_for_big!(U936, 8); +bits_for_big!(U937, 8); +bits_for_big!(U938, 8); +bits_for_big!(U939, 8); +bits_for_big!(U940, 8); +bits_for_big!(U941, 8); +bits_for_big!(U942, 8); +bits_for_big!(U943, 8); +bits_for_big!(U944, 8); +bits_for_big!(U945, 8); +bits_for_big!(U946, 8); +bits_for_big!(U947, 8); +bits_for_big!(U948, 8); +bits_for_big!(U949, 8); +bits_for_big!(U950, 8); +bits_for_big!(U951, 8); +bits_for_big!(U952, 8); +bits_for_big!(U953, 8); +bits_for_big!(U954, 8); +bits_for_big!(U955, 8); +bits_for_big!(U956, 8); +bits_for_big!(U957, 8); +bits_for_big!(U958, 8); +bits_for_big!(U959, 8); +bits_for_big!(U960, 8); +bits_for_big!(U961, 8); +bits_for_big!(U962, 8); +bits_for_big!(U963, 8); +bits_for_big!(U964, 8); +bits_for_big!(U965, 8); +bits_for_big!(U966, 8); +bits_for_big!(U967, 8); +bits_for_big!(U968, 8); +bits_for_big!(U969, 8); +bits_for_big!(U970, 8); +bits_for_big!(U971, 8); +bits_for_big!(U972, 8); +bits_for_big!(U973, 8); +bits_for_big!(U974, 8); +bits_for_big!(U975, 8); +bits_for_big!(U976, 8); +bits_for_big!(U977, 8); +bits_for_big!(U978, 8); +bits_for_big!(U979, 8); +bits_for_big!(U980, 8); +bits_for_big!(U981, 8); +bits_for_big!(U982, 8); +bits_for_big!(U983, 8); +bits_for_big!(U984, 8); +bits_for_big!(U985, 8); +bits_for_big!(U986, 8); +bits_for_big!(U987, 8); +bits_for_big!(U988, 8); +bits_for_big!(U989, 8); +bits_for_big!(U990, 8); +bits_for_big!(U991, 8); +bits_for_big!(U992, 8); +bits_for_big!(U993, 8); +bits_for_big!(U994, 8); +bits_for_big!(U995, 8); +bits_for_big!(U996, 8); +bits_for_big!(U997, 8); +bits_for_big!(U998, 8); +bits_for_big!(U999, 8); +bits_for_big!(U1000, 8); +bits_for_big!(U1001, 8); +bits_for_big!(U1002, 8); +bits_for_big!(U1003, 8); +bits_for_big!(U1004, 8); +bits_for_big!(U1005, 8); +bits_for_big!(U1006, 8); +bits_for_big!(U1007, 8); +bits_for_big!(U1008, 8); +bits_for_big!(U1009, 8); +bits_for_big!(U1010, 8); +bits_for_big!(U1011, 8); +bits_for_big!(U1012, 8); +bits_for_big!(U1013, 8); +bits_for_big!(U1014, 8); +bits_for_big!(U1015, 8); +bits_for_big!(U1016, 8); +bits_for_big!(U1017, 8); +bits_for_big!(U1018, 8); +bits_for_big!(U1019, 8); +bits_for_big!(U1020, 8); +bits_for_big!(U1021, 8); +bits_for_big!(U1022, 8); +bits_for_big!(U1023, 8); +bits_for_big!(U1024, 8); |