#!/usr/bin/env python # def moebius ( n ): #*****************************************************************************80 # ## MOEBIUS returns the value of MU(N), the Moebius function of N. # # Definition: # # MU(N) is defined as follows: # # MU(N) = 1 if N = 1; # 0 if N is divisible by the square of a prime; # (-1)^K, if N is the product of K distinct primes. # # First values: # # N MU(N) # # 1 1 # 2 -1 # 3 -1 # 4 0 # 5 -1 # 6 1 # 7 -1 # 8 0 # 9 0 # 10 1 # 11 -1 # 12 0 # 13 -1 # 14 1 # 15 1 # 16 0 # 17 -1 # 18 0 # 19 -1 # 20 0 # # As special cases, MU(N) is -1 if N is a prime, and MU(N) is 0 # if N is a square, cube, etc. # # The Moebius function is related to Euler's totient function: # # PHI(N) = Sum ( D divides N ) MU(D) * ( N / D ). # # Licensing: # # This code is distributed under the GNU LGPL license. # # Modified: # # 23 February 2015 # # Author: # # John Burkardt # # Parameters: # # Input, integer N, the value to be analyzed. # # Output, integer VALUE, the value of MU(N). # If N is less than or equal to 0, MU will be returned as -2. # If there was not enough internal space for factoring, MU # is returned as -3. # from i4_factor import i4_factor if ( n <= 0 ): value = -2 return value if ( n == 1 ): value = 1 return value # # Factor N. # nfactor, factor, power, nleft = i4_factor ( n ) if ( nleft != 1 ): print '' print 'MOEBIUS - Fatal error!' print ' Incomplete factorization.' value = -3 value = 1 for i in range ( 0, nfactor ): value = - value if ( 1 < power[i] ): value = 0 return value return value def moebius_test ( ): #*****************************************************************************80 # ## MOEBIUS_TEST tests MOEBIUS. # # Licensing: # # This code is distributed under the GNU LGPL license. # # Modified: # # 23 February 2015 # # Author: # # John Burkardt # from moebius_values import moebius_values print '' print 'MOEBIUS_TEST' print ' MOEBIUS computes the Moebius function.' print '' print ' N Exact MOEBIUS(N)' print '' n_data = 0 while ( True ): n_data, n, c = moebius_values ( n_data ) if ( n_data == 0 ): break c2 = moebius ( n ) print ' %4d %8d %8d' % ( n, c, c2 ) print '' print 'MOEBIUS_TEST' print ' Normal end of execution.' return if ( __name__ == '__main__' ): from timestamp import timestamp timestamp ( ) moebius_test ( ) timestamp ( )