annotate lib/MathUtil.pm @ 0:4816e4a8ae95 draft default tip

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