Check if a point is on the Jubjub curve [ZPS:5.4.9.3].
(point-on-jubjub-p point) → yes/no
Function:
(defun point-on-jubjub-p (point) (declare (xargs :guard (ecurve::pointp point))) (let ((__function__ 'point-on-jubjub-p)) (declare (ignorable __function__)) (ecurve::point-on-twisted-edwards-p point (jubjub-curve))))
Theorem:
(defthm booleanp-of-point-on-jubjub-p (b* ((yes/no (point-on-jubjub-p point))) (booleanp yes/no)) :rule-classes :rewrite)
Theorem:
(defthm point-on-jubjub-p-of-point-fix-point (equal (point-on-jubjub-p (ecurve::point-fix point)) (point-on-jubjub-p point)))
Theorem:
(defthm point-on-jubjub-p-point-equiv-congruence-on-point (implies (ecurve::point-equiv point point-equiv) (equal (point-on-jubjub-p point) (point-on-jubjub-p point-equiv))) :rule-classes :congruence)