File: app_tropicalbasis.cpp

package info (click to toggle)
gfan 0.6.2-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 8,372 kB
  • sloc: cpp: 53,144; makefile: 556
file content (100 lines) | stat: -rw-r--r-- 3,123 bytes parent folder | download | duplicates (6)
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
#include "parser.h"
#include "printer.h"
#include "polynomial.h"
#include "division.h"
#include "buchberger.h"
#include "wallideal.h"
#include "lp.h"
#include "reversesearch.h"
#include "termorder.h"
#include "ep_standard.h"
#include "ep_xfig.h"
#include "gfanapplication.h"
#include "polyhedralcone.h"
#include "polyhedralfan.h"
#include "tropical.h"
#include "tropical2.h"
#include "tropicalbasis.h"
#include "log.h"

class TropicalBasisApplication : public GFanApplication
{

  SimpleOption optionHomogenize;
public:
  const char *helpText()
  {
    return "This program computes a tropical basis for an ideal defining a tropical curve. Defining a tropical curve means that the Krull dimension of R/I is at most 1 + the dimension of the homogeneity space of I where R is the polynomial ring. The input is a generating set for the ideal. If the input is not homogeneous option -h must be used.\n";
  }
  TropicalBasisApplication():
    optionHomogenize("-h","Homogenise the input before computing a tropical basis and dehomogenise the output. This is needed if the input generators are not already homogeneous.")
  {
    registerOptions();
  }

  const char *name()
  {
    return "_tropicalbasis";
  }
  int main()
  {
    FileParser P(Stdin);

    /*    StringParser P1("{1+76*a2*b*c+6*a2*c4+72*a*b3*c3,"
		    "46*b3*c+68*b3*a2*c+42*a3*c4+47*b6*a2}");
    StringParser P2("{1-79ab^4-27b^3c^2+32a^4b^2c,"
		    "-36c-35b^3c^3+11a^4b^2c^2+90a^3b^6}");
    */
    PolynomialSet theInput=P.parsePolynomialSetWithRing();
    PolynomialRing originalRing=theInput.getRing();

    if(optionHomogenize.getValue())
      {
	log1 fprintf(Stderr,"Homogenizing...\n");
	IntegerVector grading=IntegerVector::allOnes(theInput.numberOfVariablesInRing());

	/*	{  // It is not necessary to compute the true homogenization
	  WeightReverseLexicographicTermOrder t(grading);
	  buchberger(&theInput,t);
	  }*/

	PolynomialSet h=theInput.homogenization(theInput.getRing().withVariablesAppended("H"));
wallInequalities(h);

	log1 fprintf(Stderr,"The homogenized ideal:\n");
	log1 AsciiPrinter(Stderr).printPolynomialSet(h);

	theInput=h;
      }


    int n=theInput.numberOfVariablesInRing();

    int homog=-1;
    {
      log1 debug.printString("Computing homogeneity space\n");
      PolynomialSet idealGroebnerBasis=theInput;
      IntegerVector grading=IntegerVector::allOnes(theInput.numberOfVariablesInRing());
      WeightReverseLexicographicTermOrder t(grading);
      buchberger(&idealGroebnerBasis,t);
      PolyhedralCone hspace=homogeneitySpace(idealGroebnerBasis);
      IntegerVectorList hv=hspace.dualCone().getEquations();
      homog=hv.size();
      log1 debug.printString("..done homogeneity space.\n");
    }

    PolynomialSet theOutput=tropicalBasisOfCurve(n,theInput,0,homog);

    if(optionHomogenize.getValue())
      {
	theOutput=theOutput.embeddedInto(originalRing);
      }
    AsciiPrinter(Stdout).printPolynomialRing(theOutput.getRing());
    AsciiPrinter(Stdout).printNewLine();
    AsciiPrinter(Stdout).printPolynomialSet(theOutput);

    return 0;
  }
};

static TropicalBasisApplication theApplication;