Rational Parametrizations of Rational Plane Curves

Note

In this section, CC will denote a complex projective plane curve, defined by an absolutely irreducible, homogeneous polynomial in three variables, with coefficients in Q\mathbb Q. Moreover, we will write n=degCn = \deg C.

Recall that the curve CC is rational if it is birationally equivalent to the projective line P1(C)\mathbb P^1(\mathbb C). In other words, there exists a rational parametrization of CC, that is, a birational map P1(C)C\mathbb P^1(\mathbb C)\dashrightarrow C. Note that such a parametrization is given by three homogeneous polynomials of the same degree in the homogeneous coordinates on P1(C)\mathbb P^1(\mathbb C).

Note

The curve CC is rational iff its geometric genus is zero.

Based on work of Max Noether on adjoint curves, Hilbert und Hurwitz showed that if CC is rational, then there is a birational map CDC \dashrightarrow D defined over Q\mathbb Q such that D=P1(C)D = \mathbb P^1(\mathbb C) if nn is odd, and DP2(C)D\subset\mathbb P^2(\mathbb C) is a conic if nn is even.

Note

If a conic DD contains a rational point, then there exists a parametrization of DD defined over Q\mathbb Q; otherwise, there exists a parametrization of DD defined over a quadratic field extension of Q\mathbb Q.

The approach of Hilbert und Hurwitz is constructive and allows one, in principle, to find rational parametrizations. The resulting algorithm is not very practical, however, as the approach asks to compute adjoint curves repeatedly, at each of a number of reduction steps.

The algorithm implemented in OSCAR relies on reduction steps of a different type and requires the computation of adjoint curves only once. Its individual steps are interesting in their own right:

  • Assure that the curve CC is rational by checking that its geometric genus is zero;
  • compute a basis of the adjoint curves of CC of degree n2{n-2}; each such basis defines a birational map CCn2,C \dashrightarrow C_{n-2}, where Cn2C_{n-2} is a rational normal curve in Pn2(C)\mathbb P^{n-2}(\mathbb C);
  • the anticanonical linear system on Cn2C_{n-2} defines a birational map Cn2Cn4C_{n-2}\dashrightarrow C_{n-4}, where Cn4C_{n-4} is a rational normal curve in in Pn4(C)\mathbb P^{n-4}(\mathbb C);
  • iterate the previous step to obtain a birational map Cn2DC_{n-2} \dashrightarrow \dots \dashrightarrow D, where D=P1(C)D = \mathbb P^1(\mathbb C) if nn is odd, and DP2(C)D\subset\mathbb P^2(\mathbb C) is a conic if nn is even;
  • invert the birational map CCn2DC \dashrightarrow C_{n-2} \dashrightarrow \dots \dashrightarrow D;
  • if nn is even, compute a parametrization of the conic DD and compose it with the inverted map above.
Note

The defining property of an adjoint curve is that it passes with “sufficiently high” multiplicity through the singularities of CC. There are several concepts of making this precise. For each such concept, there is a corresponding adjoint ideal of CC, namely the homogeneous ideal formed by the defining polynomials of the adjoint curves. In OSCAR, we follow the concept of Gorenstein which leads to the largest possible adjoint ideal.

See [Bhm99] and [BDLP17] for details and further references.

Adjoint Ideals of Plane Curves

adjoint_idealMethod
adjoint_ideal(C::ProjectivePlaneCurve{QQField})

Return the Gorenstein adjoint ideal of C.

Examples

julia> R, (x,y,z) = graded_polynomial_ring(QQ, [:x, :y, :z]);

julia> C = ProjectivePlaneCurve(y^4-2*x^3*z+3*x^2*z^2-2*y^2*z^2)
Projective plane curve
  defined by 0 = 2*x^3*z - 3*x^2*z^2 - y^4 + 2*y^2*z^2

julia> I = adjoint_ideal(C)
Ideal generated by
  -x*z + y^2
  x*y - y*z
  x^2 - x*z
source

Rational Points on Conics

rational_point_conicMethod
rational_point_conic(D::ProjectivePlaneCurve{QQField})

If the plane conic D contains a rational point, return the homogeneous coordinates of such a point. If no such point exists, return a point on D defined over a quadratic field extension of Q\mathbb Q.

Examples

julia> R, (x,y,z) = graded_polynomial_ring(QQ, [:x, :y, :z]);

julia> C = ProjectivePlaneCurve(y^4-2*x^3*z+3*x^2*z^2-2*y^2*z^2)
Projective plane curve
  defined by 0 = 2*x^3*z - 3*x^2*z^2 - y^4 + 2*y^2*z^2

julia> I = adjoint_ideal(C)
Ideal generated by
  -x*z + y^2
  x*y - y*z
  x^2 - x*z

julia> R, (x,y,z) = graded_polynomial_ring(QQ, [:x, :y, :z]);

julia> D = ProjectivePlaneCurve(x^2 + 2*y^2 + 5*z^2 - 4*x*y + 3*x*z + 17*y*z);

julia> P = rational_point_conic(D)
3-element Vector{AbstractAlgebra.Generic.MPoly{AbsSimpleNumFieldElem}}:
 -1//4*a
 -1//4*a + 1//4
 0

julia> S = parent(P[1])
Multivariate polynomial ring in 3 variables x, y, z
  over number field of degree 2 over QQ

julia> NF = base_ring(S)
Number field with defining polynomial t^2 - 2
  over rational field

julia> a = gen(NF)
a

julia> minpoly(a)
t^2 - 2
source

Parametrizing Rational Plane Curves

parametrizationMethod
parametrization(C::ProjectivePlaneCurve{QQField})

Return a rational parametrization of C.

Examples

julia> R, (x,y,z) = graded_polynomial_ring(QQ, [:x, :y, :z]);

julia> C = ProjectivePlaneCurve(y^4-2*x^3*z+3*x^2*z^2-2*y^2*z^2)
Projective plane curve
  defined by 0 = 2*x^3*z - 3*x^2*z^2 - y^4 + 2*y^2*z^2

julia> parametrization(C)
3-element Vector{QQMPolyRingElem}:
 12*s^4 - 8*s^2*t^2 + t^4
 -12*s^3*t + 2*s*t^3
 8*s^4
source

Contact

Please direct questions about this part of OSCAR to the following people:

You can ask questions in the OSCAR Slack.

Alternatively, you can raise an issue on github.