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
|
// FILE NFTEST.CC: test program for newform constructor
//////////////////////////////////////////////////////////////////////////
//
// Copyright 1990-2012 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/interface.h>
#include <eclib/moddata.h>
#include <eclib/symb.h>
#include <eclib/cusp.h>
#include <eclib/homspace.h>
#include <eclib/oldforms.h>
#include <eclib/cperiods.h>
#include <eclib/newforms.h>
//#define AUTOLOOP
#define LMFDB_ORDER // if defined, sorts newforms into LMFDB order before output
int main(void)
{
int limit,firstn,n=1,count=0;
int verbose=1;
#ifdef AUTOLOOP
cerr<<"Enter first and last N: ";cin>>firstn>>limit;
n=firstn-1; cout<<endl;
while (n<limit) { n++;
#else
verbose=1;
while (n>0) { cerr<<"Enter level: "; cin>>n;
#endif
if (n>0)
{
cout << ">>> Level " << n << " <<<\t";
newforms nf(n,verbose);
cout << "\nAfter constructor, about to createfromdata() \n";
nf.createfromdata(1,25);
int num = nf.n1ds; count+=num;
cout << num << " newform(s), "<<nf.nap<<" eigs on file." << endl;
#ifdef LMFDB_ORDER
nf.sort();
#endif
// nf.makebases();
/*
nf.sort();
cout<<"After sort():"<<endl;
nf.display();
nf.sort(1);
cout<<"After sort(1):"<<endl;
*/
nf.display();
} // end of if(n)
} // end of while()
#ifdef AUTOLOOP
cout << "\n" << count << " newform(s) in range " << firstn << "..." << limit << endl;
#endif
} // end of main()
|