src/HOL/SPARK/Manual/document/Simple_Gcd.adb
author fleury <Mathias.Fleury@mpi-inf.mpg.de>
Fri, 07 Oct 2016 17:58:36 +0200
changeset 64076 9f089287687b
parent 45044 2fae15f8984d
permissions -rw-r--r--
tuning multisets

package body Simple_Greatest_Common_Divisor
is

   procedure G_C_D (M, N : in Natural; G : out Natural)
   is
      C, D, R : Natural;
   begin
      C := M; D := N;
      while D /= 0
        --# assert Gcd (C, D) = Gcd (M, N);
      loop
         R := C mod D;
         C := D; D := R;
      end loop;
      G := C;
   end G_C_D;

end Simple_Greatest_Common_Divisor;