[
    {
        "problem_id": 2338,
        "domain": [
            "Mathematics -> Geometry -> Plane Geometry -> Triangulations"
        ],
        "difficulty": 3.5,
        "problem_text": "$P$ is a point inside triangle $A B C$, and lines $A P, B P, C P$ intersect the opposite sides $B C, C A, A B$ in points $D, E, F$, respectively. It is given that $\\angle A P B=90^{\\circ}$, and that $A C=B C$ and $A B=B D$. We also know that $B F=1$, and that $B C=999$. Find $A F$.",
        "sample_id": 1,
        "final_answer": "\\boxed{\\frac{499}{500}}",
        "steps": [
            {
                "step_id": 1,
                "edge": "This is a direct condition provided in the problem statement: AC equals BC, establishing that triangle ABC is isosceles with AC as one of the equal sides.",
                "direct_dependent_steps": null,
                "node": "AC = BC is given."
            },
            {
                "step_id": 2,
                "edge": "This is another given condition from the problem: AB equals BD, which will later help identify triangle ABD as isosceles.",
                "direct_dependent_steps": null,
                "node": "AB = BD is given."
            },
            {
                "step_id": 3,
                "edge": "The problem explicitly states that BF equals 1, providing a fixed length for segment BF that will anchor subsequent calculations.",
                "direct_dependent_steps": null,
                "node": "BF = 1 is given."
            },
            {
                "step_id": 4,
                "edge": "This given value, BC equals 999, sets the scale for the entire problem and will serve as a reference length in later algebraic manipulations.",
                "direct_dependent_steps": null,
                "node": "BC = 999 is given."
            },
            {
                "step_id": 5,
                "edge": "The problem specifies that angle APB is 90 degrees, which implies perpendicularity between segments AP and BP—a critical geometric constraint for establishing right angles and altitudes.",
                "direct_dependent_steps": null,
                "node": "∠APB = 90° is given."
            },
            {
                "step_id": 6,
                "edge": "This follows from the problem's description: D is defined as the intersection point of line AP with side BC, establishing collinearity of A, P, and D.",
                "direct_dependent_steps": null,
                "node": "Point D is the intersection of line AP and side BC."
            },
            {
                "step_id": 7,
                "edge": "As per the problem setup, E is the intersection of line BP with side CA, confirming that points B, P, and E lie on a straight line.",
                "direct_dependent_steps": null,
                "node": "Point E is the intersection of line BP and side CA."
            },
            {
                "step_id": 8,
                "edge": "The problem states that F is where line CP meets side AB, ensuring points C, P, and F are collinear by definition.",
                "direct_dependent_steps": null,
                "node": "Point F is the intersection of line CP and side AB."
            },
            {
                "step_id": 9,
                "edge": "We introduce s as a variable representing BC, leveraging Step 4 where BC is given as 999. This substitution simplifies expressions by replacing the numerical value with a symbol for algebraic manipulation.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Let BC = s."
            },
            {
                "step_id": 10,
                "edge": "We define t as a variable for AB to facilitate algebraic expressions, as no prior step provides a specific value for AB but it will be crucial in proportional relationships.",
                "direct_dependent_steps": null,
                "node": "Let AB = t."
            },
            {
                "step_id": 11,
                "edge": "Combining Step 1 (AC = BC) and Step 9 (BC = s), we directly conclude AC = s. This maintains consistency in the isosceles triangle ABC where AC and BC are equal sides.",
                "direct_dependent_steps": [
                    1,
                    9
                ],
                "node": "Therefore AC = s because AC = BC."
            },
            {
                "step_id": 12,
                "edge": "Using Step 2 (AB = BD) and Step 10 (AB = t), we deduce BD = t. This equality is foundational for analyzing triangle ABD and its properties.",
                "direct_dependent_steps": [
                    2,
                    10
                ],
                "node": "Therefore BD = t because AB = BD."
            },
            {
                "step_id": 13,
                "edge": "Substituting Step 4 (BC = 999) into Step 9 (BC = s) yields s = 999. This assigns the concrete value 999 to the symbolic variable s for later numerical evaluation.",
                "direct_dependent_steps": [
                    4,
                    9
                ],
                "node": "Therefore s = 999 because BC = 999."
            },
            {
                "step_id": 14,
                "edge": "Step 2 (AB = BD) directly implies triangle ABD is isosceles with AB and BD as the equal legs, meaning base angles at A and D are congruent—a key property for angle bisector applications.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "Triangle ABD is isosceles because AB = BD."
            },
            {
                "step_id": 15,
                "edge": "Step 6 defines D as the intersection of AP and BC, so points A, P, and D must be collinear by the definition of intersection and line extension.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Points A, P, and D are collinear because D is the intersection of AP and BC."
            },
            {
                "step_id": 16,
                "edge": "Step 7 specifies E as the intersection of BP and CA, confirming collinearity of B, P, and E as a direct consequence of the line-side intersection.",
                "direct_dependent_steps": [
                    7
                ],
                "node": "Points B, P, and E are collinear because E is the intersection of BP and CA."
            },
            {
                "step_id": 17,
                "edge": "Step 8 describes F as the intersection of CP and AB, so collinearity of C, P, and F follows immediately from this geometric construction.",
                "direct_dependent_steps": [
                    8
                ],
                "node": "Points C, P, and F are collinear because F is the intersection of CP and AB."
            },
            {
                "step_id": 18,
                "edge": "Step 5 states angle APB is 90 degrees, which by definition means segments BP and AP are perpendicular (BP ⊥ AP), establishing a right angle at P.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "BP ⟂ AP because ∠APB = 90°."
            },
            {
                "step_id": 19,
                "edge": "Step 15 confirms A, P, D are collinear, so line AP is identical to line AD. Combining this with Step 18 (BP ⊥ AP) implies BP is perpendicular to the entire line AD (BP ⊥ AD).",
                "direct_dependent_steps": [
                    15,
                    18
                ],
                "node": "Since A,P,D are collinear, BP ⟂ AP implies BP ⟂ AD."
            },
            {
                "step_id": 20,
                "edge": "In triangle ABD, Step 19 shows BP ⊥ AD, meaning BP is perpendicular to side AD. Since AD is the base of triangle ABD, BP serves as an altitude from vertex B to side AD.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "In triangle ABD, BP ⟂ AD implies BP is an altitude from B."
            },
            {
                "step_id": 21,
                "edge": "This is a standard geometric theorem: in any isosceles triangle, the altitude drawn from the apex (the vertex between the equal sides) bisects the apex angle into two congruent parts.",
                "direct_dependent_steps": null,
                "node": "In an isosceles triangle, an altitude from the apex bisects the apex angle."
            },
            {
                "step_id": 22,
                "edge": "Applying Step 21 to triangle ABD (which is isosceles per Step 14) with BP as the altitude from the apex B (per Step 20), we conclude BP bisects angle ABD into two equal angles.",
                "direct_dependent_steps": [
                    14,
                    20,
                    21
                ],
                "node": "Therefore BP bisects ∠ABD."
            },
            {
                "step_id": 23,
                "edge": "Step 6 places D on BC, so points B, D, and C are collinear by the definition of a point lying on a side of a triangle, with D between B and C as implied by the segment BC.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Points B, D, and C are collinear because D is on BC."
            },
            {
                "step_id": 24,
                "edge": "Because Step 23 establishes B, D, C collinear with D on BC, angle ABD (formed by points A, B, D) is identical to angle ABC (formed by points A, B, C), as both describe the angle at vertex B between sides BA and BC.",
                "direct_dependent_steps": [
                    23
                ],
                "node": "Since B,D,C are collinear, ∠ABD = ∠ABC."
            },
            {
                "step_id": 25,
                "edge": "Step 22 states BP bisects angle ABD, and Step 24 confirms angle ABD equals angle ABC, so BP must bisect angle ABC in triangle ABC.",
                "direct_dependent_steps": [
                    22,
                    24
                ],
                "node": "Hence BP bisects ∠ABC."
            },
            {
                "step_id": 26,
                "edge": "Step 25 shows BP bisects angle ABC in triangle ABC, so the Angle Bisector Theorem applies: it states that the bisector divides the opposite side AC into segments proportional to the adjacent sides, giving AE/EC = AB/BC.",
                "direct_dependent_steps": [
                    25
                ],
                "node": "By the Angle Bisector Theorem in triangle ABC, AE/EC = AB/BC."
            },
            {
                "step_id": 27,
                "edge": "Substituting Step 9 (BC = s), Step 10 (AB = t), and Step 11 (AC = s, though not directly used here) into Step 26's ratio AE/EC = AB/BC yields AE/EC = t/s, expressing the segment ratio in terms of our defined variables.",
                "direct_dependent_steps": [
                    9,
                    10,
                    11,
                    26
                ],
                "node": "Substituting AB = t and BC = s into AE/EC = AB/BC gives AE/EC = t/s."
            },
            {
                "step_id": 28,
                "edge": "Step 6 confirms D lies on BC, so the entire segment BC is the sum of subsegments BD and DC, giving BC = BD + DC as a fundamental segment addition property.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Since D is on BC, BC = BD + DC."
            },
            {
                "step_id": 29,
                "edge": "Using Step 9 (BC = s), Step 12 (BD = t), and Step 28 (BC = BD + DC), we solve for DC: s = t + DC implies DC = s - t. This expresses the length of DC algebraically.",
                "direct_dependent_steps": [
                    9,
                    12,
                    28
                ],
                "node": "Substituting BD = t and BC = s into BC = BD + DC gives DC = s − t."
            },
            {
                "step_id": 30,
                "edge": "From Step 12 (BD = t) and Step 29 (DC = s - t), the ratio CD/DB (where CD is equivalent to DC in length) is (s - t)/t, which will be used in Ceva's Theorem.",
                "direct_dependent_steps": [
                    12,
                    29
                ],
                "node": "Thus CD/DB = (s − t)/t."
            },
            {
                "step_id": 31,
                "edge": "Steps 15, 16, and 17 confirm that cevians AD, BE, and CF are concurrent at P (as they all pass through P). Ceva's Theorem for concurrent cevians in triangle ABC states that (AF/FB) * (BD/DC) * (CE/EA) = 1, which rearranges to AF/FB = (AE/EC) * (CD/DB) using reciprocal relationships for the segment ratios.",
                "direct_dependent_steps": [
                    15,
                    16,
                    17
                ],
                "node": "By Ceva’s Theorem for concurrent cevians AD, BE, and CF in triangle ABC, AF/FB = (AE/EC)*(CD/DB)."
            },
            {
                "step_id": 32,
                "edge": "Substituting Step 27 (AE/EC = t/s) and Step 30 (CD/DB = (s - t)/t) into Step 31's formula AF/FB = (AE/EC) * (CD/DB) gives AF/FB = (t/s) * ((s - t)/t) = (s - t)/s after canceling t in numerator and denominator.",
                "direct_dependent_steps": [
                    27,
                    30,
                    31
                ],
                "node": "Substituting AE/EC = t/s and CD/DB = (s − t)/t yields AF/FB = (s − t)/s."
            },
            {
                "step_id": 33,
                "edge": "Step 8 defines F as the intersection of CP and AB, so F must lie on segment AB by the problem's construction, ensuring AB is divided into AF and FB.",
                "direct_dependent_steps": [
                    8
                ],
                "node": "F lies on AB because F is the intersection of CP and AB."
            },
            {
                "step_id": 34,
                "edge": "Since Step 33 places F on AB, the segment addition property applies: AB is the sum of AF and FB, so AB = AF + FB.",
                "direct_dependent_steps": [
                    33
                ],
                "node": "Therefore AB = AF + FB."
            },
            {
                "step_id": 35,
                "edge": "Dividing both sides of Step 34's equation AB = AF + FB by FB yields AB/FB = AF/FB + 1, a standard algebraic manipulation to isolate the ratio AF/FB for substitution.",
                "direct_dependent_steps": [
                    34
                ],
                "node": "Dividing AB = AF + FB by FB gives AB/FB = AF/FB + 1."
            },
            {
                "step_id": 36,
                "edge": "Substituting Step 32 (AF/FB = (s - t)/s) into Step 35 (AB/FB = AF/FB + 1) gives AB/FB = (s - t)/s + 1 = (s - t + s)/s = (2s - t)/s, combining the terms over a common denominator.",
                "direct_dependent_steps": [
                    32,
                    35
                ],
                "node": "Substituting AF/FB = (s − t)/s into AB/FB = AF/FB + 1 gives AB/FB = (2s − t)/s."
            },
            {
                "step_id": 37,
                "edge": "Step 10 sets AB = t, and Step 36 gives AB/FB = (2s - t)/s, so substituting t for AB yields t/FB = (2s - t)/s, relating the variables t and s through FB.",
                "direct_dependent_steps": [
                    10,
                    36
                ],
                "node": "Since AB = t, we have t/FB = (2s − t)/s."
            },
            {
                "step_id": 38,
                "edge": "Solving Step 37's equation t/FB = (2s - t)/s for FB involves cross-multiplication: t * s = FB * (2s - t), so FB = st/(2s - t) after rearranging terms.",
                "direct_dependent_steps": [
                    37
                ],
                "node": "Solving t/FB = (2s − t)/s for FB gives FB = st/(2s − t)."
            },
            {
                "step_id": 39,
                "edge": "Step 3 states BF = 1 (and BF is equivalent to FB), so setting Step 38's expression FB = st/(2s - t) equal to 1 gives st/(2s - t) = 1.",
                "direct_dependent_steps": [
                    3,
                    38
                ],
                "node": "Given BF = 1 we set st/(2s − t) = 1."
            },
            {
                "step_id": 40,
                "edge": "Multiplying both sides of Step 39's equation st/(2s - t) = 1 by (2s - t) eliminates the denominator, yielding st = 2s - t as an equivalent linear equation.",
                "direct_dependent_steps": [
                    39
                ],
                "node": "Multiplying both sides of st/(2s − t) = 1 by (2s − t) yields st = 2s − t."
            },
            {
                "step_id": 41,
                "edge": "Adding t to both sides of Step 40's equation st = 2s - t isolates terms with t on one side, resulting in st + t = 2s, preparing for factoring.",
                "direct_dependent_steps": [
                    40
                ],
                "node": "Adding t to both sides of st = 2s − t gives st + t = 2s."
            },
            {
                "step_id": 42,
                "edge": "Factoring t from the left side of Step 41's equation st + t = 2s gives t(s + 1) = 2s, a simplified form that expresses t in terms of s.",
                "direct_dependent_steps": [
                    41
                ],
                "node": "Factoring the left side of st + t = 2s yields t(s + 1) = 2s."
            },
            {
                "step_id": 43,
                "edge": "Solving Step 42's equation t(s + 1) = 2s for t by dividing both sides by (s + 1) yields t = 2s/(s + 1), providing an explicit expression for AB in terms of s.",
                "direct_dependent_steps": [
                    42
                ],
                "node": "Solving t(s + 1) = 2s for t gives t = 2s/(s + 1)."
            },
            {
                "step_id": 44,
                "edge": "Step 3 specifies BF = 1 (so FB = 1), and Step 32 gives AF/FB = (s - t)/s; substituting FB = 1 implies AF = (s - t)/s directly from the ratio definition.",
                "direct_dependent_steps": [
                    3,
                    32
                ],
                "node": "AF/FB = (s − t)/s and FB = 1 imply AF = (s − t)/s."
            },
            {
                "step_id": 45,
                "edge": "Substituting Step 43 (t = 2s/(s + 1)) into s - t gives s - 2s/(s + 1) = [s(s + 1) - 2s]/(s + 1) = (s² + s - 2s)/(s + 1) = (s² - s)/(s + 1). Sanity check: for s > 1, s² - s is positive, consistent with AF being a length.",
                "direct_dependent_steps": [
                    9,
                    43
                ],
                "node": "Substituting t = 2s/(s + 1) into s − t gives s − 2s/(s + 1) = (s^2 − s)/(s + 1)."
            },
            {
                "step_id": 46,
                "edge": "Step 44 states AF = (s - t)/s, and Step 45 gives s - t = (s² - s)/(s + 1); substituting yields AF = [(s² - s)/(s + 1)] / s = (s² - s)/(s(s + 1)) = (s - 1)/(s + 1) after canceling s (valid since s = BC = 999 ≠ 0).",
                "direct_dependent_steps": [
                    44,
                    45
                ],
                "node": "Therefore AF = [(s^2 − s)/(s + 1)]/s = (s − 1)/(s + 1)."
            },
            {
                "step_id": 47,
                "edge": "Substituting Step 13 (s = 999) into Step 46's simplified expression AF = (s - 1)/(s + 1) gives (999 - 1)/(999 + 1) = 998/1000. Reducing by dividing numerator and denominator by 2 yields 499/500. Sanity check: 998/1000 = 0.998 and 499/500 = 0.998, confirming equivalence.",
                "direct_dependent_steps": [
                    13,
                    46
                ],
                "node": "Substituting s = 999 yields AF = (999 − 1)/(999 + 1) = 998/1000 = 499/500."
            },
            {
                "step_id": 48,
                "edge": "Step 47 computes AF = 499/500, which is the exact fractional form of the solution; thus, the final answer is boxed as required.",
                "direct_dependent_steps": [
                    47
                ],
                "node": "The final answer is \\boxed{\\frac{499}{500}}."
            }
        ]
    }
]
