File: tropical_weildivisor.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 (116 lines) | stat: -rw-r--r-- 3,278 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
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
#include "tropical_weildivisor.h"
#include "tropical2.h"
#include "log.h"
#include "printer.h"
#include <iostream>

PolyhedralFan weilDivisor(PolyhedralFan const &F, PolyhedralFan const &G)//, Polynomial const &g)
{
  //  PolynomialRing R=g.getRing();
  //  PolyhedralFan G=PolyhedralFan::bergmanOfPrincipalIdeal(g);
  int n=G.getAmbientDimension();
  int d=F.getMaxDimension();

  PolyhedralFan retTemp(n);

  log1 cerr<<"Computing refinement"<<endl;
  for(PolyhedralConeList::const_iterator i=F.conesBegin();i!=F.conesEnd();i++)
    {
      log1 cerr<<"*";

#if 1
      bool found=false;
      {
        IntegerVector v=i->getRelativeInteriorPoint();
        PolyhedralCone c=G.coneContaining(v);
        if(!(c!=*i))
          {
            retTemp.insert(c);
            found=true;
          }
      }
      if(!found)
#endif
      for(PolyhedralConeList::const_iterator j=G.conesBegin();j!=G.conesEnd();j++)
	{
	  PolyhedralCone c=intersection(*i,*j);
	  c.canonicalize();
	  retTemp.insert(c);
	}
    }

  log1 cerr<<"Computing full complex"<<endl;
  retTemp=retTemp.fullComplex();
  PolyhedralFan ret(n);

  log1 cerr<<"Computing divisor"<<endl;
  for(PolyhedralConeList::iterator i=retTemp.conesBegin();i!=retTemp.conesEnd();i++)
    {
      log1 cerr<<"*";
      if(i->dimension()==d-1)
	{
	  IntegerVector v=i->getRelativeInteriorPoint();

	  AsciiPrinter P(Stderr);

	  log2 P<<v<<v<<"\n";

	  int multiplicity=0;
	  IntegerVector evaluationVector(n);

	  //	  Polynomial localg=initialForm(g,v);
	  //	  PolyhedralFan localG=PolyhedralFan::normalFanOfNewtonPolytope(localg);
	  PolyhedralFan localG=G.link(v);

	  for(PolyhedralConeList::const_iterator j=F.conesBegin();j!=F.conesEnd();j++)
	    {
	      if(j->contains(v))
		{
		  IntegerVectorList equations=j->getEquations();
		  IntegerVectorList inequalities1=j->getHalfSpaces();
		  IntegerVectorList inequalities2;
		  for(IntegerVectorList::const_iterator i=inequalities1.begin();i!=inequalities1.end();i++)
		    if(dotLong(v,*i)==0)inequalities2.push_back(*i);
		  PolyhedralCone localJ(inequalities2,equations,n);
		  localJ.canonicalize();

		  PolyhedralFan refinement(n);
		  for(PolyhedralConeList::const_iterator k=localG.conesBegin();k!=localG.conesEnd();k++)
		    {
		      PolyhedralCone sigma=intersection(localJ,*k);
		      sigma.canonicalize();
		      refinement.insert(sigma);
		    }

		  for(PolyhedralConeList::const_iterator k=refinement.conesBegin();k!=refinement.conesEnd();k++)
		    {
		      PolyhedralCone const &sigma(*k);
		      if(sigma.dimension()==d)
			{
			  /*IntegerVectorList rays=sigma.extremeRays();
			  assert(rays.size()==1);//SHOULD ALWAYS BE TRUE????
			  {
			    IntegerVector ray=*rays.begin();
			*/
			  IntegerVector ray=sigma.semiGroupGeneratorOfRay();
			  evaluationVector+=j->getMultiplicity()*ray;
			  //multiplicity+=j->getMultiplicity()*localg.degree(ray);
			  multiplicity+=j->getMultiplicity()*localG.evaluatePiecewiseLinearFunction(ray);
			}
		    }

		}
	    }
	  //multiplicity-=localg.degree(evaluationVector);
	  multiplicity-=localG.evaluatePiecewiseLinearFunction(evaluationVector);
	  if(multiplicity!=0)
	    {
	      PolyhedralCone c=*i;
	      c.setMultiplicity(multiplicity);
	      ret.insert(c);
	    }
	}
    }

  return ret;
}