geMixedAdd function
Implementation
void geMixedAdd(CompletedGroupElement r, ExtendedGroupElement p,
PreComputedGroupElement q) {
var t0 = FieldElement();
FeAdd(r.X, p.Y, p.X);
FeSub(r.Y, p.Y, p.X);
FeMul(r.Z, r.X, q.yPlusX);
FeMul(r.Y, r.Y, q.yMinusX);
FeMul(r.T, q.xy2d, p.T);
FeAdd(t0, p.Z, p.Z);
FeSub(r.X, r.Z, r.Y);
FeAdd(r.Y, r.Z, r.Y);
FeAdd(r.Z, t0, r.T);
;
FeSub(r.T, t0, r.T);
}