Let n,k≥0 and q≥n. Let α1,…,αn∈Fq and define the Reed-Solomon Code with parameters q,n,k,α as
RSq(n,k)={(f(α1),…,f(αn))∣f∈Fq[x],degf<k}
That is, RSq(n,k) codes are defined as evaluation maps of polynomials of degree at most k on n points α1,…,αn in Fq. Geometrically, Fq is an affine line which we can projectivize to PFq1=:P1.
We can view f(x)∈Fq[x] equivalently as a rational function on P1. Then the condition degf<k is restated equivalently as f having a pole of order at most k−1 at ∞.
In the notation of divisors, div(f)+(k−1)[∞]≥0, or equivalently f∈OP1((k−1)[∞]). Thus what if instead we try curves C other than P1, and divisors G other than (k−1)[1:0]? This is exactly the intuition behind algebraic geometry codes.
Algebraic Geometry Codes
Throughout this post, we will fix the following notation. C will denote a smooth, projective, connected, irreducible algebraic curve over Fq of genus g. We will let p1,…,pn be pairwise distinct Fq-rational points of C. We will let D=p1+…+pn denote the corresponding divisor, and G will denote another divisor on C such that SuppD∩SuppG=∅.
We will use Riemman-Roch for curves particularly often, so we restate it below.
Theorem (Riemann-Roch) For a smooth, projective, connected, irreducible curve C of genus G with canonical divisor KC, and a divisor D on C,
ℓ(D)−ℓ(KC−D)=degD+1−g
We can now define the primary object of interest in this post, which is our error correcting code constructed using our theory of algebraic curves.
Definition (AG Code) The algebraic geometry (AG) code associated with the curve C and divisors D,G above is denoted C(D,G) and is given by
C(D,G):={(f(p1),⋯,f(pn)):f∈Γ(C,OC(G))}⊆Fqn
Note that f(pi) is well-defined since div(f)+G≥0 and SuppD∩SuppG=∅, i.e. if f has a pole at pi then ordpi(f)<0, which would imply div(f)+G≥0 since G is not supported on pi.
So now having defined AG codes, we can ask ourselves about the properties of such codes, for example, the distance and the message length.
Theorem The following hold.
C(D,G) is a linear [n,k,d]q code such that
d≥n−degGandk=ℓ(G)−ℓ(G−D)
If degG<n then k≥degG+1−g. If in addition 2g−2<degG<n, we have equality. That is,
k=degG+1−g
If {f1,…,fk} is a basis of Γ(C,OC(G)) then the n×k matrix
Proof. If we consider the evaluation map, ev:Γ(C,OC(G))→Fqn,
ev(f)=(f(p1),⋯,f(pn))
we see that f is in the kernel of ev if and only if div(f)+G−D≥0, i.e. f has at a zero of order at least 1 at each pi. Equivalently, f∈Γ(C,OC(G−D)) and so the kernel of ev has dimension ℓ(G−D). By rank-nullity we indeed get
k=dim(C(D,G))=ℓ(G)−ℓ(G−D)
If degG<degD=n then ℓ(G−D)=0 (that is, ev is injective) and k=ℓ(G) which can be computed directly using Riemann-Roch, where KC is the canonical divisor.
ℓ(G)=deg(G)+1−g+ℓ(KC−G)
In particular, ℓ(G)≥degG+1−g and we have equality iff 2g−2=deg(KC)<deg(G).
For the distance, let us consider a non-zero f∈Γ(C,OC(G)) such that ev(f) is of weight d. This means f vanishes on n−d points pi1,⋯,pin−d. Then
f∈Γ(C,OC(G−(pi1+⋯+pin−d)))
and so ℓ(G−(pi1+⋯+pin−d))>0, so in particular, we must have degG−(n−d)≥0 which implies that d≥n−degG.
It's clear that if f=c1f1+…+ckfk then f(pi)=c1f1(pi)+…+ckfk(pi)=[Mf]i.
Dual Codes
We can construct another code using the two divisors G,D, using another point of view. The AG codes defined above used an evaluation point of view. We can also use the residual point of view to create some linear codes.
Fix the same notation for C,D=p1+…+pn, and G such that SuppG∩SuppD=∅ as in the previous subsection, and recall the notions of the rational differential 1-form ω on C, canonical divisor KC=div(ω), and canonical bundle ΩC=OC(KC).
Recall Γ(C,ΩC(Z)) is the space of global rational 1-forms η such that div(η)−Z≥0. Note that
Γ(C,ΩC(Z))=Γ(C,OC(KC−Z))
since giving a rational f such that div(f)+KC−Z=div(f)+div(ω)−Z≥0 is the same as giving a rational 1-form η=fω such that div(η)−Z≥0.
For a rational 1-form η, suppose the local component at p is given by ηp=f(z)dz. If ηp=f(z)dz, the residue Resp(η) of η at p is defined as the coefficient of 1/z in the Laurent series expansion of f(z) at 0.
Residue Theorem Let ω be a rational differentiable 1-form on a smooth projective curve C. Then
p∈C∑Resp(ω)=0
This is the analogue of the residue theorem in complex analysis, but the proof is rather involved so we omit it.
Definition Let C,D,G be as before with SuppD∩SuppG=∅. Define the following code.
Then we have an analogue of the Theorem in the previous section for AG codes whose proof contains essentially the same ideas.
Theorem The following statements hold.
CΩ(D,G) is a linear [n,k′,d′]q code such that
d′≥degG−(2g−2)andk′=ℓ(KC−G+D)−ℓ(KC−G)
If 2g−2<degG then k′=ℓ(KC−G+D)≥n−degG+g−1.
If 2g−2<degG<n we have equality, i.e.
k′=n−degG+g−1
Proof. Consider the residue map Res:ΩC(G−D)→Fqn, defined as
Res(η)=(Resp1(η),…,Respn(η))
The kernel consists of rational 1-forms η with 0 residue at each pi. Since div(η)−G+D≥0, each η has a pole of order at most 1 at every pi and having residue 0 implies it has no pole, i.e. div(η)−G≥0. Thus the kernel is Γ(C,ΩC(G))=Γ(C,OC(KC−G)) which has dimension ℓ(KC−G).
Similarly, the domain has dimension ℓ(KC−G+D). By rank-nullity,
k′=ℓ(KC−G+D)−ℓ(KC−G)
In particular, if 2g−2=degKC<degG then ℓ(KC−G)=0 and by Riemann-Roch
k′=ℓ(KC−G+D)=ℓ(G−D)−deg(G−D)+g−1≥n−degG+g−1
If in addition degG<degD=n then ℓ(G−D)=0 and we have equality.
For distance, suppose n−d′ residues vanish pi1,…,pin−d for some η. Then
η∈Γ(C,ΩC(G−D+pi1+…+pin−d′))
so ℓ(KC−G+D−(pi1+…+pin−d′))>0. We must then have degKC−degG+n−(n−d′)≥0, i.e.
d′≥degG−(2g−2)
In the particular case 2g−2<degG<n, the above theorem and the analogous theorem for AG codes imply
k′+k=(n−degG+g−1)+(degG+1−g)=n
but it's not too hard to check this holds in general, i.e.
k′+k=ℓ(KC−G+D)−ℓ(KC−G)+ℓ(G)−ℓ(G−D)=n
(Hint: use Riemann-Roch). There's good reason for this, as we see with the next theorem.
Theorem (Duality) The codes C(D,G) and CΩ(D,G) are dual to each other;
C(D,G)=CΩ(D,G)⊥
Proof. We showed that k+k′=n so it suffices to show any codewords satisfy ⟨ev(f),Res(η)⟩=0. Note that since div(f)+G≥0 and div(η)−G+D≥0, we have div(fη)+D≥0 so fη has a pole of order at most 1 at each pi. The residue of fη at pi is f(pi)Respi(η), hence
Note that as div(fη)+D≥0 these are the only possible poles, i.e. the only points with nonzero residues, hence by the residue theorem
i=1∑nRespi(fη)=p∈C∑Resp(fη)=0
Conclusion
It turns out that these codes have merits other than this interesting relationship between AG codes and their duals being constructed from the trivial bundle and its Serre dualizing sheaf.
There is a famouns bound on the rate and distance of error correcting codes called the Gilbert-Varshamov (GV) Bound established in 1957, which includes a proof that there are a family of linear codes at or above this bound. The proof was non-constructive and instead selected linear codes at random.
It was an open question for around 30 years as to whether there were a family of codes that could beat the GV bound. AG codes were the first family of codes found to beat the bound, which can be shown using results on counting the maximum number of Fq-rational points Nq(g) on curves of genus g, similar to the Hasse-Weil bound. Nonetheless, these codes provide interesting mathematical objects outside the realm of coding theory which was my primary motivation in writing this blog post.