[
    {
        "problem_id": 3131,
        "domain": [
            "Mathematics -> Geometry -> Plane Geometry -> Triangulations"
        ],
        "difficulty": 5.25,
        "problem_text": "Triangle $A B C$ has side lengths $A B=15, B C=18, C A=20$. Extend $C A$ and $C B$ to points $D$ and $E$ respectively such that $D A=A B=B E$. Line $A B$ intersects the circumcircle of $C D E$ at $P$ and $Q$. Find the length of $P Q$.",
        "sample_id": 1,
        "final_answer": "The final answer is $\\boxed{37}$",
        "steps": [
            {
                "step_id": 1,
                "edge": "The problem explicitly states the side length of triangle $ABC$ as $AB = 15$, which serves as a foundational measurement for subsequent calculations and definitions. This given value establishes the baseline for assigning variables to side lengths.",
                "direct_dependent_steps": null,
                "node": "Triangle $ABC$ has side length $AB = 15$."
            },
            {
                "step_id": 2,
                "edge": "This side length $BC = 18$ is directly provided in the problem statement for triangle $ABC$. It is essential for defining the triangle's geometry and will later be used in power of a point applications involving point $B$.",
                "direct_dependent_steps": null,
                "node": "Triangle $ABC$ has side length $BC = 18$."
            },
            {
                "step_id": 3,
                "edge": "The problem specifies $CA = 20$ as the third side length of triangle $ABC$. This given value completes the triangle's side measurements and will be critical when applying the power of a point theorem at vertex $A$.",
                "direct_dependent_steps": null,
                "node": "Triangle $ABC$ has side length $CA = 20$."
            },
            {
                "step_id": 4,
                "edge": "Building on Step 1 where $AB = 15$ is given, we define $c = AB$ to simplify algebraic expressions. This standard notation (using $a$, $b$, $c$ for opposite sides) streamlines later equations by replacing the specific length $15$ with a variable, facilitating generalization before substituting numerical values.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Define $c = AB$."
            },
            {
                "step_id": 5,
                "edge": "Using Step 2's given $BC = 18$, we define $a = BC$ to maintain consistent triangle notation. This assignment allows us to reference this side length uniformly in power of a point formulas, avoiding repetitive numerical values during intermediate derivations.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "Define $a = BC$."
            },
            {
                "step_id": 6,
                "edge": "From Step 3's given $CA = 20$, we define $b = CA$ to complete the standard side-length labeling convention. This abstraction is necessary for expressing relationships involving $AC$ (which equals $CA$) in algebraic form before numerical substitution.",
                "direct_dependent_steps": [
                    3
                ],
                "node": "Define $b = CA$."
            },
            {
                "step_id": 7,
                "edge": "The problem instructs to extend $CA$ beyond $A$ to point $D$, so this geometric configuration is established by the problem statement. This extension defines the position of $D$ relative to segment $CA$, enabling length calculations involving $DA$.",
                "direct_dependent_steps": null,
                "node": "Point $D$ lies on line $CA$ extended beyond $A$."
            },
            {
                "step_id": 8,
                "edge": "Building on Step 7's definition of $D$ on the extension of $CA$ beyond $A$, the problem specifies $DA = AB$. This equality sets the length of segment $DA$ equal to side $AB$, which is crucial for determining the position of $D$ and later computing $AD$ in power of a point applications.",
                "direct_dependent_steps": [
                    7
                ],
                "node": "$DA = AB$."
            },
            {
                "step_id": 9,
                "edge": "The problem requires extending $CB$ beyond $B$ to point $E$, so this placement is dictated by the problem statement. This configuration establishes $E$'s position relative to segment $CB$, which is necessary for defining segment $BE$.",
                "direct_dependent_steps": null,
                "node": "Point $E$ lies on line $CB$ extended beyond $B$."
            },
            {
                "step_id": 10,
                "edge": "Given Step 9's definition of $E$ on the extension of $CB$ beyond $B$, the problem states $BE = AB$. This equality links $BE$ to side $AB$, providing a fixed length for $BE$ that will be used in the power of a point theorem at $B$.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "$BE = AB$."
            },
            {
                "step_id": 11,
                "edge": "Combining Step 4 ($c = AB$) and Step 8 ($DA = AB$), we deduce $DA = c$ by transitive equality. This substitution replaces the specific length $AB$ with variable $c$, simplifying expressions involving $DA$ in later algebraic manipulations.",
                "direct_dependent_steps": [
                    4,
                    8
                ],
                "node": "$DA = c$."
            },
            {
                "step_id": 12,
                "edge": "Using Step 4 ($c = AB$) and Step 10 ($BE = AB$), we establish $BE = c$ through equality substitution. This allows consistent use of $c$ for both $AB$ and $BE$ in power of a point equations, reducing notational complexity.",
                "direct_dependent_steps": [
                    4,
                    10
                ],
                "node": "$BE = c$."
            },
            {
                "step_id": 13,
                "edge": "The problem describes line $AB$ intersecting the circumcircle of $CDE$ at $P$ and $Q$, so this intersection is given by the problem statement. This defines the key points $P$ and $Q$ whose separation $PQ$ we must compute, setting up the application of circle theorems.",
                "direct_dependent_steps": null,
                "node": "The circumcircle of triangle $CDE$ intersects line $AB$ at points $P$ and $Q$."
            },
            {
                "step_id": 14,
                "edge": "Based on Step 13's intersection points $P$ and $Q$, we assume $P$ lies on the extension of $AB$ beyond $A$ to resolve geometric ambiguity. This positional assumption (consistent with the extension of $CA$ to $D$) ensures the correct segment ordering $P$-$A$-$B$-$Q$ for length calculations.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "Assume $P$ lies on the extension of line $AB$ beyond $A$."
            },
            {
                "step_id": 15,
                "edge": "From Step 13's intersection points, we assume $Q$ lies on the extension of $AB$ beyond $B$ to complete the geometric configuration. This, combined with Step 14, establishes the linear order $P$-$A$-$B$-$Q$ on line $AB$, which is essential for defining segment additions later.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "Assume $Q$ lies on the extension of line $AB$ beyond $B$."
            },
            {
                "step_id": 16,
                "edge": "Given Step 13's points $P$ and $Q$ on line $AB$, we define $x = AP$ to represent the unknown length from $A$ to $P$. This variable captures the distance along the extension beyond $A$, which will be solved using power of a point relationships.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "Define $x = AP$."
            },
            {
                "step_id": 17,
                "edge": "Using Step 13's intersection points, we define $y = BQ$ to represent the unknown length from $B$ to $Q$. This variable quantifies the extension beyond $B$, complementing $x$ in the system of equations derived from circle theorems.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "Define $y = BQ$."
            },
            {
                "step_id": 18,
                "edge": "Combining Step 1 ($AB = 15$) and Step 16 ($x = AP$), we express $BP$ as $BA + AP$. Since $P$ is beyond $A$ (Step 14), the segment $BP$ spans from $B$ to $A$ ($BA$) and then to $P$ ($AP$), so $BP = BA + AP$ by segment addition along the straight line.",
                "direct_dependent_steps": [
                    1,
                    16
                ],
                "node": "$BP = BA + AP$."
            },
            {
                "step_id": 19,
                "edge": "Using Step 4 ($c = AB$) and Step 18 ($BP = BA + AP$), we simplify to $BP = c + x$. Since $BA = AB = c$ and $AP = x$, this substitution replaces specific lengths with variables for algebraic manipulation, preparing for power of a point application.",
                "direct_dependent_steps": [
                    4,
                    18
                ],
                "node": "Therefore $BP = c + x$."
            },
            {
                "step_id": 20,
                "edge": "From Step 1 ($AB = 15$) and Step 17 ($y = BQ$), we derive $AQ = AB + BQ$. Given $Q$ is beyond $B$ (Step 15), the segment $AQ$ comprises $AB$ (from $A$ to $B$) and $BQ$ (from $B$ to $Q$), so $AQ = AB + BQ$ by segment addition.",
                "direct_dependent_steps": [
                    1,
                    17
                ],
                "node": "$AQ = AB + BQ$."
            },
            {
                "step_id": 21,
                "edge": "Building on Step 4 ($c = AB$), Step 17 ($y = BQ$), and Step 20 ($AQ = AB + BQ$), we substitute to get $AQ = c + y$. This consolidates known and unknown lengths into a single expression using variable $c$, streamlining the power of a point equation at $A$.",
                "direct_dependent_steps": [
                    4,
                    17,
                    20
                ],
                "node": "Therefore $AQ = c + y$."
            },
            {
                "step_id": 22,
                "edge": "This step applies the intersecting chords theorem at point $B$, which is a standard geometric principle for circles. Since chords $PQ$ (on line $AB$) and $CE$ (on line $CBE$) intersect at $B$, the theorem states $BP \\cdot BQ = BC \\cdot BE$, providing a key equation relating the segments.",
                "direct_dependent_steps": null,
                "node": "By the power of a point theorem at $B$, we have $BP\\cdot BQ = BC\\cdot BE$."
            },
            {
                "step_id": 23,
                "edge": "Using Step 17 ($y = BQ$), Step 19 ($BP = c + x$), and Step 22 ($BP \\cdot BQ = BC \\cdot BE$), we substitute to form $(c + x)y = BC \\cdot BE$. This replaces geometric segments with algebraic expressions, converting the theorem into an equation solvable for $x$ and $y$.",
                "direct_dependent_steps": [
                    17,
                    19,
                    22
                ],
                "node": "Substituting $BP = c + x$ and $BQ = y$ into $BP\\cdot BQ = BC\\cdot BE$ gives $(c + x)y = BC\\cdot BE$."
            },
            {
                "step_id": 24,
                "edge": "From Step 5 ($a = BC$), we directly state $BC = a$ to maintain consistent variable usage. This substitution ensures $BC$ is represented by $a$ in all subsequent equations, aligning with our initial side-length definitions.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "$BC = a$."
            },
            {
                "step_id": 25,
                "edge": "Using Step 12 ($BE = c$), we state $BE = c$ to apply the previously defined variable. This replaces the segment $BE$ with $c$, simplifying the right-hand side of the power of a point equation at $B$.",
                "direct_dependent_steps": [
                    12
                ],
                "node": "$BE = c$."
            },
            {
                "step_id": 26,
                "edge": "Combining Step 23 ($(c + x)y = BC \\cdot BE$), Step 24 ($BC = a$), and Step 25 ($BE = c$), we substitute to obtain $(c + x)y = a c$. This equation now contains only variables $x$, $y$, $a$, and $c$, ready for expansion and solution.",
                "direct_dependent_steps": [
                    23,
                    24,
                    25
                ],
                "node": "Therefore $(c + x)y = a c$."
            },
            {
                "step_id": 27,
                "edge": "This step applies the intersecting chords theorem at point $A$, leveraging the circle geometry where chords $PQ$ (on line $AB$) and $CD$ (on line $CAD$) intersect at $A$. The theorem gives $AP \\cdot AQ = AC \\cdot AD$, establishing a second equation for the system.",
                "direct_dependent_steps": null,
                "node": "By the power of a point theorem at $A$, we have $AP\\cdot AQ = AC\\cdot AD$."
            },
            {
                "step_id": 28,
                "edge": "Using Step 16 ($x = AP$), Step 21 ($AQ = c + y$), and Step 27 ($AP \\cdot AQ = AC \\cdot AD$), we substitute to form $x(c + y) = AC \\cdot AD$. This converts the geometric relationship into an algebraic equation involving $x$ and $y$.",
                "direct_dependent_steps": [
                    16,
                    21,
                    27
                ],
                "node": "Substituting $AP = x$ and $AQ = c + y$ into $AP\\cdot AQ = AC\\cdot AD$ gives $x(c + y) = AC\\cdot AD$."
            },
            {
                "step_id": 29,
                "edge": "From Step 6 ($b = CA$), we state $AC = b$ since $AC$ is identical to $CA$. This substitution ensures consistent variable representation for side $AC$ in the power of a point equation at $A$.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "$AC = b$."
            },
            {
                "step_id": 30,
                "edge": "Using Step 11 ($DA = c$), we note $AD = c$ because segment length $AD$ equals $DA$. This replaces $AD$ with $c$ in the equation, simplifying the right-hand side to $b c$.",
                "direct_dependent_steps": [
                    11
                ],
                "node": "$AD = c$."
            },
            {
                "step_id": 31,
                "edge": "Combining Step 28 ($x(c + y) = AC \\cdot AD$), Step 29 ($AC = b$), and Step 30 ($AD = c$), we derive $x(c + y) = b c$. This second equation, alongside Step 26's equation, forms a system to solve for $x$ and $y$.",
                "direct_dependent_steps": [
                    28,
                    29,
                    30
                ],
                "node": "Therefore $x(c + y) = b c$."
            },
            {
                "step_id": 32,
                "edge": "Expanding Step 26's equation $(c + x)y = a c$ using distributive property yields $a c = xy + cy$. This rearrangement isolates terms to facilitate elimination when combined with the other equation, preparing for system solution.",
                "direct_dependent_steps": [
                    26
                ],
                "node": "Expanding $(c + x)y = a c$ gives $a c = xy + cy$."
            },
            {
                "step_id": 33,
                "edge": "Expanding Step 31's equation $x(c + y) = b c$ via distributive property gives $b c = xy + cx$. This symmetric expansion matches the form of Step 32, enabling direct subtraction to eliminate the $xy$ term.",
                "direct_dependent_steps": [
                    31
                ],
                "node": "Expanding $x(c + y) = b c$ gives $b c = xy + cx$."
            },
            {
                "step_id": 34,
                "edge": "Subtracting Step 33 ($b c = xy + cx$) from Step 32 ($a c = xy + cy$) eliminates $xy$, resulting in $a c - b c = cy - cx$. This operation isolates the difference of products, simplifying to a linear relationship between $x$ and $y$.",
                "direct_dependent_steps": [
                    32,
                    33
                ],
                "node": "Subtracting $b c = xy + cx$ from $a c = xy + cy$ yields $a c - b c = cy - cx$."
            },
            {
                "step_id": 35,
                "edge": "Factoring Step 34's equation $a c - b c = cy - cx$ gives $c(a - b) = c(y - x)$ by extracting common factors on both sides. This factorization reveals the proportional relationship between the side differences and segment differences.",
                "direct_dependent_steps": [
                    34
                ],
                "node": "Factoring gives $c(a - b) = c(y - x)$."
            },
            {
                "step_id": 36,
                "edge": "Dividing both sides of Step 35's equation $c(a - b) = c(y - x)$ by $c$ (valid since $c = AB = 15 \\neq 0$) yields $a - b = y - x$. This simplification removes the common factor, producing a direct linear equation relating $x$ and $y$.",
                "direct_dependent_steps": [
                    35
                ],
                "node": "Dividing both sides by $c$ gives $a - b = y - x$."
            },
            {
                "step_id": 37,
                "edge": "Rearranging Step 36's equation $a - b = y - x$ by adding $x$ to both sides gives $y = x + (a - b)$. This expresses $y$ explicitly in terms of $x$, reducing the system to a single variable for substitution.",
                "direct_dependent_steps": [
                    36
                ],
                "node": "Rearranging gives $y = x + (a - b)$."
            },
            {
                "step_id": 38,
                "edge": "Substituting Step 5 ($a = 18$) and Step 6 ($b = 20$) into Step 37's equation $y = x + (a - b)$ yields $y = x - 2$. The arithmetic $18 - 20 = -2$ is verified by noting $BC < CA$, so the difference is negative, and this simplifies the relationship to $y = x - 2$.",
                "direct_dependent_steps": [
                    5,
                    6,
                    37
                ],
                "node": "Substituting $a = 18$ and $b = 20$ yields $y = x - 2$."
            },
            {
                "step_id": 39,
                "edge": "Substituting Step 38's $y = x - 2$ into Step 26's equation $(c + x)y = a c$ gives $(c + x)(x - 2) = a c$. This reduces the system to a single equation in $x$, ready for numerical substitution and solving.",
                "direct_dependent_steps": [
                    26,
                    38
                ],
                "node": "Substituting $y = x - 2$ into $(c + x)y = a c$ gives $(c + x)(x - 2) = a c$."
            },
            {
                "step_id": 40,
                "edge": "Using Step 4 ($c = 15$) and Step 5 ($a = 18$) in Step 39's equation $(c + x)(x - 2) = a c$ yields $(x + 15)(x - 2) = 270$. The product $18 \\times 15 = 270$ is confirmed by $10 \\times 18 = 180$ and $5 \\times 18 = 90$, summing to $270$, ensuring correct substitution.",
                "direct_dependent_steps": [
                    4,
                    5,
                    39
                ],
                "node": "Substituting $c = 15$ and $a = 18$ into $(c + x)(x - 2) = a c$ yields $(x + 15)(x - 2) = 270$."
            },
            {
                "step_id": 41,
                "edge": "Expanding Step 40's $(x + 15)(x - 2) = 270$ using FOIL gives $x^2 - 2x + 15x - 30 = 270$, which simplifies to $x^2 + 13x - 30 = 270$. Sanity check: coefficients $-2 + 15 = 13$ and $15 \\times (-2) = -30$ are correct.",
                "direct_dependent_steps": [
                    40
                ],
                "node": "Expanding $(x + 15)(x - 2) = 270$ gives $x^2 + 13x - 30 = 270$."
            },
            {
                "step_id": 42,
                "edge": "Subtracting $270$ from both sides of Step 41's $x^2 + 13x - 30 = 270$ gives $x^2 + 13x - 300 = 0$. This standard quadratic form is necessary for applying the quadratic formula, and the constant term $-30 - 270 = -300$ is verified.",
                "direct_dependent_steps": [
                    41
                ],
                "node": "Subtracting $270$ from both sides gives $x^2 + 13x - 300 = 0$."
            },
            {
                "step_id": 43,
                "edge": "Applying the quadratic formula to Step 42's $x^2 + 13x - 300 = 0$ gives $x = \\frac{-13 \\pm \\sqrt{13^2 - 4 \\cdot 1 \\cdot (-300)}}{2}$. The discriminant calculation $13^2 - 4(1)(-300)$ follows the standard formula $b^2 - 4ac$ with $a=1$, $b=13$, $c=-300$.",
                "direct_dependent_steps": [
                    42
                ],
                "node": "The quadratic formula gives $x = \\frac{-13 \\pm \\sqrt{13^2 - 4\\cdot1\\cdot(-300)}}{2}$."
            },
            {
                "step_id": 44,
                "edge": "Computing the discriminant from Step 43: $13^2 = 169$ and $-4 \\cdot 1 \\cdot (-300) = 1200$, so $169 + 1200 = 1369$. Quick verification: $13^2 = 169$ is standard, and $4 \\times 300 = 1200$, so the sum is correct.",
                "direct_dependent_steps": [
                    43
                ],
                "node": "Computing the discriminant gives $13^2 + 1200 = 1369$."
            },
            {
                "step_id": 45,
                "edge": "From Step 44's discriminant $1369$, we compute $\\sqrt{1369} = 37$ since $37 \\times 37 = 1369$. Sanity check: $30^2 = 900$, $40^2 = 1600$, and $37^2 = (30+7)^2 = 900 + 420 + 49 = 1369$, confirming the square root.",
                "direct_dependent_steps": [
                    44
                ],
                "node": "Thus $\\sqrt{1369} = 37$."
            },
            {
                "step_id": 46,
                "edge": "Substituting Step 43's formula and Step 45's $\\sqrt{1369} = 37$ gives $x = \\frac{-13 + 37}{2} = 12$ or $x = \\frac{-13 - 37}{2} = -25$. The arithmetic $-13 + 37 = 24$ (so $24/2=12$) and $-13 - 37 = -50$ (so $-50/2=-25$) is verified.",
                "direct_dependent_steps": [
                    43,
                    45
                ],
                "node": "Hence $x = \\frac{-13 + 37}{2} = 12$ or $x = \\frac{-13 - 37}{2} = -25$."
            },
            {
                "step_id": 47,
                "edge": "Rejecting Step 46's $x = -25$ because Step 16 defines $x = AP$ as a length, which must be non-negative. Geometrically, $P$ is positioned such that $AP$ is a positive extension beyond $A$, so negative values are extraneous.",
                "direct_dependent_steps": [
                    46
                ],
                "node": "Reject $x = -25$ because $x = AP$ is a length."
            },
            {
                "step_id": 48,
                "edge": "Selecting the valid solution from Step 47, we conclude $x = 12$. This positive length satisfies the geometric constraints and will be used to compute $y$ and ultimately $PQ$.",
                "direct_dependent_steps": [
                    47
                ],
                "node": "Therefore $x = 12$."
            },
            {
                "step_id": 49,
                "edge": "Substituting Step 38 ($y = x - 2$) and Step 48 ($x = 12$) gives $y = 12 - 2 = 10$. The arithmetic is straightforward, and $y = 10$ is positive, consistent with $BQ$ being a length beyond $B$.",
                "direct_dependent_steps": [
                    38,
                    48
                ],
                "node": "Then $y = x - 2 = 10$."
            },
            {
                "step_id": 50,
                "edge": "Given Step 14 ($P$ beyond $A$) and Step 15 ($Q$ beyond $B$), the segment $PQ$ comprises $PA$ (from $P$ to $A$), $AB$ (from $A$ to $B$), and $BQ$ (from $B$ to $Q$). Thus $PQ = PA + AB + BQ$ by segment addition along the straight line $P$-$A$-$B$-$Q$.",
                "direct_dependent_steps": [
                    14,
                    15
                ],
                "node": "By definition $PQ = PA + AB + BQ$."
            },
            {
                "step_id": 51,
                "edge": "Using Step 4 ($c = AB$), Step 16 ($x = AP$), Step 17 ($y = BQ$), and Step 50 ($PQ = PA + AB + BQ$), we substitute to get $PQ = x + c + y$. Since $PA = AP = x$ (lengths are positive), this expresses $PQ$ in terms of solved variables.",
                "direct_dependent_steps": [
                    4,
                    16,
                    17,
                    50
                ],
                "node": "Therefore $PQ = x + c + y$."
            },
            {
                "step_id": 52,
                "edge": "Substituting Step 4 ($c = 15$), Step 48 ($x = 12$), Step 49 ($y = 10$), and Step 51 ($PQ = x + c + y$) yields $PQ = 12 + 15 + 10 = 37$. The sum $12 + 15 = 27$ and $27 + 10 = 37$ is verified, matching the expected final length.",
                "direct_dependent_steps": [
                    4,
                    48,
                    49,
                    51
                ],
                "node": "Substituting $x = 12$, $c = 15$, and $y = 10$ yields $PQ = 37$."
            },
            {
                "step_id": 53,
                "edge": "Based on Step 52's calculation $PQ = 37$, we present the final answer in the required boxed format. This result satisfies all geometric constraints and algebraic derivations, confirming the length of $PQ$.",
                "direct_dependent_steps": [
                    52
                ],
                "node": "The final answer is $\\boxed{37}$."
            }
        ]
    }
]
