Skip to content

Commit

Permalink
[FTheoryTools] Implement method ambient_space_models_of_g4_fluxes
Browse files Browse the repository at this point in the history
  • Loading branch information
HereAround committed Nov 2, 2024
1 parent a22e240 commit bd3e45a
Show file tree
Hide file tree
Showing 3 changed files with 119 additions and 2 deletions.
39 changes: 37 additions & 2 deletions experimental/FTheoryTools/docs/src/g4.md
Original file line number Diff line number Diff line change
Expand Up @@ -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)
```
81 changes: 81 additions & 0 deletions experimental/FTheoryTools/src/G4Fluxes/special_attributes.jl
Original file line number Diff line number Diff line change
Expand Up @@ -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
1 change: 1 addition & 0 deletions experimental/FTheoryTools/src/exports.jl
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down

0 comments on commit bd3e45a

Please sign in to comment.