/* * algorithm for computing simultaneously the GCD and the LCM, * by Sankaranarayanan */ extern void abort(void); extern void __assert_fail(const char *, const char *, unsigned int, const char *) __attribute__ ((__nothrow__ , __leaf__)) __attribute__ ((__noreturn__)); void reach_error() { __assert_fail("0", "lcm1.c", 8, "reach_error"); } extern unsigned __VERIFIER_nondet_uint(void); extern void abort(void); void assume_abort_if_not(int cond) { if(!cond) {abort();} } void __VERIFIER_assert(int cond) { if (!(cond)) { ERROR: {reach_error();} } return; } int main() { unsigned a, b; unsigned x, y, u, v; a = __VERIFIER_nondet_uint(); b = __VERIFIER_nondet_uint(); assume_abort_if_not(a >= 1); //infinite loop if remove assume_abort_if_not(b >= 1); assume_abort_if_not(a <= 65535); assume_abort_if_not(b <= 65535); x = a; y = b; u = b; v = 0; while (1) { __VERIFIER_assert(x*u + y*v == a*b); if (!(x != y)) break; while (1) { __VERIFIER_assert(x*u + y*v == a*b); if (!(x > y)) break; x = x - y; v = v + u; } while (1) { __VERIFIER_assert(x*u + y*v == a*b); if (!(x < y)) break; y = y - x; u = u + v; } } __VERIFIER_assert(u*y + v*y == a*b); __VERIFIER_assert(x == y); //x == gcd(a,b) //u + v == lcm(a,b) return 0; }