File: array-profile-main.c

package info (click to toggle)
libzn-poly 0.9.2-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, bullseye, forky, sid, trixie
  • size: 904 kB
  • sloc: ansic: 10,736; python: 124; makefile: 12; sh: 6
file content (111 lines) | stat: -rw-r--r-- 3,338 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/*
   array-profile-main.c:  program for profiling simple array operations
   
   Copyright (C) 2007, 2008, David Harvey
   
   This file is part of the zn_poly library (version 0.9).
   
   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 2 of the License, or
   (at your option) version 3 of the License.

   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/>.

*/


#include <math.h>
#include "support.h"
#include "profiler.h"
#include "zn_poly_internal.h"
#include "zn_poly.h"


char* type_str[3] = {"add", "sub", "bfly"};
char* speed_str[2] = {"safe", "slim"};


void
prof_main (int argc, char* argv[])
{
   ulong type, speed;
   double result, spread;
   
   printf ("\n");

   // profile various butterfly loops
   for (type = 0; type < 3; type++)
   for (speed = 0; speed < 2; speed++)
   {
      ulong arg[2];
      arg[0] = type;
      arg[1] = speed;
      
      result = profile (&spread, NULL, profile_bfly, arg, 1.0) / 1000;
      
      printf (" %4s %s, cycles/coeff = %6.2lf (%.1lf%%)\n",
              type_str[type], speed_str[speed], result, 100 * spread);
   }
   
   // profile mpn_add_n and mpn_sub_n
   for (type = 0; type < 2; type++)
   {
      ulong arg[1];
      arg[0] = type;

      result = profile (&spread, NULL, profile_mpn_aors, arg, 1.0) / 1000;
   
      printf (" mpn_%s_n, cycles/limb  = %6.2lf (%.1lf%%)\n",
              type_str[type], result, 100 * spread);
   }

   // profile zn_array_scalar_mul
   {
      ulong arg[2];
      arg[1] = 0;
   
      arg[0] = ULONG_BITS - 1;
      result = profile (&spread, NULL, profile_scalar_mul, arg, 1.0) / 1000;
      printf ("scalar_mul (> half-word), cycles/coeff = %6.2lf (%.1lf%%)\n",
              result, 100 * spread);

      arg[0] = ULONG_BITS/2 - 1;
      result = profile (&spread, NULL, profile_scalar_mul, arg, 1.0) / 1000;
      printf ("scalar_mul (< half-word), cycles/coeff = %6.2lf (%.1lf%%)\n",
              result, 100 * spread);
   }

   // profile zn_array_scalar_mul with REDC
   {
      ulong arg[2];
      arg[1] = 1;

      arg[0] = ULONG_BITS;
      result = profile (&spread, NULL, profile_scalar_mul, arg, 1.0) / 1000;
      printf ("scalar_mul (> half-word, non-slim, REDC), "
              "cycles/coeff = %6.2lf (%.1lf%%)\n",
              result, 100 * spread);

      arg[0] = ULONG_BITS - 1;
      result = profile (&spread, NULL, profile_scalar_mul, arg, 1.0) / 1000;
      printf ("scalar_mul (> half-word, REDC), "
              "cycles/coeff = %6.2lf (%.1lf%%)\n",
              result, 100 * spread);

      arg[0] = ULONG_BITS/2 - 1;
      result = profile (&spread, NULL, profile_scalar_mul, arg, 1.0) / 1000;
      printf ("scalar_mul (< half-word, REDC), "
              "cycles/coeff = %6.2lf (%.1lf%%)\n",
              result, 100 * spread);
   }
}


// end of file ****************************************************************