diff --git a/experimental/FTheoryTools/docs/src/g4.md b/experimental/FTheoryTools/docs/src/g4.md index a0359fd0677b..54dc77ab79eb 100644 --- a/experimental/FTheoryTools/docs/src/g4.md +++ b/experimental/FTheoryTools/docs/src/g4.md @@ -32,9 +32,44 @@ passes_elementary_quantization_checks(gf::G4Flux) ``` -## Auxiliary +## Ambient Space Models for G4-Fluxes + +Focus on 4-dimensional F-theory models $m$, such that the resolution $\widehat{Y}_4$ +of the defining singular elliptically fibered CY 4-fold $\Y_4 \twoheadrightarrow B_3$ +is defined as hypersurface in a complete and simplicial toric variety $X_\Sigma$. In +such a setup, it is convenient to focus on $G_4$-fluxes modelled from the restriction +of elements of $H^{(2,2)}( X_\Sigma, \mathbb{Q})$ to $\widehat{Y}_4$. This method +identifies a basis of $H^{(2,2)}( X_\Sigma, \mathbb{Q})$ and filters out elements, +whose restricton to $\widehat{Y}_4$ is obviously trivial. + +It is important to elaborate a bit more on the meaning of "obviously". To this end, fix a +basis element of $H^{(2,2)}( X_\Sigma, \mathbb{Q})$. Let us denote a corresponding algebraic +cycle by $A = \mathbb{V}(x_i, x_j) \subset X_\Sigma$, where $x_i$, $x_j$ are suitable +homogeneous coordinates. Furthermore, let $\widehat{Y}_4 = \mathbb{V}( p ) \subset X_\Sigma$. +Then of course, we can look at the set-theoretic intersection $\mathbb{V}( p, x_i, x_j)$. +Provided that $p(x_i = 0, x_j = 0)$ is a non-zero constant, this set-theoretic intersection +is trivial. This is exactly the check conducted by the method `ambient_space_models_of_g4_fluxes` +below. However, for reasons of simplicity, this approach is avoid a number of sutleties. + +Namely, we really have to work out the intersection in the Chow ring, that is we should consider +the rational equivalence class of the algebraic cycle $A$ and intersect this class with the +rational equivalence class of the algebraic cycle $\mathbb{V}( p )$. In particular, for +"unlucky" choices of $i, j$, the algebraic cycles $\mathbb{V}( p )$ and $\mathbb{V}(x_i, x_j)$ +may not intersect transversely. This is for instance the case if $i = j$. Such phenomena are +addressed in theory by "moving the algebraic cycles into general position", but in practice this +somewhat tricky. Instances include the following: +1. $i = j$: Then apparently, a self-intersection of $\mathbb{V}(x_i)$ is involved. +2. $p(x_i, x_j) \equiv 0$: This is unexpected for dimensional reasons, and indicates a +non-transverse intersection. + +In both instances, one makes use of the linear relations of $X_\Sigma$ to replace the cycle + $\mathbb{V}(x_i)$ (and/or $\mathbb{V}(x_j)$) with a rational combination of algebraic cycles +$R = \sum_{k = 1}^{N}{c_k \cdot A_k}$, such that $R$ is rationally equivalent to $\mathbb{V}(x_i)$. +From experience, it is then rather common that $R$ and $\mathbb{V}(x_i)$ intersect transversely. +And if not, then modify the non-transverse intersections by using the linear relations again to +replace an involved algebraic cycle. -The following methods are relevant to the discussion and study of $G_4$-fluxes: ```@docs +ambient_space_models_of_g4_fluxes(m::AbstractFTheoryModel; check::Bool = true)::Vector{CohomologyClass} basis_of_h22(v::NormalToricVariety; check::Bool = true) ``` diff --git a/experimental/FTheoryTools/src/G4Fluxes/special_attributes.jl b/experimental/FTheoryTools/src/G4Fluxes/special_attributes.jl index 9aa7371633fe..9793d959342a 100644 --- a/experimental/FTheoryTools/src/G4Fluxes/special_attributes.jl +++ b/experimental/FTheoryTools/src/G4Fluxes/special_attributes.jl @@ -156,3 +156,84 @@ function basis_of_h22(v::NormalToricVariety; check::Bool = true)::Vector{Cohomol return basis_of_h22 end + + +@doc raw""" + ambient_space_models_of_g4_fluxes(m::AbstractFTheoryModel; check::Bool = true)::Vector{CohomologyClass} + +Given an F-theory model $m$ defined as hypersurface in a simplicial and +complete toric base, we this method first computes a basis of +$H^(2,2)(X, \mathbb{Q})$ (by use of the method `basis_of_h22` below) and then filters +out "some" basis elements whose restriction to the hypersurface in question +is trivial. The exact meaning of "some" is explained above this method. + +Note that it can be computationally very demanding to check if a toric variety +$X$ is complete (and simplicial). The optional argument `check` can be set +to `false` to skip these tests. + +# Examples +```jldoctest; setup = :(Oscar.LazyArtifacts.ensure_artifact_installed("QSMDB", Oscar.LazyArtifacts.find_artifacts_toml(Oscar.oscardir))) +julia> qsm_model = literature_model(arxiv_id = "1903.00009", model_parameters = Dict("k" => 8)) + +julia> g4_amb_list = ambient_space_models_of_g4_fluxes(qsm_model, check = false); + +julia> length(g4_amb_list) == 172 +true +``` +""" +function ambient_space_models_of_g4_fluxes(m::AbstractFTheoryModel; check::Bool = true)::Vector{CohomologyClass} + + # Entry check + @req base_space(m) isa NormalToricVariety "Base space must be a toric variety for computation of ambient space G4 candidates" + + # Prepare data of the toric ambient space + gS = gens(cox_ring(ambient_space(m))) + mnf = Oscar._minimal_nonfaces(ambient_space(m)) + sr_ideal_pos = [Vector{Int}(Polymake.row(mnf, i)) for i in 1:Polymake.nrows(mnf)] + filtered_h22_basis = basis_of_h22(ambient_space(m), check = check) + + # Filter out basis elements + for a in length(filtered_h22_basis):-1:1 + + # Find non-zero exponent positions in the polynomial filtered_h22_basis[a] + exp_list = collect(exponents(polynomial(filtered_h22_basis[a]).f))[1] + vanishing_vars_pos = findall(!=(0), exp_list) + + # Simplify the hypersurface polynomial by setting relevant variables to zero + new_pt = divrem(hypersurface_equation(m), gS[vanishing_vars_pos[1]])[2] + if length(vanishing_vars_pos) == 2 + new_pt = divrem(new_pt, gS[vanishing_vars_pos[2]])[2] + end + + # If all coefficient of `new_pt` sum to zero, keep this generator. + if sum(coefficients(new_pt)) == 0 + continue + end + + # Determine remaining variables, after scaling "away" others. + remaining_vars_list = Set(1:length(gS)) + for my_exps in sr_ideal_pos + len_my_exps = length(my_exps) + inter_len = count(idx -> idx in vanishing_vars_pos, my_exps) + if (len_my_exps == 2 && inter_len == 1) || (len_my_exps == 3 && inter_len == 2) + delete!(remaining_vars_list, my_exps[findfirst(idx -> !(idx in vanishing_vars_pos), my_exps)]) + end + end + remaining_vars_list = collect(remaining_vars_list) + + # If one monomial of `new_pt` has unset positions, then keep this generator. + delete_it = true + for exps in exponents(new_pt) + if any(x -> x != 0, exps[remaining_vars_list]) + delete_it = false + break + end + end + if delete_it + deleteat!(filtered_h22_basis, a) + end + + end + + return filtered_h22_basis +end diff --git a/experimental/FTheoryTools/src/exports.jl b/experimental/FTheoryTools/src/exports.jl index ff5faa5d3b32..6a3f2b2acd41 100644 --- a/experimental/FTheoryTools/src/exports.jl +++ b/experimental/FTheoryTools/src/exports.jl @@ -23,6 +23,7 @@ export add_weighted_resolution export add_weighted_resolution_generating_section export add_weighted_resolution_zero_section export ambient_space +export ambient_space_models_of_g4_fluxes export analyze_fibers export arxiv_doi export arxiv_id