File: tpoints.cc

package info (click to toggle)
eclib 20250122-2
  • links: PTS, VCS
  • area: main
  • in suites: sid, trixie
  • size: 5,916 kB
  • sloc: cpp: 45,414; makefile: 272; sh: 127
file content (124 lines) | stat: -rw-r--r-- 3,981 bytes parent folder | download | duplicates (2)
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
112
113
114
115
116
117
118
119
120
121
122
123
124
// tpoints.cc -- to test points.h/cc
//////////////////////////////////////////////////////////////////////////
//
// Copyright 1990-2023 John Cremona
// 
// This file is part of the eclib package.
// 
// eclib 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) any later version.
// 
// eclib 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 eclib; if not, write to the Free Software Foundation,
// Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
// 
//////////////////////////////////////////////////////////////////////////
//

#include <eclib/points.h>

int main(){
#ifdef MPFP
  set_precision(100);
#else
  set_precision("Enter precision in bits");
#endif
  initprimes("PRIMES",1);

  Curve c(0,0,1,-7,6);
  Curvedata cd(c,1);

  cout << "Testing some points:\n";
  Point P0(cd, bigint(0),bigint(2)) ;
  Point P1(cd, bigint(1),bigint(0)) ;
  Point P2(cd, bigint(2),bigint(0)) ;
  cout << "The points are P0 = " << P0 << 
    ", P1 = " << P1 << ", and P2 = " << P2 << endl ;
  cout << "Now in Pari format:\n";
  cout << "The points are P0 = "; output_pari(cout,P0); 
  cout << ", P1 = ";              output_pari(cout,P1); 
  cout << ", and P2 = ";          output_pari(cout,P2); cout << endl ;
  if (!P0.isvalid()) cout << "P0 is not on the curve!\n";
  if (!P1.isvalid()) cout << "P1 is not on the curve!\n";
  if (!P2.isvalid()) cout << "P2 is not on the curve!\n";
  cout << "Their negatives are -P0 = " << -P0 << 
    ", -P1 = " << -P1 << ", and -P2 = " << -P2 << endl ;
        
  cout << "Computing their heights:\n";
  bigfloat ht0 = height(P0) ;
  bigfloat ht1 = height(P1) ;
  bigfloat ht2 = height(P2) ;

  cout << "Heights are " << ht0 << ", " << ht1 << ", and " << ht2 << endl ;
        
  Point origin(cd);
  cout << "The origin is " << origin << endl;
  cout << "Now some additions etc,:\n";
  Point sum = P0 + P1 ;
  cout << "P0 + P1 = " << sum << endl ;
  sum = P0 - P1 ;
  cout << "P0 - P1 = " << sum << endl ;
  sum -= P2 ;
  cout << "P0 - P1 - P2 = " << sum << endl ;
  sum = P0.twice();
  cout << "P0.twice() = " << sum << endl;
  sum = P0 + P0;
  cout << "P0 + P0 = " << sum << endl;
  sum = 3*P0;
  cout << "3*P0 = " << sum << endl;
  sum = P0 - P0;
  cout << "P0 - P0 = " << sum << endl;
  sum = P0 + 3 * P1 - P2 ;
  cout << "P0 +3 P1 - P2 = " << sum << endl ;
  sum = 2*P0 + 2* P1 + P2 ;
  cout << "2P0 +2 P1 + P2 = " << sum << endl ;

  cout << "Now we try a systematic exploration" << endl ;
  int loop=1;
  //  cout << "input 0 to skip: ";  cin >> loop;
  if (loop)
    {
      Point Q0,Q1,Q2; int i0,i1,i2;
      for(i0 = -3, Q0=-3*(P0+P1+P2) ; i0 < 4 ; i0++, Q0+=P0){
	for(i1 = -3, Q1=Q0 ; i1 < 4 ; i1++, Q1+=P1){
	  for(i2 = -3, Q2=Q1 ; i2 < 4 ; i2++, Q2+=P2){
	    cout << i0 << ", " << i1 <<", " << i2<< ": " << Q2 << endl ;
	  }
	}
      }
    }

  sum = P0 -P1 -P2 ;
  cout << "P0 -P1 -P2 = " << sum << endl ;
  cout << "Height of     P0-P1-P2 = " << flush;
  bigfloat htsum = height(sum) ;
  cout << htsum << endl ;
        
  cout <<"3 (P0 -P1 -P2) = " << flush;  
  Point triplesum = 3 * sum ;
  cout << triplesum << endl ;

  cout << "Height of 3*(P0-P1-P2) = " << flush;
  bigfloat ht3sum = height(triplesum) ;
  cout << ht3sum << endl ;
        
  cout << "The quotient is " << ht3sum/htsum << endl ;
        
  /*
  vector<Point> pointlist(3); // won't initialize
  pointlist[0] = P0; pointlist[1] = P1; pointlist[2] = P2 ;
  bigfloat reg = regulator(pointlist) ;

  cout << "The regulator of P0, P1, P2 is " << reg << endl ;      
  */
  return 0;
} //ends main

//ends file tpoints.cc