annotate mayachemtool/mayachemtools/lib/MathUtil.pm @ 0:68300206e90d draft default tip

Uploaded
author deepakjadmin
date Thu, 05 Nov 2015 02:41:30 -0500
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
1 package MathUtil;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
2 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
3 # $RCSfile: MathUtil.pm,v $
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
4 # $Date: 2015/02/28 20:47:17 $
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
5 # $Revision: 1.28 $
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
6 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
7 # Author: Manish Sud <msud@san.rr.com>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
8 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
9 # Copyright (C) 2015 Manish Sud. All rights reserved.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
10 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
11 # This file is part of MayaChemTools.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
12 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
13 # MayaChemTools is free software; you can redistribute it and/or modify it under
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
14 # the terms of the GNU Lesser General Public License as published by the Free
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
15 # Software Foundation; either version 3 of the License, or (at your option) any
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
16 # later version.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
17 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
18 # MayaChemTools is distributed in the hope that it will be useful, but without
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
19 # any warranty; without even the implied warranty of merchantability of fitness
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
20 # for a particular purpose. See the GNU Lesser General Public License for more
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
21 # details.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
22 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
23 # You should have received a copy of the GNU Lesser General Public License
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
24 # along with MayaChemTools; if not, see <http://www.gnu.org/licenses/> or
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
25 # write to the Free Software Foundation Inc., 59 Temple Place, Suite 330,
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
26 # Boston, MA, 02111-1307, USA.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
27 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
28
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
29 use strict;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
30 use Exporter;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
31 use Constants;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
32 use Math::Trig ();
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
33 use POSIX ();
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
34
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
35 use vars qw(@ISA @EXPORT @EXPORT_OK %EXPORT_TAGS);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
36
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
37 @ISA = qw(Exporter);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
38 @EXPORT = qw(acos asin atan tan ceil floor log10 min max srandom random round GeneratePrimeNumbersUpToLimit GeneratePrimeNumbersUpToCount);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
39 @EXPORT_OK = qw();
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
40
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
41 %EXPORT_TAGS = (all => [@EXPORT, @EXPORT_OK]
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
42 );
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
43
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
44
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
45 # Return next largest integer...
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
46 sub ceil ($) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
47 my($Value) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
48
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
49 return POSIX::ceil($Value);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
50 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
51
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
52 # Return previous smallest integer...
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
53 sub floor ($) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
54 my($Value) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
55
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
56 return POSIX::floor($Value);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
57 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
58
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
59 # Calculate log value using base 10...
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
60 sub log10 ($) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
61 my($Value) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
62
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
63 return CORE::log($Value)/CORE::log(10);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
64 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
65
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
66 # Return the smaller of two numbers...
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
67 sub min ($$) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
68 my($Value1, $Value2) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
69
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
70 return ($Value1 <= $Value2) ? $Value1 : $Value2;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
71 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
72
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
73 # Return the larger of two numbers...
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
74 sub max ($$) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
75 my($Value1, $Value2) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
76
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
77 return ($Value1 >= $Value2) ? $Value1 : $Value2;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
78 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
79
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
80 # The random number generator implemented in MayaChemTools is a variant of linear
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
81 # congruential generator (LCG) as described by Miller et al. [ Ref 120 ]. It is
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
82 # also referred to as Lehmer random number generator or Park-Miller random number
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
83 # generator.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
84 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
85 # Unlike Perl's core random number generator function rand, the random number
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
86 # generator implemented in MayaChemTools generates consistent random values
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
87 # across different platforms - Windows, CygWin, Linux, Unix - for a specific random
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
88 # seed.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
89 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
90
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
91 # $RandomModulus = 2**31 - 1;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
92 # $RandomMultiplier = 16807;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
93 # $RandomQuotient = $RandomModulus / $RandomMultiplier;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
94 # $RandomRemainder = $RandomModulus % $RandomMultiplier
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
95 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
96 # $MaxRandomSeed = 2*31 -2
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
97 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
98 my($MaxRandomSeed, $RandomSeed, $RandomModulus, $RandomMultiplier, $RandomQuotient, $RandomRemainder);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
99
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
100 $MaxRandomSeed = 2147483646;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
101 $RandomSeed = 123456789;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
102
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
103 $RandomModulus = 2147483647;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
104 $RandomMultiplier = 16807;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
105 $RandomQuotient = 127773;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
106 $RandomRemainder = 2836;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
107
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
108 # Set random number seed...
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
109 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
110 # The intial value of random number seed is recommeded to be an integer between 1
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
111 # and 2**31 - 2 [Ref 120] which translates to be 1 and 2147483646
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
112 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
113 sub srandom ($) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
114 my($Seed) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
115
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
116 if ($Seed <= 0 ) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
117 die "Error: srandom: Specified seed value must be greater than 0...";
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
118 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
119
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
120 $RandomSeed = ($Seed > $MaxRandomSeed) ? ($Seed % $MaxRandomSeed) : $Seed;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
121
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
122 return $RandomSeed;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
123 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
124
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
125 # Retrun a random number between 0 and less than 1 or specified size...
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
126 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
127 sub random (;$) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
128 my($Size) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
129 my($Value, $LowValue, $HighValue);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
130
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
131 $Size = defined $Size ? $Size : 1.0;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
132
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
133 $HighValue = $RandomSeed / $RandomQuotient;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
134 $LowValue = $RandomSeed % $RandomQuotient;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
135
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
136 $Value = $RandomMultiplier * $LowValue - $RandomRemainder * $HighValue;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
137
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
138 $RandomSeed = ($Value > 0) ? $Value : ($Value + $RandomModulus);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
139
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
140 return ($RandomSeed / $RandomModulus) * $Size;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
141 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
142
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
143 # Round a integer/real number to:
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
144 # . A nearest integer
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
145 # . Specified number of decimal places
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
146 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
147 sub round ($;$) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
148 my($Value, $DecimalPlaces) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
149 my($RoundedValue);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
150
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
151 if (defined($DecimalPlaces) && $DecimalPlaces > 0) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
152 $RoundedValue = sprintf "%.${DecimalPlaces}f", $Value;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
153 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
154 else {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
155 if ($Value < 0) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
156 $RoundedValue = int($Value - 0.5);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
157 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
158 else {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
159 $RoundedValue = int($Value + 0.5);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
160 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
161 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
162 return $RoundedValue;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
163 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
164
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
165 # Return tangent of an angle expressed in radians.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
166 sub tan {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
167 my($Value) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
168
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
169 return (CORE::sin($Value)/CORE::cos($Value));
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
170 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
171
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
172 # Return inverse sine of an angle expressed in radians.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
173 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
174 # For a right angle triangle defined by sides X and Y in a unit circle, Pythagorean theorem implies
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
175 # X**2 + Y**2 = 1 and sin value corresponds to Y. So asin is equivalent to atan2(Y, sqrt(1-Y**2)).
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
176 # However, taking sqrt of negative numbers is problematic; Math::Trig::asin handles it using complex
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
177 # numbers.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
178 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
179 sub asin ($) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
180 my($Value) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
181
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
182 return Math::Trig::asin($Value);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
183 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
184
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
185 # Return inverse cosine of an angle expressed in radians.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
186 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
187 # For a right angle triangle defined by sides X and Y in a unit circle, Pythagorean theorem implies
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
188 # X**2 + Y**2 = 1 and cos value corresponds to X. So asin is equivalent to atan2(sqrt(1-X**2), X)
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
189 # However, taking sqrt of negative numbers is problematic; Math::Trig::acos handles it using complex
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
190 # numbers.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
191 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
192 sub acos ($) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
193 my($Value) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
194
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
195 return Math::Trig::acos($Value);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
196 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
197
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
198 # Generate prime numbers up to a specified limit and return a reference to an
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
199 # array containing the prime numbers.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
200 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
201 # By default, the first 1000 prime numbers are generated. The 1000th prime
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
202 # number is 7919 and that's why default limit is set to 7920.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
203 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
204 sub GeneratePrimeNumbersUpToLimit (;$) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
205 my($Limit) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
206
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
207 $Limit = defined $Limit ? $Limit : 7920;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
208
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
209 return _GeneratePrimeNumbers('ByLimit', $Limit)
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
210 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
211
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
212 # Generate prime numbers up to specified count of prime numbers and return a
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
213 # reference to an array containing the prime numbers.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
214 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
215 # By default, the first 1000 prime numbers are generated. The 1000th prime
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
216 # number is 7919.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
217 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
218 sub GeneratePrimeNumbersUpToCount (;$) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
219 my($Count) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
220
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
221 $Count = defined $Count ? $Count : 1000;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
222
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
223 return _GeneratePrimeNumbers('ByCount', $Count)
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
224 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
225
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
226 # Generate prime numbers up to specified limit or count and return a reference
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
227 # to an array containing the prime numbers.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
228 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
229 # The algorithm to generate prime numbers is a modification of Sieve of Erastothenes
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
230 # prime number generator.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
231 #
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
232 sub _GeneratePrimeNumbers {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
233 my($Mode, $Value) = @_;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
234 my($ByLimit, $PrimeNumber, $Number, $SqrtOfNumber, $NumberIsPrime, @PrimeNumbers);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
235
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
236 $ByLimit = ($Mode =~ /^ByLimit$/i) ? 1 : 0;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
237
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
238 @PrimeNumbers = (2, 3);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
239 $Number = 3;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
240
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
241 # while ($Number <= $Limit) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
242 while ($ByLimit ? ($Number < $Value) : (@PrimeNumbers < $Value)) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
243 $Number += 2;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
244 $SqrtOfNumber = sqrt $Number;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
245
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
246 $NumberIsPrime = 1;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
247 PRIMENUMBER: for $PrimeNumber (@PrimeNumbers) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
248 if ($PrimeNumber > $SqrtOfNumber) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
249 last PRIMENUMBER;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
250 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
251 if (!($Number % $PrimeNumber)) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
252 $NumberIsPrime = 0;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
253 last PRIMENUMBER;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
254 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
255 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
256 if ($NumberIsPrime) {
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
257 push @PrimeNumbers, $Number;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
258 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
259 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
260 return \@PrimeNumbers;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
261 }
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
262
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
263 1;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
264
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
265 __END__
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
266
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
267 =head1 NAME
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
268
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
269 MathUtil
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
270
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
271 =head1 SYNOPSIS
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
272
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
273 use MathUtil;
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
274
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
275 use MathUtil qw(:all);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
276
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
277 =head1 DESCRIPTION
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
278
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
279 B<MathUtil> module provides a variety of common math functions not available in core
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
280 Perl package or some other useful math utilities. In order to be consistent with other
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
281 Perl functions, name of all the functions in this package are in lowercase which differs
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
282 from MayaChemTools naming convention for function names.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
283
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
284 B<MathUtil> module provides the following functions:
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
285
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
286 GeneratePrimeNumbersUpToCount, GeneratePrimeNumbersUpToLimit, acos, asin, ceil,
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
287 floor, log10, max, min, random, round, srandom, tan
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
288
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
289 =head2 FUNCTIONS
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
290
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
291 =over 4
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
292
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
293 =item B<GeneratePrimeNumbersUpToCount>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
294
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
295 $PrimesRef = GeneratePrimeNumbersUpToCount();
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
296 $PrimesRef = GeneratePrimeNumbersUpToCount($Count);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
297
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
298 Generate prime numbers up to specified I<Count> of prime numbers and return a
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
299 reference to an array containing the prime numbers.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
300
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
301 By default, the first 1000 prime numbers are generated. The 1000th prime
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
302 number is 7919.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
303
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
304 The algorithm to generate prime numbers is a modification of Sieve of Erastothenes
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
305 prime number generator.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
306
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
307 =item B<GeneratePrimeNumbersUpToLimit>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
308
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
309 $PrimesRef = GeneratePrimeNumbersUpToLimit();
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
310 $PrimesRef = GeneratePrimeNumbersUpToLimit($Limit);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
311
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
312 Generate prime numbers up to a specified I<Limit> and return a reference to an
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
313 array containing the prime numbers.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
314
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
315 By default, the first 1000 prime numbers are generated. The 1000th prime
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
316 number is 7919 and that's why default limit is set to 7920.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
317
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
318 The algorithm to generate prime numbers is a modification of Sieve of Erastothenes
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
319 prime number generator.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
320
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
321 =item B<acos>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
322
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
323 $Value = acos($AngleInRadians);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
324
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
325 Returns the nverse cosine of an angle expressed in I<Radians> using Math::Trig::acos
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
326 function.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
327
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
328 =item B<asin>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
329
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
330 $Value = asin($AngleInRadians);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
331
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
332 Returns the inverse sine of an angle expressed in I<Radians> using Math::Trig::asin
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
333 function.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
334
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
335 =item B<ceil>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
336
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
337 $IntegerValue = ceil($Value);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
338
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
339 Returns the next largest integer for I<Value> using POSIX::ceil function.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
340
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
341 =item B<floor>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
342
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
343 $IntegerValue = floor($Value);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
344
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
345 Returns the previous smallest integer for I<Value> using POSIX::floor function.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
346
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
347 =item B<log10>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
348
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
349 $Log10Value = log10($Value);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
350
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
351 Returns the log of I<Value> using base 10.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
352
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
353 =item B<max>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
354
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
355 $Number = max($Number1, $Number2);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
356
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
357 Returns a B<Number> corresponding to the maximum of I<Number1> and I<Number2>.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
358
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
359 =item B<min>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
360
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
361 $Number = min($Number1, $Number2);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
362
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
363 Returns a B<Number> corresponding to the minimum of I<Number1> and I<Number2>.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
364
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
365 =item B<round>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
366
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
367 $RoundedValue = round($Number);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
368 $RoundedValue = round($Number, $DecimalPlaces);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
369
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
370 Returns a value corresponding to a nearst ingeter for I<Number> or formatted to I<DecimalPlaces>.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
371
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
372 =item B<random>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
373
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
374 $RandomNumber = random();
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
375 $RandomNumber = random($Size);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
376
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
377 Returns a random number between 0 and less than 1 or specified size.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
378
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
379 The random number generator implemented in MayaChemTools is a variant of linear
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
380 congruential generator (LCG) as described by Miller et al. [ Ref 120 ]. It is
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
381 also referred to as Lehmer random number generator or Park-Miller random number
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
382 generator.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
383
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
384 Unlike Perl's core random number generator function rand, the random number
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
385 generator implemented in MayaChemTools generates consistent random values
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
386 across different platforms - Windows, CygWin, Linux, Unix - for a specific random
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
387 seed.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
388
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
389 =item B<srandom>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
390
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
391 $Seed = srandom($Seed);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
392
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
393 Sets random number seed to be used by <random> function and returns seed value.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
394
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
395 The random number seed is recommeded to be an integer between 1 and 2**31 - 2
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
396 [Ref 120] which translates to be 1 and 2147483646.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
397
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
398 The default seed is set to 123456789.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
399
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
400 =item B<tan>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
401
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
402 $Value = tan($AngleInRadians);
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
403
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
404 Returns the tangent of an angle expressed in I<Radians>.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
405
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
406 =back
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
407
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
408 =head1 AUTHOR
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
409
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
410 Manish Sud <msud@san.rr.com>
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
411
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
412 =head1 SEE ALSO
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
413
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
414 Constants.pm, ConversionsUtil.pm
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
415
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
416 =head1 COPYRIGHT
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
417
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
418 Copyright (C) 2015 Manish Sud. All rights reserved.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
419
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
420 This file is part of MayaChemTools.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
421
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
422 MayaChemTools is free software; you can redistribute it and/or modify it under
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
423 the terms of the GNU Lesser General Public License as published by the Free
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
424 Software Foundation; either version 3 of the License, or (at your option)
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
425 any later version.
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
426
68300206e90d Uploaded
deepakjadmin
parents:
diff changeset
427 =cut