[
    {
        "problem_id": 1703,
        "domain": [
            "Mathematics -> Geometry -> Plane Geometry -> Other"
        ],
        "difficulty": 4.5,
        "problem_text": "Find the angle of reflection $\\theta$ such that a ball bounces 2012 times inside a $1 \\times 1$ square before returning to its starting point.",
        "sample_id": 1,
        "final_answer": "\\boxed{\\theta=\\tan^{-1}\\left(\\frac{1009}{1005}\\right)}",
        "steps": [
            {
                "step_id": 1,
                "edge": "The problem statement establishes the initial condition for the bouncing ball scenario, specifying that the ball begins at the origin (0,0) within a unit square bounded by coordinates (0,0), (1,0), (1,1), and (0,1). This foundational setup provides the reference frame for modeling the ball's trajectory and reflections.",
                "direct_dependent_steps": null,
                "node": "The ball starts at the origin inside a $1\\times1$ square."
            },
            {
                "step_id": 2,
                "edge": "This step describes the core physical behavior of the system: when the ball encounters a boundary of the square (vertical or horizontal side), it undergoes reflection according to the law of reflection (angle of incidence equals angle of reflection). This characteristic motion is inherent to the problem's description and serves as the basis for applying mathematical modeling techniques to simplify the analysis.",
                "direct_dependent_steps": null,
                "node": "The ball reflects off the sides of the square."
            },
            {
                "step_id": 3,
                "edge": "Building on the reflection behavior described in Step 2, we employ the standard geometric technique of 'unfolding' the square. Instead of tracking reflections, we replicate the square infinitely in all directions, transforming each reflection into straight-line motion through adjacent grid squares. This method preserves the path's geometry while converting the complex bouncing trajectory into a simpler straight-line path in an infinite grid of unit squares, leveraging symmetry to avoid trigonometric complications during reflections.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "We apply the method of unfolding the square by considering an infinite grid of unit squares to model reflections as straight-line motion."
            },
            {
                "step_id": 4,
                "edge": "Combining the starting point from Step 1 (origin) with the unfolding method from Step 3, the ball's entire trajectory becomes a straight line in the infinite grid. This line must terminate at a lattice point (a,b) where a and b are positive integers, representing the coordinates where the path returns to an equivalent starting position in the unfolded grid. The integers a and b correspond to the number of squares traversed horizontally and vertically before the path closes.",
                "direct_dependent_steps": [
                    1,
                    3
                ],
                "node": "In the unfolded model, the ball travels in a straight line from the origin to a lattice point $(a,b)$."
            },
            {
                "step_id": 5,
                "edge": "Extending Step 4, we specify that (a,b) must be the first lattice point encountered along the straight-line path. This ensures the path corresponds to the minimal closed trajectory in the original square, avoiding intermediate returns to the starting point. If a smaller lattice point existed on the path, it would imply the ball returned prematurely, violating the requirement of exactly 2012 bounces before closure.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "The first lattice point the path meets is $(a,b)$."
            },
            {
                "step_id": 6,
                "edge": "From Step 4's lattice point (a,b), we assume without loss of generality that b > a to simplify the analysis. This assumption restricts consideration to trajectories with a steeper slope (greater vertical displacement per horizontal unit), eliminating symmetric cases where a > b (which would yield equivalent angles via horizontal/vertical symmetry). The condition b > a corresponds to angles θ > 45° with the horizontal, and we will later confirm this yields the required solution.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "We assume $b>a$."
            },
            {
                "step_id": 7,
                "edge": "To prevent the path from terminating early at a corner (vertex) of the square, Step 5's lattice point (a,b) must satisfy gcd(a,b) = 1. If d = gcd(a,b) > 1, the path would first reach (a/d, b/d), corresponding to a vertex in the original square where the ball stops bouncing. Thus, coprimality ensures the path completes exactly the desired bounces without premature termination at a corner.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "We require $\\gcd(a,b)=1$ to avoid hitting a vertex before the desired number of bounces."
            },
            {
                "step_id": 8,
                "edge": "Directly from Step 4's straight-line path from (0,0) to (a,b) in the unfolded grid, the slope is defined as the ratio of vertical displacement to horizontal displacement, giving b/a. This slope directly determines the angle θ via tanθ = slope, linking geometric trajectory to the target angle.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "The slope of the straight-line path is $b/a$."
            },
            {
                "step_id": 9,
                "edge": "Using Step 4's unfolded path model, the number of bounces is calculated by counting grid line crossings: traversing a squares horizontally requires crossing (a-1) vertical grid lines (each representing a vertical bounce), and traversing b squares vertically requires crossing (b-1) horizontal grid lines (each representing a horizontal bounce). Summing these gives the total bounces as (a-1) + (b-1), which corresponds exactly to reflections in the original square.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "The number of bounces before reaching $(a,b)$ equals $(a-1)+(b-1)$."
            },
            {
                "step_id": 10,
                "edge": "Applying Step 9's bounce count formula to the problem's requirement of 2012 bounces, we set (a-1) + (b-1) = 2012. This equation directly encodes the bounce constraint into the lattice point parameters, establishing the relationship between a and b that must be satisfied for the trajectory to meet the problem's condition.",
                "direct_dependent_steps": [
                    9
                ],
                "node": "We set $(a-1)+(b-1)=2012$."
            },
            {
                "step_id": 11,
                "edge": "Simplifying Step 10's equation (a-1) + (b-1) = 2012 through basic algebra: a + b - 2 = 2012, so a + b = 2014. This reduces the bounce constraint to a linear Diophantine equation, streamlining the search for valid integer pairs (a,b).",
                "direct_dependent_steps": [
                    10
                ],
                "node": "Thus $a+b=2014$."
            },
            {
                "step_id": 12,
                "edge": "Rearranging Step 11's equation a + b = 2014, we isolate b as b = 2014 - a. This parametrization expresses b in terms of a, allowing us to analyze the slope and coprimality conditions as functions of a single variable.",
                "direct_dependent_steps": [
                    11
                ],
                "node": "We express $b$ as $2014-a$."
            },
            {
                "step_id": 13,
                "edge": "Substituting Step 12's expression b = 2014 - a into Step 8's slope formula b/a yields (2014 - a)/a. This rewrites the slope purely in terms of a, enabling analysis of how the slope varies with a and facilitating the search for valid a values that satisfy all constraints.",
                "direct_dependent_steps": [
                    8,
                    12
                ],
                "node": "The slope $b/a$ becomes $(2014-a)/a$."
            },
            {
                "step_id": 14,
                "edge": "From Step 13's slope expression (2014 - a)/a, we observe it is equivalent to 2014/a - 1. For positive integer a, as a increases, 2014/a decreases monotonically, so the entire expression decreases. This monotonicity is crucial: larger a values produce smaller slopes, meaning we can minimize the slope (and thus the angle θ) by selecting the largest valid a satisfying all constraints.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "The expression $(2014-a)/a$ is decreasing as $a$ increases for positive $a$."
            },
            {
                "step_id": 15,
                "edge": "Combining Step 6's assumption b > a with Step 12's relation b = 2014 - a, we substitute to get 2014 - a > a. This inequality enforces the slope condition b/a > 1 (since b > a), which corresponds to angles θ > 45° and aligns with our earlier assumption to restrict the solution space.",
                "direct_dependent_steps": [
                    6,
                    12
                ],
                "node": "The inequality $b>a$ implies $a<2014-a$."
            },
            {
                "step_id": 16,
                "edge": "Solving Step 15's inequality 2014 - a > a algebraically: 2014 > 2a, so a < 1007. Since a must be a positive integer (as a lattice coordinate), this bounds a to values from 1 to 1006 inclusive, narrowing the search space for valid solutions.",
                "direct_dependent_steps": [
                    15
                ],
                "node": "Solving $a<2014-a$ gives $a<1007$."
            },
            {
                "step_id": 17,
                "edge": "Given Step 16's constraint a < 1007, the largest integer a satisfying this is 1006. This candidate maximizes a (and thus minimizes the slope per Step 14), but we must verify if it meets the coprimality requirement from Step 7 before accepting it as a solution.",
                "direct_dependent_steps": [
                    16
                ],
                "node": "The maximal integer less than $1007$ is $1006$."
            },
            {
                "step_id": 18,
                "edge": "Using Step 12's relation b = 2014 - a and Step 17's candidate a = 1006, we compute b = 2014 - 1006 = 1008. Checking gcd(1006, 1008): 1008 - 1006 = 2, and gcd(1006, 2) = 2 since 1006 is even. Thus gcd = 2 ≠ 1, violating Step 7's requirement for coprimality. This confirms a = 1006 is invalid as it would cause premature termination at a corner.",
                "direct_dependent_steps": [
                    12,
                    17
                ],
                "node": "We check $\\gcd(1006,1008)$ equals $2$."
            },
            {
                "step_id": 19,
                "edge": "Since Step 18 invalidated a = 1006, we decrement a to the next largest integer below 1006, which is 1005. This maintains our strategy of seeking the largest possible a (to minimize slope per Step 14) while adhering to the constraint a < 1007 from Step 16.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "The next lower integer $a$ less than $1006$ is $1005$."
            },
            {
                "step_id": 20,
                "edge": "Applying Step 12's relation b = 2014 - a to Step 19's candidate a = 1005, we compute b = 2014 - 1005 = 1009. This gives the candidate lattice point (1005, 1009), which we will now verify for coprimality to ensure it satisfies the no-early-termination condition.",
                "direct_dependent_steps": [
                    12,
                    19
                ],
                "node": "We pair $a=1005$ with $b=2014-a=1009$."
            },
            {
                "step_id": 21,
                "edge": "To satisfy Step 7's coprimality requirement, we verify gcd(1005, 1009) = 1 using the Euclidean algorithm: 1009 - 1005 = 4; gcd(1005, 4) = gcd(4, 1005 mod 4) = gcd(4, 1) since 1005 = 4×251 + 1; gcd(4,1) = 1. This confirms no common divisors, so the path reaches (1005,1009) without hitting intermediate corners, satisfying Step 7's condition.",
                "direct_dependent_steps": [
                    7,
                    20
                ],
                "node": "We verify $\\gcd(1005,1009)=1$."
            },
            {
                "step_id": 22,
                "edge": "Combining Step 14's monotonicity (slope decreases as a increases), Step 20's candidate (a=1005, b=1009), and Step 21's verified coprimality, this pair maximizes a while satisfying all constraints (a < 1007, gcd=1). Since larger a minimizes slope per Step 14, and this is the largest valid a (as a=1006 failed), it yields the minimal possible slope for the trajectory, which corresponds to the smallest valid angle θ meeting the bounce condition.",
                "direct_dependent_steps": [
                    14,
                    20,
                    21
                ],
                "node": "Thus $a=1005$ and $b=1009$ minimize the slope $b/a$."
            },
            {
                "step_id": 23,
                "edge": "From Step 22's validated lattice point (a=1005, b=1009), Step 8's slope definition gives b/a = 1009/1005. This fraction is already simplified (as confirmed by gcd=1 in Step 21), so the slope is exactly 1009/1005.",
                "direct_dependent_steps": [
                    22
                ],
                "node": "Hence the slope of the path is $1009/1005$."
            },
            {
                "step_id": 24,
                "edge": "Using Step 23's slope value and the fundamental relationship between slope and angle in the unfolded grid (where slope = tanθ), we establish tanθ = 1009/1005. This directly links the geometric trajectory to the target angle θ, which we now solve for explicitly.",
                "direct_dependent_steps": [
                    23
                ],
                "node": "The angle $\\theta$ satisfies $\\tan\\theta=1009/1005$."
            },
            {
                "step_id": 25,
                "edge": "Applying the inverse tangent function to Step 24's equation tanθ = 1009/1005, we obtain θ = tan⁻¹(1009/1005). This final expression satisfies all problem constraints: it yields exactly 2012 bounces (verified via a+b=2014 and gcd=1), and the angle is well-defined within the context of reflection geometry.",
                "direct_dependent_steps": [
                    24
                ],
                "node": "The final answer is \\boxed{\\theta=\\tan^{-1}\\left(\\frac{1009}{1005}\\right)}"
            }
        ]
    }
]
