@@ -113,7 +113,6 @@ def random_WehlerK3Surface(PP):
113
113
114
114
class WehlerK3Surface_ring (AlgebraicScheme_subscheme_product_projective ):
115
115
r"""
116
-
117
116
A K3 surface in `\mathbb{P}^2 \times \mathbb{P}^2` defined as the
118
117
intersection of a bilinear and biquadratic form. [Weh1998]_
119
118
@@ -807,7 +806,7 @@ def degenerate_fibers(self):
807
806
vars = list (PSX .gens ())
808
807
K = FractionField (PSX .base_ring ())
809
808
R0 = PolynomialRing (K , 3 , vars )
810
- I = R .ideal (self .Gpoly (1 , 0 ), self .Gpoly (1 , 1 ), self .Gpoly (1 , 2 ), self .Hpoly (1 , 0 ,1 ), \
809
+ I = R .ideal (self .Gpoly (1 , 0 ), self .Gpoly (1 , 1 ), self .Gpoly (1 , 2 ), self .Hpoly (1 , 0 ,1 ),
811
810
self .Hpoly (1 , 0 , 2 ), self .Hpoly (1 , 1 , 2 ))
812
811
phi = R .hom (vars + [0 , 0 , 0 ], R0 )
813
812
I = phi (I )
@@ -838,7 +837,7 @@ def degenerate_fibers(self):
838
837
vars = list (PSY .gens ())
839
838
K = FractionField (PSY .base_ring ())
840
839
R0 = PolynomialRing (K , 3 , vars )
841
- I = R .ideal (self .Gpoly (0 , 0 ), self .Gpoly (0 , 1 ), self .Gpoly (0 , 2 ), self .Hpoly (0 , 0 , 1 ), \
840
+ I = R .ideal (self .Gpoly (0 , 0 ), self .Gpoly (0 , 1 ), self .Gpoly (0 , 2 ), self .Hpoly (0 , 0 , 1 ),
842
841
self .Hpoly (0 , 0 , 2 ), self .Hpoly (0 , 1 , 2 ))
843
842
phi = PP .coordinate_ring ().hom ([0 , 0 , 0 ] + vars , R0 )
844
843
I = phi (I )
@@ -1108,16 +1107,16 @@ def sigmaX(self, P, **kwds):
1108
1107
raise TypeError ("%s fails to convert into the map's domain %s, but a `pushforward` method is not properly implemented" % (P , self ))
1109
1108
pt = list (P [0 ]) + [0 , 0 , 0 ]
1110
1109
if P [1 ][0 ] != 0 :
1111
- [a ,b ,c ] = [P [1 ][0 ]* self .Gpoly (1 , 0 )(* pt ),\
1112
- - 1 * P [1 ][0 ]* self .Hpoly (1 , 0 , 1 )(* pt ) - P [1 ][1 ]* self .Gpoly (1 , 0 )(* pt ),\
1110
+ [a ,b ,c ] = [P [1 ][0 ]* self .Gpoly (1 , 0 )(* pt ),
1111
+ - 1 * P [1 ][0 ]* self .Hpoly (1 , 0 , 1 )(* pt ) - P [1 ][1 ]* self .Gpoly (1 , 0 )(* pt ),
1113
1112
- P [1 ][0 ]* self .Hpoly (1 , 0 , 2 )(* pt ) - P [1 ][2 ]* self .Gpoly (1 , 0 )(* pt )]
1114
1113
elif P [1 ][1 ] != 0 :
1115
- [a ,b ,c ] = [- 1 * P [1 ][1 ]* self .Hpoly (1 , 0 , 1 )(* pt )- P [1 ][0 ]* self .Gpoly (1 , 1 )(* pt ),\
1116
- P [1 ][1 ]* self .Gpoly (1 , 1 )(* pt ),\
1114
+ [a ,b ,c ] = [- 1 * P [1 ][1 ]* self .Hpoly (1 , 0 , 1 )(* pt )- P [1 ][0 ]* self .Gpoly (1 , 1 )(* pt ),
1115
+ P [1 ][1 ]* self .Gpoly (1 , 1 )(* pt ),
1117
1116
- P [1 ][1 ]* self .Hpoly (1 , 1 , 2 )(* pt )- P [1 ][2 ]* self .Gpoly (1 , 1 )(* pt )]
1118
1117
else :
1119
- [a ,b ,c ] = [- 1 * P [1 ][2 ]* self .Hpoly (1 , 0 , 2 )(* pt ) - P [1 ][0 ]* self .Gpoly (1 , 2 )(* pt ),\
1120
- - P [1 ][2 ]* self .Hpoly (1 , 1 , 2 )(* pt ) - P [1 ][1 ]* self .Gpoly (1 , 2 )(* pt ),\
1118
+ [a ,b ,c ] = [- 1 * P [1 ][2 ]* self .Hpoly (1 , 0 , 2 )(* pt ) - P [1 ][0 ]* self .Gpoly (1 , 2 )(* pt ),
1119
+ - P [1 ][2 ]* self .Hpoly (1 , 1 , 2 )(* pt ) - P [1 ][1 ]* self .Gpoly (1 , 2 )(* pt ),
1121
1120
P [1 ][2 ]* self .Gpoly (1 , 2 )(* pt )]
1122
1121
Point = [P [0 ][0 ], P [0 ][1 ], P [0 ][2 ], a , b , c ]
1123
1122
@@ -1148,13 +1147,13 @@ def sigmaX(self, P, **kwds):
1148
1147
t = w1 - t1
1149
1148
phi = R .hom ([s1 * (t ) + s0 * P [0 ][0 ]/ P [0 ][2 ], s0 * w1 , s0 , z0 , z1 , z2 ], S )
1150
1149
1151
- #Blow-up the fiber
1152
- T = [phi (self .L ),phi (self .Q ),\
1153
- phi (self .Gpoly (1 , 0 )),\
1154
- phi (self .Gpoly (1 , 1 )),\
1155
- phi (self .Gpoly (1 , 2 )),\
1156
- - phi (self .Hpoly (1 , 0 , 1 )),\
1157
- - phi (self .Hpoly (1 , 0 , 2 )),\
1150
+ # Blow-up the fiber
1151
+ T = [phi (self .L ),phi (self .Q ),
1152
+ phi (self .Gpoly (1 , 0 )),
1153
+ phi (self .Gpoly (1 , 1 )),
1154
+ phi (self .Gpoly (1 , 2 )),
1155
+ - phi (self .Hpoly (1 , 0 , 1 )),
1156
+ - phi (self .Hpoly (1 , 0 , 2 )),
1158
1157
- phi (self .Hpoly (1 , 1 , 2 ))]
1159
1158
maxexp = []
1160
1159
@@ -1182,11 +1181,11 @@ def sigmaX(self, P, **kwds):
1182
1181
#on the fiber
1183
1182
RR = PolynomialRing (BR , 5 ,'s0, s1, z0, z1, z2' ,order = 'lex' )
1184
1183
s0 , s1 , z0 , z1 , z2 = RR .gens ()
1185
- I = RR .ideal ([RR (T [0 ]), \
1186
- RR (T [1 ]), \
1187
- RR (T [2 ]) - P [1 ][0 ]* z0 , RR (T [3 ]) - P [1 ][1 ]* z1 , RR (T [4 ])- P [1 ][2 ]* z2 , \
1188
- RR (T [5 ]) - (P [1 ][0 ]* z1 + P [1 ][1 ]* z0 ), \
1189
- RR (T [6 ]) - (P [1 ][0 ]* z2 + P [1 ][2 ]* z0 ), \
1184
+ I = RR .ideal ([RR (T [0 ]),
1185
+ RR (T [1 ]),
1186
+ RR (T [2 ]) - P [1 ][0 ]* z0 , RR (T [3 ]) - P [1 ][1 ]* z1 , RR (T [4 ])- P [1 ][2 ]* z2 ,
1187
+ RR (T [5 ]) - (P [1 ][0 ]* z1 + P [1 ][1 ]* z0 ),
1188
+ RR (T [6 ]) - (P [1 ][0 ]* z2 + P [1 ][2 ]* z0 ),
1190
1189
RR (T [7 ]) - (P [1 ][1 ]* z2 + P [1 ][2 ]* z1 )])
1191
1190
1192
1191
#Find the points
@@ -1225,13 +1224,13 @@ def sigmaX(self, P, **kwds):
1225
1224
for i in range (2 ,len (T )):
1226
1225
newT [i ] = newT [i ]/ s ** e
1227
1226
#Create the new ideal
1228
- II = SS .ideal ([SS (newT [0 ]), \
1229
- SS (newT [1 ]), \
1230
- SS (newT [2 ]) - P [1 ][0 ]* z0 , \
1231
- SS (newT [3 ]) - P [1 ][1 ]* z1 , \
1232
- SS (newT [4 ]) - P [1 ][2 ]* z2 , \
1233
- SS (newT [5 ]) - (P [1 ][0 ]* z1 + P [1 ][1 ]* z0 ), \
1234
- SS (newT [6 ]) - (P [1 ][0 ]* z2 + P [1 ][2 ]* z0 ), \
1227
+ II = SS .ideal ([SS (newT [0 ]),
1228
+ SS (newT [1 ]),
1229
+ SS (newT [2 ]) - P [1 ][0 ]* z0 ,
1230
+ SS (newT [3 ]) - P [1 ][1 ]* z1 ,
1231
+ SS (newT [4 ]) - P [1 ][2 ]* z2 ,
1232
+ SS (newT [5 ]) - (P [1 ][0 ]* z1 + P [1 ][1 ]* z0 ),
1233
+ SS (newT [6 ]) - (P [1 ][0 ]* z2 + P [1 ][2 ]* z0 ),
1235
1234
SS (newT [7 ]) - (P [1 ][1 ]* z2 + P [1 ][2 ]* z1 )])
1236
1235
1237
1236
#Find the points
@@ -1350,16 +1349,16 @@ def sigmaY(self,P, **kwds):
1350
1349
raise TypeError ("%s fails to convert into the map's domain %s, but a `pushforward` method is not properly implemented" % (P , self ))
1351
1350
pt = [0 , 0 , 0 ] + list (P [1 ])
1352
1351
if P [0 ][0 ] != 0 :
1353
- [a , b , c ] = [P [0 ][0 ]* self .Gpoly (0 , 0 )(* pt ), \
1354
- - 1 * P [0 ][0 ]* self .Hpoly (0 , 0 , 1 )(* pt ) - P [0 ][1 ]* self .Gpoly (0 , 0 )(* pt ), \
1352
+ [a , b , c ] = [P [0 ][0 ]* self .Gpoly (0 , 0 )(* pt ),
1353
+ - 1 * P [0 ][0 ]* self .Hpoly (0 , 0 , 1 )(* pt ) - P [0 ][1 ]* self .Gpoly (0 , 0 )(* pt ),
1355
1354
- P [0 ][0 ]* self .Hpoly (0 , 0 , 2 )(* pt ) - P [0 ][2 ]* self .Gpoly (0 , 0 )(* pt )]
1356
1355
elif P [0 ][1 ] != 0 :
1357
- [a , b , c ] = [- 1 * P [0 ][1 ]* self .Hpoly (0 , 0 , 1 )(* pt ) - P [0 ][0 ]* self .Gpoly (0 , 1 )(* pt ),\
1358
- P [0 ][1 ]* self .Gpoly (0 , 1 )(* pt ), \
1356
+ [a , b , c ] = [- 1 * P [0 ][1 ]* self .Hpoly (0 , 0 , 1 )(* pt ) - P [0 ][0 ]* self .Gpoly (0 , 1 )(* pt ),
1357
+ P [0 ][1 ]* self .Gpoly (0 , 1 )(* pt ),
1359
1358
- P [0 ][1 ]* self .Hpoly (0 , 1 , 2 )(* pt ) - P [0 ][2 ]* self .Gpoly (0 , 1 )(* pt )]
1360
1359
else :
1361
- [a , b , c ] = [- 1 * P [0 ][2 ]* self .Hpoly (0 , 0 , 2 )(* pt ) - P [0 ][0 ]* self .Gpoly (0 , 2 )(* pt ), \
1362
- - P [0 ][2 ]* self .Hpoly (0 , 1 , 2 )(* pt ) - P [0 ][1 ]* self .Gpoly (0 , 2 )(* pt ), \
1360
+ [a , b , c ] = [- 1 * P [0 ][2 ]* self .Hpoly (0 , 0 , 2 )(* pt ) - P [0 ][0 ]* self .Gpoly (0 , 2 )(* pt ),
1361
+ - P [0 ][2 ]* self .Hpoly (0 , 1 , 2 )(* pt ) - P [0 ][1 ]* self .Gpoly (0 , 2 )(* pt ),
1363
1362
P [0 ][2 ]* self .Gpoly (0 , 2 )(* pt )]
1364
1363
Point = [a , b , c , P [1 ][0 ], P [1 ][1 ], P [1 ][2 ]]
1365
1364
if [a , b , c ] != [0 , 0 , 0 ]:
@@ -1391,13 +1390,13 @@ def sigmaY(self,P, **kwds):
1391
1390
phi = R .hom ([z0 , z1 , z2 , s1 * (t ) + s0 * P [1 ][0 ]/ P [1 ][2 ], s0 * w1 , s0 ], S )
1392
1391
1393
1392
#Blow-up the fiber
1394
- T = [phi (self .L ),\
1395
- phi (self .Q ),\
1396
- phi (self .Gpoly (0 , 0 )), \
1397
- phi (self .Gpoly (0 , 1 )), \
1398
- phi (self .Gpoly (0 , 2 )), \
1399
- - phi (self .Hpoly (0 , 0 , 1 )), \
1400
- - phi (self .Hpoly (0 , 0 , 2 )), \
1393
+ T = [phi (self .L ),
1394
+ phi (self .Q ),
1395
+ phi (self .Gpoly (0 , 0 )),
1396
+ phi (self .Gpoly (0 , 1 )),
1397
+ phi (self .Gpoly (0 , 2 )),
1398
+ - phi (self .Hpoly (0 , 0 , 1 )),
1399
+ - phi (self .Hpoly (0 , 0 , 2 )),
1401
1400
- phi (self .Hpoly (0 , 1 , 2 ))]
1402
1401
maxexp = []
1403
1402
@@ -1422,13 +1421,13 @@ def sigmaY(self,P, **kwds):
1422
1421
# on the fiber
1423
1422
RR = PolynomialRing (BR , 5 , 's0, s1, z0, z1, z2' , order = 'lex' )
1424
1423
s0 , s1 , z0 , z1 , z2 = RR .gens ()
1425
- I = RR .ideal ([RR (T [0 ]), \
1426
- RR (T [1 ]), \
1427
- RR (T [2 ]) - P [0 ][0 ]* z0 , \
1428
- RR (T [3 ]) - P [0 ][1 ]* z1 , \
1429
- RR (T [4 ]) - P [0 ][2 ]* z2 , \
1430
- RR (T [5 ]) - (P [0 ][0 ]* z1 + P [0 ][1 ]* z0 ), \
1431
- RR (T [6 ]) - (P [0 ][0 ]* z2 + P [0 ][2 ]* z0 ), \
1424
+ I = RR .ideal ([RR (T [0 ]),
1425
+ RR (T [1 ]),
1426
+ RR (T [2 ]) - P [0 ][0 ]* z0 ,
1427
+ RR (T [3 ]) - P [0 ][1 ]* z1 ,
1428
+ RR (T [4 ]) - P [0 ][2 ]* z2 ,
1429
+ RR (T [5 ]) - (P [0 ][0 ]* z1 + P [0 ][1 ]* z0 ),
1430
+ RR (T [6 ]) - (P [0 ][0 ]* z2 + P [0 ][2 ]* z0 ),
1432
1431
RR (T [7 ]) - (P [0 ][1 ]* z2 + P [0 ][2 ]* z1 )])
1433
1432
#Find the points
1434
1433
SS = PolynomialRing (BR , 4 , 's, z0, z1, z2' , order = 'lex' )
@@ -1465,14 +1464,14 @@ def sigmaY(self,P, **kwds):
1465
1464
for i in range (2 ,len (T )):
1466
1465
newT [i ] = newT [i ]/ s ** e
1467
1466
#Create the new ideal
1468
- II = SS .ideal ([SS (newT [0 ]), \
1469
- SS (newT [1 ]), \
1470
- SS (newT [2 ]) - P [0 ][0 ]* z0 , \
1471
- SS (newT [3 ]) - P [0 ][1 ]* z1 , \
1472
- SS (newT [4 ]) - P [0 ][2 ]* z2 , \
1473
- SS (newT [5 ]) - (P [0 ][0 ]* z1 + P [0 ][1 ]* z0 ), \
1474
- SS (newT [6 ]) - (P [0 ][0 ]* z2 + P [0 ][2 ]* z0 ), \
1475
- SS (newT [7 ]) - (P [0 ][1 ]* z2 + P [0 ][2 ]* z1 )])
1467
+ II = SS .ideal ([SS (newT [0 ]),
1468
+ SS (newT [1 ]),
1469
+ SS (newT [2 ]) - P [0 ][0 ]* z0 ,
1470
+ SS (newT [3 ]) - P [0 ][1 ]* z1 ,
1471
+ SS (newT [4 ]) - P [0 ][2 ]* z2 ,
1472
+ SS (newT [5 ]) - (P [0 ][0 ]* z1 + P [0 ][1 ]* z0 ),
1473
+ SS (newT [6 ]) - (P [0 ][0 ]* z2 + P [0 ][2 ]* z0 ),
1474
+ SS (newT [7 ]) - (P [0 ][1 ]* z2 + P [0 ][2 ]* z1 )])
1476
1475
# Find the points
1477
1476
SSS = PolynomialRing (BR , 3 , 'z0, z1, z2' , order = 'lex' )
1478
1477
z0 , z1 , z2 = SSS .gens ()
@@ -1633,11 +1632,11 @@ def lambda_plus(self, P, v, N, m, n, prec = 100):
1633
1632
K = Qp (v , prec )
1634
1633
PK = P .change_ring (K )
1635
1634
W = self .change_ring (K )
1636
- Rx = W .ambient_space ().coordinate_ring ().hom (\
1637
- list (W .ambient_space ()[0 ].coordinate_ring ().gens ())+ [0 , 0 , 0 ], \
1635
+ Rx = W .ambient_space ().coordinate_ring ().hom (
1636
+ list (W .ambient_space ()[0 ].coordinate_ring ().gens ()) + [0 , 0 , 0 ],
1638
1637
W .ambient_space ()[0 ].coordinate_ring ())
1639
- Ry = W .ambient_space ().coordinate_ring ().hom (\
1640
- [0 , 0 , 0 ] + list (W .ambient_space ()[1 ].coordinate_ring ().gens ()), \
1638
+ Ry = W .ambient_space ().coordinate_ring ().hom (
1639
+ [0 , 0 , 0 ] + list (W .ambient_space ()[1 ].coordinate_ring ().gens ()),
1641
1640
W .ambient_space ()[1 ].coordinate_ring ())
1642
1641
beta = R (2 + sqrt (3 ))
1643
1642
L = [x .abs () for x in list (PK [0 ])]
@@ -1730,10 +1729,10 @@ def lambda_minus(self, P, v, N, m, n, prec=100):
1730
1729
K = Qp (v , prec )
1731
1730
PK = P .change_ring (K )
1732
1731
W = self .change_ring (K )
1733
- Rx = W .ambient_space ().coordinate_ring ().hom (list (W .ambient_space ()[0 ].coordinate_ring ().gens ())\
1734
- + [0 , 0 , 0 ],W .ambient_space ()[0 ].coordinate_ring ())
1735
- Ry = W .ambient_space ().coordinate_ring ().hom ([0 , 0 , 0 ] + \
1736
- list (W .ambient_space ()[1 ].coordinate_ring ().gens ()), \
1732
+ Rx = W .ambient_space ().coordinate_ring ().hom (list (W .ambient_space ()[0 ].coordinate_ring ().gens ())
1733
+ + [0 , 0 , 0 ], W .ambient_space ()[0 ].coordinate_ring ())
1734
+ Ry = W .ambient_space ().coordinate_ring ().hom ([0 , 0 , 0 ] +
1735
+ list (W .ambient_space ()[1 ].coordinate_ring ().gens ()),
1737
1736
W .ambient_space ()[1 ].coordinate_ring ())
1738
1737
beta = R (2 + sqrt (3 ))
1739
1738
L = [x .abs () for x in list (PK [0 ])]
0 commit comments