1/*==============================================================================
2|
3| NAME
4|
5| ppOperationCount.cpp
6|
7| DESCRIPTION
8|
9| Collect operation counts for the primitive polynomial algorithm:
10| number of iterations for prime factoring, number of polynomials free of
11| linear factors, and whatnot.
12|
13| User manual and technical documentation are described in detail in my web page at
14| http://seanerikoconnor.freeservers.com/Mathematics/AbstractAlgebra/PrimitivePolynomials/overview.html
15|
16| LEGAL
17|
18| Primpoly Version 16.3 - A Program for Computing Primitive Polynomials.
19| Copyright (C) 1999-2025 by Sean Erik O'Connor. All Rights Reserved.
20|
21| This program is free software: you can redistribute it and/or modify
22| it under the terms of the GNU General Public License as published by
23| the Free Software Foundation, either version 3 of the License, or
24| (at your option) any later version.
25|
26| This program is distributed in the hope that it will be useful,
27| but WITHOUT ANY WARRANTY; without even the implied warranty of
28| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
29| GNU General Public License for more details.
30|
31| You should have received a copy of the GNU General Public License
32| along with this program. If not, see http://www.gnu.org/licenses/.
33|
34| The author's address is seanerikoconnor!AT!gmail!DOT!com
35| with !DOT! replaced by . and the !AT! replaced by @
36|
37==============================================================================*/
38
39
40
41/*------------------------------------------------------------------------------
42| Includes |
43------------------------------------------------------------------------------*/
44
45#include <cstdlib> // abort()
46#include <iostream> // Basic stream I/O.
47#include <new> // set_new_handler()
48#include <cmath> // Basic math functions e.g. sqrt()
49#include <limits> // Numeric limits.
50#include <complex> // Complex data type and operations.
51#include <fstream> // File stream I/O.
52#include <sstream> // String stream I/O.
53#include <vector> // STL vector class.
54#include <string> // STL string class.
55#include <algorithm> // Iterators.
56#include <stdexcept> // Exceptions.
57#include <cassert> // assert()
58
59using namespace std ; // So we don't need to say std::vector everywhere.
60
61
62
63/*------------------------------------------------------------------------------
64| PP Include Files |
65------------------------------------------------------------------------------*/
66
67#include "Primpoly.hpp" // Global functions.
68#include "ppArith.hpp" // Basic arithmetic functions.
69#include "ppBigInt.hpp" // Arbitrary precision integer arithmetic.
70#include "ppOperationCount.hpp" // OperationCount collection for factoring and poly finding.
71#include "ppFactor.hpp" // Prime factorization and Euler Phi.
72#include "ppPolynomial.hpp" // Polynomial operations and mod polynomial operations.
73#include "ppParser.hpp" // Parsing of polynomials and I/O services.
74#include "ppUnitTest.hpp" // Complete unit test.
75
76
77/*=============================================================================
78 |
79 | NAME
80 |
81 | OperationCount
82 |
83 | DESCRIPTION
84 |
85 | Default constructor.
86 |
87 +============================================================================*/
88
89OperationCount::OperationCount()
90 : n( 0u )
91 , p( 0u )
92 , max_num_possible_poly( 0u )
93 , num_primitive_poly( 0u )
94 , num_poly_tested( 0u )
95 , num_gcds( 0u )
96 , num_primality_tests( 0u )
97 , num_squarings( 0u )
98 , num_trial_divides( 0u )
99 , num_free_of_linear_factors( 0u )
100 , num_where_const_coeff_is_primitive_root( 0u )
101 , num_passing_const_coeff_test( 0u )
102 , num_irreducible_to_power( 0u )
103 , num_order_m( 0u )
104 , num_order_r( 0u )
105{
106}
107
108
109
110/*=============================================================================
111 |
112 | NAME
113 |
114 | OperationCount
115 |
116 | DESCRIPTION
117 |
118 | No special destruction needed.
119 |
120 +============================================================================*/
121
122OperationCount::~OperationCount()
123{
124}
125
126
127
128/*=============================================================================
129 |
130 | NAME
131 |
132 | OperationCount
133 |
134 | DESCRIPTION
135 |
136 | Copy constructor.
137 |
138 +============================================================================*/
139
140OperationCount::OperationCount( const OperationCount & statistics )
141 :n( statistics.n )
142 ,p( statistics.p )
143 ,max_num_possible_poly( statistics.max_num_possible_poly )
144 ,num_primitive_poly( statistics.num_primitive_poly )
145 ,num_poly_tested( statistics.num_poly_tested )
146 ,num_gcds( statistics.num_gcds )
147 ,num_primality_tests( statistics.num_primality_tests )
148 ,num_squarings( statistics.num_squarings )
149 ,num_trial_divides( statistics.num_trial_divides )
150 ,num_free_of_linear_factors( statistics.num_free_of_linear_factors )
151 ,num_where_const_coeff_is_primitive_root( statistics.num_where_const_coeff_is_primitive_root )
152 ,num_passing_const_coeff_test( statistics.num_passing_const_coeff_test )
153 ,num_irreducible_to_power( statistics.num_irreducible_to_power )
154 ,num_order_m( statistics.num_order_m )
155 ,num_order_r( statistics.num_order_r )
156
157{
158}
159
160
161
162/*=============================================================================
163 |
164 | NAME
165 |
166 | OperationCount
167 |
168 | DESCRIPTION
169 |
170 | Assignment.
171 |
172 +============================================================================*/
173
174OperationCount & OperationCount::operator=( const OperationCount & statistics )
175{
176 // Check for assigning to oneself: just pass back a reference to the unchanged object.
177 if (this == &statistics)
178 return *this ;
179
180 n = statistics.n ;
181 p = statistics.p ;
182
183 max_num_possible_poly = statistics.max_num_possible_poly ;
184 num_primitive_poly = statistics.num_primitive_poly ;
185
186 num_poly_tested = statistics.num_poly_tested ;
187 num_gcds = statistics.num_gcds ;
188 num_primality_tests = statistics.num_primality_tests ;
189 num_squarings = statistics.num_squarings ;
190 num_trial_divides = statistics.num_trial_divides ;
191 num_free_of_linear_factors = statistics.num_free_of_linear_factors ;
192 num_where_const_coeff_is_primitive_root = statistics.num_where_const_coeff_is_primitive_root ;
193 num_passing_const_coeff_test = statistics.num_passing_const_coeff_test ;
194 num_irreducible_to_power = statistics.num_irreducible_to_power ;
195 num_order_m = statistics.num_order_m ;
196 num_order_r = statistics.num_order_r ;
197
198 return *this ;
199}
200
201
202
203/*=============================================================================
204 |
205 | NAME
206 |
207 | OperationCount
208 |
209 | DESCRIPTION
210 |
211 | Print out a report of the operation count to the console.
212 |
213 +============================================================================*/
214
215ostream & operator<<( ostream & out, const OperationCount & op )
216{
217 out << "+--------- OperationCount --------------------------------\n" ;
218 out << "|\n" ;
219 out << "| Integer factorization: Table lookup + Trial division + Pollard Rho\n" ;
220 out << "|\n" ;
221 out << "| Number of trial divisions : " << op.num_trial_divides << endl ;
222 out << "| Number of gcd's computed : " << op.num_gcds << endl ;
223 out << "| Number of primality tests : " << op.num_primality_tests << endl ;
224 out << "| Number of squarings: " << op.num_squarings << endl ;
225 out << "|\n" ;
226 out << "| Polynomial Testing\n" ;
227 out << "|\n" ;
228 out << "| Total num. degree " << op.n << " poly mod " << op.p << " : " << op.max_num_possible_poly << endl ;
229 out << "| Number of possible primitive poly: " << op.num_primitive_poly << endl ;
230 out << "| Polynomials tested : " << op.num_poly_tested << endl ;
231 out << "| Const. coeff. was primitive root : " << op.num_where_const_coeff_is_primitive_root << endl ;
232 out << "| Free of linear factors : " << op.num_free_of_linear_factors << endl ;
233 out << "| Irreducible to power >=1 : " << op.num_irreducible_to_power << endl ;
234 out << "| Had order r (x^r = integer) : " << op.num_order_r << endl ;
235 out << "| Passed const. coeff. test : " << op.num_passing_const_coeff_test << endl ;
236 out << "| Had order m (x^m != integer) : " << op.num_order_m << endl ;
237 out << "|\n" ;
238 out << "+-----------------------------------------------------\n" ;
239
240 return out ;
241}