1*8462SApril.Chin@Sun.COM#!/usr/bin/ksh93 2*8462SApril.Chin@Sun.COM 3*8462SApril.Chin@Sun.COM# 4*8462SApril.Chin@Sun.COM# CDDL HEADER START 5*8462SApril.Chin@Sun.COM# 6*8462SApril.Chin@Sun.COM# The contents of this file are subject to the terms of the 7*8462SApril.Chin@Sun.COM# Common Development and Distribution License (the "License"). 8*8462SApril.Chin@Sun.COM# You may not use this file except in compliance with the License. 9*8462SApril.Chin@Sun.COM# 10*8462SApril.Chin@Sun.COM# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE 11*8462SApril.Chin@Sun.COM# or http://www.opensolaris.org/os/licensing. 12*8462SApril.Chin@Sun.COM# See the License for the specific language governing permissions 13*8462SApril.Chin@Sun.COM# and limitations under the License. 14*8462SApril.Chin@Sun.COM# 15*8462SApril.Chin@Sun.COM# When distributing Covered Code, include this CDDL HEADER in each 16*8462SApril.Chin@Sun.COM# file and include the License file at usr/src/OPENSOLARIS.LICENSE. 17*8462SApril.Chin@Sun.COM# If applicable, add the following below this CDDL HEADER, with the 18*8462SApril.Chin@Sun.COM# fields enclosed by brackets "[]" replaced with your own identifying 19*8462SApril.Chin@Sun.COM# information: Portions Copyright [yyyy] [name of copyright owner] 20*8462SApril.Chin@Sun.COM# 21*8462SApril.Chin@Sun.COM# CDDL HEADER END 22*8462SApril.Chin@Sun.COM# 23*8462SApril.Chin@Sun.COM 24*8462SApril.Chin@Sun.COM# 25*8462SApril.Chin@Sun.COM# Copyright 2008 Sun Microsystems, Inc. All rights reserved. 26*8462SApril.Chin@Sun.COM# Use is subject to license terms. 27*8462SApril.Chin@Sun.COM# 28*8462SApril.Chin@Sun.COM 29*8462SApril.Chin@Sun.COM# 30*8462SApril.Chin@Sun.COM# primenumbers1 - a simple prime number generator 31*8462SApril.Chin@Sun.COM# 32*8462SApril.Chin@Sun.COM 33*8462SApril.Chin@Sun.COM# Solaris needs /usr/xpg6/bin:/usr/xpg4/bin because the tools in /usr/bin are not POSIX-conformant 34*8462SApril.Chin@Sun.COMexport PATH=/usr/xpg6/bin:/usr/xpg4/bin:/bin:/usr/bin 35*8462SApril.Chin@Sun.COM 36*8462SApril.Chin@Sun.COM# Make sure all math stuff runs in the "C" locale to avoid problems 37*8462SApril.Chin@Sun.COM# with alternative # radix point representations (e.g. ',' instead of 38*8462SApril.Chin@Sun.COM# '.' in de_DE.*-locales). This needs to be set _before_ any 39*8462SApril.Chin@Sun.COM# floating-point constants are defined in this script). 40*8462SApril.Chin@Sun.COMif [[ "${LC_ALL}" != "" ]] ; then 41*8462SApril.Chin@Sun.COM export \ 42*8462SApril.Chin@Sun.COM LC_MONETARY="${LC_ALL}" \ 43*8462SApril.Chin@Sun.COM LC_MESSAGES="${LC_ALL}" \ 44*8462SApril.Chin@Sun.COM LC_COLLATE="${LC_ALL}" \ 45*8462SApril.Chin@Sun.COM LC_CTYPE="${LC_ALL}" 46*8462SApril.Chin@Sun.COM unset LC_ALL 47*8462SApril.Chin@Sun.COMfi 48*8462SApril.Chin@Sun.COMexport LC_NUMERIC=C 49*8462SApril.Chin@Sun.COM 50*8462SApril.Chin@Sun.COM 51*8462SApril.Chin@Sun.COM# check whether arg1 is a prime number via comparing it against the "pn" array 52*8462SApril.Chin@Sun.COMfunction is_prime 53*8462SApril.Chin@Sun.COM{ 54*8462SApril.Chin@Sun.COM integer i 55*8462SApril.Chin@Sun.COM integer num=$1 56*8462SApril.Chin@Sun.COM float max_pn 57*8462SApril.Chin@Sun.COM 58*8462SApril.Chin@Sun.COM (( max_pn=sqrt(num)+1. )) 59*8462SApril.Chin@Sun.COM 60*8462SApril.Chin@Sun.COM for (( i=0 ; i < num_pn && pn[i] < max_pn ; i++)) ; do 61*8462SApril.Chin@Sun.COM (( num % pn[i] == 0 )) && return 1; 62*8462SApril.Chin@Sun.COM done 63*8462SApril.Chin@Sun.COM return 0 64*8462SApril.Chin@Sun.COM} 65*8462SApril.Chin@Sun.COM 66*8462SApril.Chin@Sun.COM# main 67*8462SApril.Chin@Sun.COMset -o errexit 68*8462SApril.Chin@Sun.COM 69*8462SApril.Chin@Sun.COM# get arguments 70*8462SApril.Chin@Sun.COMinteger max_prime=$1 # maximum prime number 71*8462SApril.Chin@Sun.COMtypeset outputformat=$2 72*8462SApril.Chin@Sun.COM 73*8462SApril.Chin@Sun.COM# variables 74*8462SApril.Chin@Sun.COMinteger -a pn # integer array for the prime numbers 75*8462SApril.Chin@Sun.COMinteger num_pn=1 # number of prime numbers 76*8462SApril.Chin@Sun.COMinteger n # current number which should be tested 77*8462SApril.Chin@Sun.COMpn[0]=2 # start value 78*8462SApril.Chin@Sun.COM 79*8462SApril.Chin@Sun.COM# prechecks 80*8462SApril.Chin@Sun.COM(( max_prime > 1 )) || { print -u2 -f "%s: requires a positive integer as first input.\n" "$0" ; exit 1 ; } 81*8462SApril.Chin@Sun.COM 82*8462SApril.Chin@Sun.COM# calculate prime numbers 83*8462SApril.Chin@Sun.COMprintf $"# %s: Calculating prime numbes from 1 to %i\n" "${ date '+%T' ; }" max_prime 1>&2 84*8462SApril.Chin@Sun.COM 85*8462SApril.Chin@Sun.COMfor (( n=3 ; n < max_prime ; n+=2 )) ; do 86*8462SApril.Chin@Sun.COM if is_prime $n ; then 87*8462SApril.Chin@Sun.COM (( pn[num_pn++]=n )) 88*8462SApril.Chin@Sun.COM fi 89*8462SApril.Chin@Sun.COMdone 90*8462SApril.Chin@Sun.COM 91*8462SApril.Chin@Sun.COM# print results 92*8462SApril.Chin@Sun.COMprintf $"# %s: Calculation done, printing results:\n" "${ date '+%T' ; }" 1>&2 93*8462SApril.Chin@Sun.COM 94*8462SApril.Chin@Sun.COMfor (( n=0 ; n < num_pn ; n++ )) ; do 95*8462SApril.Chin@Sun.COM # print prime number 96*8462SApril.Chin@Sun.COM case ${outputformat} in 97*8462SApril.Chin@Sun.COM block) 98*8462SApril.Chin@Sun.COM printf $"%i$( (( n % 8 == 0 )) && print -r '\n' || print -r ',\t')" pn[n] 99*8462SApril.Chin@Sun.COM ;; 100*8462SApril.Chin@Sun.COM line) 101*8462SApril.Chin@Sun.COM printf $"%i\n" pn[n] 102*8462SApril.Chin@Sun.COM ;; 103*8462SApril.Chin@Sun.COM *) 104*8462SApril.Chin@Sun.COM printf $"prime %i:\t%i\n" n pn[n] 105*8462SApril.Chin@Sun.COM ;; 106*8462SApril.Chin@Sun.COM esac 107*8462SApril.Chin@Sun.COMdone 108*8462SApril.Chin@Sun.COM 109*8462SApril.Chin@Sun.COMif [[ ${outputformat} == "block" ]] && (( n % 8 != 1 )); then 110*8462SApril.Chin@Sun.COM print 111*8462SApril.Chin@Sun.COMfi 112*8462SApril.Chin@Sun.COM 113*8462SApril.Chin@Sun.COMprintf $"# %s: Done.\n" "${ date '+%T' ; }" 1>&2 114*8462SApril.Chin@Sun.COM 115*8462SApril.Chin@Sun.COM#EOF. 116