1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
|
/**************************************************************************/
/* */
/* The Why platform for program certification */
/* Copyright (C) 2002-2008 */
/* Romain BARDOU */
/* Jean-Franois COUCHOT */
/* Mehdi DOGGUY */
/* Jean-Christophe FILLITRE */
/* Thierry HUBERT */
/* Claude MARCH */
/* Yannick MOY */
/* Christine PAULIN */
/* Yann RGIS-GIANAS */
/* Nicolas ROUSSET */
/* Xavier URBAIN */
/* */
/* This software is free software; you can redistribute it and/or */
/* modify it under the terms of the GNU General Public */
/* License version 2, as published by the Free Software Foundation. */
/* */
/* This software is distributed in the hope that it will be useful, */
/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. */
/* */
/* See the GNU General Public License version 2 for more details */
/* (enclosed in the file GPL). */
/* */
/**************************************************************************/
// the i-th bit of x as 0 or 2^i
//@ logic int bit(int x, int i)
// the number of bits 1 in x
//@ logic int nbits(int x)
//@ axiom nbits_nonneg : \forall int x; nbits(x) >= 0
//@ axiom nbits_zero : nbits(0) == 0
// the lowest bit 1 in x
//@ logic int lowest_bit(int x)
/*@ axiom lowest_bit_def :
@ \forall int x; x != 0 =>
@ \exists int i; (i >= 0 &&
@ lowest_bit(x) == bit(x,i) &&
@ bit(x,i) != 0 &&
@ \forall int j; 0 <= j < i => bit(x,j) == 0)
@*/
/*@ axiom lowest_bit_zero :
@ \forall int x; lowest_bit(x) == 0 <=> x == 0
@*/
/*@ axiom lowest_bit_trick :
@ \forall int x; x & -x == lowest_bit(x)
@*/
/*@ axiom remove_one_bit :
@ \forall int x, int i;
@ bit(x,i) != 0 => nbits(x - bit(x,i)) == nbits(x) - 1
@*/
/*@ ensures \result == nbits(x) */
int count_bits(int x) {
int d, c;
/*@ invariant c + nbits(x) == nbits(\at(x,init))
@ variant nbits(x)
@*/
for (c = 0; d = x&-x; x -= d) c++;
return c;
}
|