PowerOf2.cs 1.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. /* Copyright 2010-2015 MongoDB Inc.
  2. *
  3. * Licensed under the Apache License, Version 2.0 (the "License");
  4. * you may not use this file except in compliance with the License.
  5. * You may obtain a copy of the License at
  6. *
  7. * http://www.apache.org/licenses/LICENSE-2.0
  8. *
  9. * Unless required by applicable law or agreed to in writing, software
  10. * distributed under the License is distributed on an "AS IS" BASIS,
  11. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. * See the License for the specific language governing permissions and
  13. * limitations under the License.
  14. */
  15. using System;
  16. namespace MongoDB.Bson
  17. {
  18. internal static class PowerOf2
  19. {
  20. public static bool IsPowerOf2(int n)
  21. {
  22. return n == RoundUpToPowerOf2(n);
  23. }
  24. public static int RoundUpToPowerOf2(int n)
  25. {
  26. if (n < 0 || n > 0x40000000)
  27. {
  28. throw new ArgumentOutOfRangeException("n");
  29. }
  30. // see: Hacker's Delight, by Henry S. Warren
  31. n = n - 1;
  32. n = n | (n >> 1);
  33. n = n | (n >> 2);
  34. n = n | (n >> 4);
  35. n = n | (n >> 8);
  36. n = n | (n >> 16);
  37. return n + 1;
  38. }
  39. }
  40. }