bitmap_core.rs 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271
  1. use core::{intrinsics::unlikely, marker::PhantomData};
  2. use crate::traits::BitOps;
  3. #[derive(Debug, Clone)]
  4. pub struct BitMapCore<T: BitOps> {
  5. phantom: PhantomData<T>,
  6. }
  7. impl<T: BitOps> Default for BitMapCore<T> {
  8. fn default() -> Self {
  9. Self::new()
  10. }
  11. }
  12. impl<T: BitOps> BitMapCore<T> {
  13. pub const fn new() -> Self {
  14. Self {
  15. phantom: PhantomData,
  16. }
  17. }
  18. /// 获取位图中的某一位
  19. pub fn get(&self, n: usize, data: &[T], index: usize) -> Option<bool> {
  20. if unlikely(index >= n) {
  21. return None;
  22. }
  23. let element_index = index / T::bit_size();
  24. let bit_index = index % T::bit_size();
  25. let element = data.get(element_index)?;
  26. let bit = <T as BitOps>::get(element, bit_index);
  27. Some(bit)
  28. }
  29. /// 设置位图中的某一位
  30. pub fn set(&self, n: usize, data: &mut [T], index: usize, value: bool) -> Option<bool> {
  31. if unlikely(index >= n) {
  32. return None;
  33. }
  34. let element_index = index / T::bit_size();
  35. let bit_index = index % T::bit_size();
  36. let element = data.get_mut(element_index)?;
  37. let bit = <T as BitOps>::set(element, bit_index, value);
  38. Some(bit)
  39. }
  40. pub fn set_all(&self, n: usize, data: &mut [T], value: bool) {
  41. let val = if value { T::max() } else { T::zero() };
  42. for element in data.iter_mut() {
  43. *element = val;
  44. }
  45. // 特殊处理最后一个元素
  46. let last_element = data.last_mut().unwrap();
  47. let mask = T::make_mask(n % T::bit_size());
  48. if mask != T::zero() {
  49. *last_element &= mask;
  50. }
  51. }
  52. /// 获取位图中第一个为1的位
  53. pub fn first_index(&self, data: &[T]) -> Option<usize> {
  54. for (i, element) in data.iter().enumerate() {
  55. let bit = <T as BitOps>::first_index(element);
  56. if let Some(b) = bit {
  57. return Some(i * T::bit_size() + b);
  58. }
  59. }
  60. None
  61. }
  62. /// 获取位图中第一个为0的位
  63. pub fn first_false_index(&self, n: usize, data: &[T]) -> Option<usize> {
  64. for (i, element) in data.iter().enumerate() {
  65. if let Some(bit) = <T as BitOps>::first_false_index(element) {
  66. return self.make_index(n, i * T::bit_size() + bit);
  67. }
  68. }
  69. None
  70. }
  71. /// 获取位图中最后一个为1的位
  72. pub fn last_index(&self, n: usize, data: &[T]) -> Option<usize> {
  73. for (i, element) in data.iter().enumerate().rev() {
  74. if let Some(bit) = <T as BitOps>::last_index(element) {
  75. return self.make_index(n, i * T::bit_size() + bit);
  76. }
  77. }
  78. None
  79. }
  80. /// 获取位图中最后一个为0的位
  81. ///
  82. /// ## 参数
  83. ///
  84. /// - `data`:位图数据
  85. /// - `n`:位图有效位数
  86. pub fn last_false_index(&self, n: usize, data: &[T]) -> Option<usize> {
  87. let mut iter = data.iter().rev();
  88. let mut last_element = *iter.next()?;
  89. // 对最后一个元素进行特殊处理,因为最后一个元素可能不是满的
  90. let mut mask = T::make_mask(n % T::bit_size());
  91. if mask != T::zero() {
  92. <T as BitOps>::invert(&mut mask);
  93. last_element |= mask;
  94. }
  95. if let Some(bit) = <T as BitOps>::last_false_index(&last_element) {
  96. return self.make_index(n, (data.len() - 1) * T::bit_size() + bit);
  97. }
  98. for element in iter {
  99. if let Some(bit) = <T as BitOps>::last_false_index(element) {
  100. return self.make_index(n, (data.len() - 1) * T::bit_size() + bit);
  101. }
  102. }
  103. None
  104. }
  105. /// 获取位图中下一个为1的位
  106. pub fn next_index(&self, n: usize, data: &[T], index: usize) -> Option<usize> {
  107. if unlikely(index >= n) {
  108. return None;
  109. }
  110. let element_index = index / T::bit_size();
  111. let bit_index = index % T::bit_size();
  112. let element = data.get(element_index)?;
  113. if let Some(bit) = <T as BitOps>::next_index(element, bit_index) {
  114. return self.make_index(n, element_index * T::bit_size() + bit);
  115. }
  116. for (i, element) in data.iter().enumerate().skip(element_index + 1) {
  117. if let Some(bit) = <T as BitOps>::first_index(element) {
  118. return self.make_index(n, i * T::bit_size() + bit);
  119. }
  120. }
  121. None
  122. }
  123. /// 获取位图中下一个为0的位
  124. pub fn next_false_index(&self, n: usize, data: &[T], index: usize) -> Option<usize> {
  125. if unlikely(index >= n) {
  126. return None;
  127. }
  128. let element_index = index / T::bit_size();
  129. let bit_index = index % T::bit_size();
  130. let element = data.get(element_index)?;
  131. if let Some(bit) = <T as BitOps>::next_false_index(element, bit_index) {
  132. return self.make_index(n, element_index * T::bit_size() + bit);
  133. }
  134. for (i, element) in data.iter().enumerate().skip(element_index + 1) {
  135. if let Some(bit) = <T as BitOps>::first_false_index(element) {
  136. return self.make_index(n, i * T::bit_size() + bit);
  137. }
  138. }
  139. None
  140. }
  141. /// 获取位图中上一个为1的位
  142. pub fn prev_index(&self, n: usize, data: &[T], index: usize) -> Option<usize> {
  143. if unlikely(index >= n) {
  144. return None;
  145. }
  146. let element_index = index / T::bit_size();
  147. let bit_index = index % T::bit_size();
  148. let element = data.get(element_index)?;
  149. if let Some(bit) = <T as BitOps>::prev_index(element, bit_index) {
  150. return self.make_index(n, element_index * T::bit_size() + bit);
  151. }
  152. for (i, element) in data.iter().enumerate().take(element_index).rev() {
  153. if let Some(bit) = <T as BitOps>::last_index(element) {
  154. return self.make_index(n, i * T::bit_size() + bit);
  155. }
  156. }
  157. None
  158. }
  159. pub fn prev_false_index(&self, n: usize, data: &[T], index: usize) -> Option<usize> {
  160. let element_index = index / T::bit_size();
  161. let bit_index = index % T::bit_size();
  162. let element = data.get(element_index)?;
  163. if let Some(bit) = <T as BitOps>::prev_false_index(element, bit_index) {
  164. return self.make_index(n, element_index * T::bit_size() + bit);
  165. }
  166. for (i, element) in data.iter().enumerate().take(element_index).rev() {
  167. if let Some(bit) = <T as BitOps>::last_false_index(element) {
  168. return self.make_index(n, i * T::bit_size() + bit);
  169. }
  170. }
  171. None
  172. }
  173. pub fn invert(&self, n: usize, data: &mut [T]) {
  174. for element in data.iter_mut() {
  175. <T as BitOps>::invert(element);
  176. }
  177. // 特殊处理最后一个元素
  178. let last_element = data.last_mut().unwrap();
  179. let mask = T::make_mask(n % T::bit_size());
  180. if mask != T::zero() {
  181. *last_element &= mask;
  182. }
  183. }
  184. pub fn is_full(&self, n: usize, data: &[T]) -> bool {
  185. let mut iter = data.iter().peekable();
  186. while let Some(element) = iter.next() {
  187. if iter.peek().is_none() {
  188. // 这是最后一个元素,进行特殊处理
  189. let mut element = *element;
  190. let mut mask = T::make_mask(n % T::bit_size());
  191. if mask == T::zero() {
  192. mask = T::max();
  193. }
  194. T::bit_and(&mut element, &mask);
  195. if element == mask {
  196. return true;
  197. }
  198. } else if element != &T::make_mask(T::bit_size()) {
  199. return false;
  200. }
  201. }
  202. return false;
  203. }
  204. pub fn is_empty(&self, data: &[T]) -> bool {
  205. for element in data.iter() {
  206. if element != &T::zero() {
  207. return false;
  208. }
  209. }
  210. return true;
  211. }
  212. fn make_index(&self, n: usize, index: usize) -> Option<usize> {
  213. if unlikely(index >= n) {
  214. return None;
  215. }
  216. Some(index)
  217. }
  218. }