download wheel-gen.pl
Language: Perl
License: GPL
Copyright: (C) 2001, 2005 Free Software Foundation, Inc.
LOC: 80
Project Info
GNU Core Utilities(coreutils)
Server: Savannah GNU
Type: cvs
...ls\coreutils\coreutils\src\
   .gitignore
   base64.c
   basename.c
   c99-to-c89.diff
   cat.c
   chcon.c
   chgrp.c
   chmod.c
   chown-core.c
   chown-core.h
   chown.c
   chroot.c
   cksum.c
   comm.c
   copy.c
   copy.h
   cp-hash.c
   cp-hash.h
   cp.c
   csplit.c
   cut.c
   date.c
   dd.c
   df.c
   dircolors.c
   dircolors.hin
   dirname.c
   du.c
   echo.c
   env.c
   expand.c
   expr.c
   factor.c
   false.c
   fmt.c
   fold.c
   groups.sh
   head.c
   hostid.c
   hostname.c
   id.c
   install.c
   join.c
   kill.c
   lbracket.c
   link.c
   ln.c
   logname.c
   ls-dir.c
   ls-ls.c
   ls-vdir.c
   ls.c
   ls.h
   Makefile.am
   md5sum.c
   mkdir.c
   mkfifo.c
   mknod.c
   mv.c
   nice.c
   nl.c
   nohup.c
   od.c
   paste.c
   pathchk.c
   pinky.c
   pr.c
   printenv.c
   printf.c
   ptx.c
   pwd.c
   readlink.c
   remove.c
   remove.h
   rm.c
   rmdir.c
   runcon.c
   seq.c
   setuidgid.c
   shred.c
   shuf.c
   sleep.c
   sort.c
   split.c
   stat.c
   stty.c
   su.c
   sum.c
   sync.c
   system.h
   tac-pipe.c
   tac.c
   tail.c
   tee.c
   test.c
   touch.c
   tr.c
   true.c
   tsort.c
   tty.c
   uname-arch.c
   uname-uname.c
   uname.c
   uname.h
   unexpand.c
   uniq.c
   unlink.c
   uptime.c
   users.c
   wc.c
   wheel-gen.pl
   who.c
   whoami.c
   yes.c

#!/usr/bin/perl -w
# Generate the spokes of a wheel, for wheel factorization.

# Copyright (C) 2001, 2005 Free Software Foundation, Inc.

# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.

# This program 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 for more details.

# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.

eval 'exec /usr/bin/perl -S $0 ${1+"$@"}'
  if 0;

use strict;
(my $ME = $0) =~ s|.*/||;

# A global destructor to close standard output with error checking.
sub END
{
  defined fileno STDOUT
    or return;
  close STDOUT
    and return;
  warn "$ME: closing standard output: $!\n";
  $? ||= 1;
}

sub is_prime ($)
{
  my ($n) = @_;
  use integer;

  $n == 2
    and return 1;

  my $d = 2;
  my $w = 1;
  while (1)
    {
      my $q = $n / $d;
      $n == $q * $d
        and return 0;
      $d += $w;
      $q < $d
	and last;
      $w = 2;
    }
  return 1;
}

{
  @ARGV == 1
    or die "$ME: missing argument\n";

  my $wheel_size = $ARGV[0];

  my @primes = (2);
  my $product = $primes[0];
  my $n_primes = 1;
  for (my $i = 3; ; $i += 2)
    {
      if (is_prime $i)
	{
	  push @primes, $i;
	  $product *= $i;
	  ++$n_primes == $wheel_size
	    and last;
	}
    }

  my $ws_m1 = $wheel_size - 1;
  print <<EOF;
/* The first $ws_m1 elements correspond to the incremental offsets of the
   first $wheel_size primes (@primes).  The $wheel_size(th) element is the
   difference between that last prime and the next largest integer
   that is not a multiple of those primes.  The remaining numbers
   define the wheel.  For more information, see
   http://www.utm.edu/research/primes/glossary/WheelFactorization.html.  */
EOF

  my @increments;
  my $prev = 2;
  for (my $i = 3; ; $i += 2)
    {
      my $rel_prime = 1;
      foreach my $divisor (@primes)
	{
	  $i != $divisor && $i % $divisor == 0
	    and $rel_prime = 0;
	}

      if ($rel_prime)
	{
	  #warn $i, ' ', $i - $prev, "\n";
	  push @increments, $i - $prev;
	  $prev = $i;

	  $product + 1 < $i
	    and last;
	}
    }

  print join (",\n", @increments), "\n";

  exit 0;
}

About Koders | Resources | Downloads | Support | Black Duck | Submit Project | Terms of Service | DMCA | Privacy Policy | Site Map| Contact Us