[
    {
        "problem_id": 195,
        "domain": [
            "Mathematics -> Geometry -> Plane Geometry -> Polygons",
            "Mathematics -> Geometry -> Solid Geometry -> 3D Shapes"
        ],
        "difficulty": 5.0,
        "problem_text": "Determine the number of unordered triples of distinct points in the $4 \\times 4 \\times 4$ lattice grid $\\{0,1,2,3\\}^{3}$ that are collinear in $\\mathbb{R}^{3}$ (i.e. there exists a line passing through the three points).",
        "sample_id": 1,
        "final_answer": "The final answer is \\boxed{376}",
        "steps": [
            {
                "step_id": 1,
                "edge": "The problem explicitly defines the grid as the set of all points with integer coordinates in the range {0,1,2,3} for each dimension, forming a 4×4×4 lattice cube in three-dimensional space. This step establishes the foundational domain of points we will analyze, as stated in the problem text.",
                "direct_dependent_steps": null,
                "node": "The lattice grid under consideration is $\\{0,1,2,3\\}^3$."
            },
            {
                "step_id": 2,
                "edge": "This restates the core objective from the problem statement: counting unordered triples of distinct lattice points that lie on a common straight line in ℝ³. It clarifies that we are seeking combinations of three distinct points where collinearity holds in the continuous geometric space, not just in the discrete grid sense.",
                "direct_dependent_steps": null,
                "node": "We seek the number of unordered triples of distinct lattice points that are collinear in $\\mathbb{R}^3$."
            },
            {
                "step_id": 3,
                "edge": "Building on the grid definition from Step 1 (coordinates 0 to 3 inclusive), any straight line intersecting the lattice can contain at most four distinct points. This follows because each coordinate can take only four integer values, and a line in ℝ³ can pass through at most one lattice point per integer coordinate step in any direction. Thus, the maximum collinear points on any line is constrained by the grid size.",
                "direct_dependent_steps": [
                    1
                ],
                "node": "Any line in this grid contains at most four lattice points because coordinates range from 0 to 3 inclusive."
            },
            {
                "step_id": 4,
                "edge": "To systematically count the collinear triples defined in Step 2, we adopt a classification strategy by the lines containing them. This approach avoids overcounting and ensures completeness, as each triple lies on exactly one line, while lines may contain multiple triples. We will categorize all possible lines based on their geometric orientation within the grid.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "We classify collinear triples by classifying the lines that contain them."
            },
            {
                "step_id": 5,
                "edge": "Following the classification framework from Step 4, we define Type (a) as axis-aligned lines—those parallel to two coordinate axes (e.g., constant y and z) and thus orthogonal to one coordinate plane (e.g., the xy-plane). These are the simplest lines to enumerate, as they align with the grid structure.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Type (a) lines are lines parallel to two coordinate axes and orthogonal to one coordinate plane."
            },
            {
                "step_id": 6,
                "edge": "To enumerate Type (a) lines as defined in Step 5, we consider all planes perpendicular to a coordinate axis. Specifically, for each direction v ∈ {x,y,z} and each constant k ∈ {0,1,2,3}, the plane v=k fixes one coordinate. This gives 3 choices for v and 4 for k, yielding 12 distinct planes that partition the grid orthogonally.",
                "direct_dependent_steps": [
                    5
                ],
                "node": "For each coordinate direction $v\\in\\{x,y,z\\}$ and each value $k\\in\\{0,1,2,3\\}$, consider the plane $v=k$."
            },
            {
                "step_id": 7,
                "edge": "Within a single plane v=k (from Step 6), lines parallel to one remaining axis (e.g., x-axis in z=k plane) require the other coordinate to be constant (e.g., fixed y). Since y takes 4 values (0,1,2,3), there are exactly four such lines per plane for one axis direction. For example, in z=0, fixing y=0,1,2,3 gives four distinct lines parallel to the x-axis.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Each such plane contains four lines parallel to one remaining axis."
            },
            {
                "step_id": 8,
                "edge": "Similarly, in the same plane v=k (from Step 6), lines parallel to the other remaining axis (e.g., y-axis in z=k plane) require the first coordinate to be constant (e.g., fixed x). With x taking 4 values, this yields four additional lines per plane for the second axis direction, as each fixed x generates a unique line.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "Each such plane also contains four lines parallel to the other remaining axis."
            },
            {
                "step_id": 9,
                "edge": "Combining the results from Step 7 (four lines for one axis) and Step 8 (four lines for the other axis), each plane v=k contains 4 + 4 = 8 axis-aligned lines. This accounts for all Type (a) lines within the plane, as no other axis-aligned lines exist in a single coordinate plane.",
                "direct_dependent_steps": [
                    7,
                    8
                ],
                "node": "Thus each plane $v=k$ contains $4+4=8$ lines in total."
            },
            {
                "step_id": 10,
                "edge": "As established in Step 6, there are 3 coordinate directions (x,y,z) and 4 values for k (0,1,2,3), so the total number of planes v=k is 3 × 4 = 12. Each plane is uniquely determined by the pair (v,k), and this count is fundamental for aggregating line totals.",
                "direct_dependent_steps": [
                    6
                ],
                "node": "There are $3\\times4=12$ choices of the pair $(v,k)$, so there are 12 such planes."
            },
            {
                "step_id": 11,
                "edge": "A Type (a) line (Step 5) has two fixed coordinates (e.g., y=a, z=b for an x-axis parallel line), so it lies in both the plane y=a (from Step 6) and the plane z=b (from Step 6). Thus, each such line is contained in exactly two of the planes v=k, which is critical for avoiding double-counting in the enumeration.",
                "direct_dependent_steps": [
                    5,
                    6
                ],
                "node": "Each line of type (a) lies in exactly two of these planes $v=k$."
            },
            {
                "step_id": 12,
                "edge": "Using Step 10 (12 planes), Step 9 (8 lines per plane), and Step 11 (each line counted twice), we compute the total Type (a) lines as (12 × 8) / 2 = 48. Division by 2 corrects for the double-counting identified in Step 11, yielding the exact count of distinct axis-aligned lines.",
                "direct_dependent_steps": [
                    9,
                    10,
                    11
                ],
                "node": "Therefore, the total number of type (a) lines is $\\frac{12\\times8}{2}=48$."
            },
            {
                "step_id": 13,
                "edge": "From Step 3, lines have at most four lattice points. For Type (a) lines (Step 5), the varying coordinate spans all four values (0,1,2,3) while others are fixed, so each contains exactly four distinct points. For example, the line x∈{0,1,2,3}, y=0, z=0 has points (0,0,0), (1,0,0), (2,0,0), (3,0,0).",
                "direct_dependent_steps": [
                    3,
                    5
                ],
                "node": "Each type (a) line contains exactly four lattice points."
            },
            {
                "step_id": 14,
                "edge": "Given that a Type (a) line has four distinct points (Step 13), any unordered triple of these points is collinear by definition. Choosing three points from four defines a unique collinear triple, and this combinatorial approach systematically captures all triples on the line.",
                "direct_dependent_steps": [
                    13
                ],
                "node": "Each set of three points chosen from four points on a line forms one unordered collinear triple."
            },
            {
                "step_id": 15,
                "edge": "Applying the combination formula to Step 14, the number of ways to choose 3 points from 4 is C(4,3) = 4. This is verified by enumeration: for points {A,B,C,D}, the triples are ABC, ABD, ACD, BCD. Each line thus contributes exactly four distinct unordered collinear triples.",
                "direct_dependent_steps": [
                    14
                ],
                "node": "There are $\\binom{4}{3}=4$ choices of three points on a line of four points."
            },
            {
                "step_id": 16,
                "edge": "Multiplying Step 12 (48 Type (a) lines) by Step 15 (4 triples per line) gives 48 × 4 = 192. This uses the multiplication principle for counting: each line independently contributes its triples, and the total is the sum over all lines.",
                "direct_dependent_steps": [
                    12,
                    15
                ],
                "node": "Thus the total number of collinear triples on lines of type (a) is $48\\times4=192$."
            },
            {
                "step_id": 17,
                "edge": "Extending the classification from Step 4, Type (b) lines are the full-length diagonals within coordinate planes—specifically, those connecting opposite corners of a 4×4 grid face and containing four lattice points. These diagonals lie entirely in planes like z=k and have slope ±1 in the plane.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Type (b) lines are plane diagonals of length four contained in coordinate planes."
            },
            {
                "step_id": 18,
                "edge": "As in Step 6 but now for Type (b) context, a coordinate plane is defined by fixing one coordinate (v) to k (from Step 17). Thus, for v∈{x,y,z} and k∈{0,1,2,3}, we have the same 12 planes as in Step 6, each serving as a 4×4 grid for diagonal enumeration.",
                "direct_dependent_steps": [
                    6,
                    17
                ],
                "node": "For each coordinate direction $v\\in\\{x,y,z\\}$ and each $k\\in\\{0,1,2,3\\}$, the plane $v=k$ is a coordinate plane."
            },
            {
                "step_id": 19,
                "edge": "In each coordinate plane (Step 18), two diagonals span the entire grid: one from (0,0,k) to (3,3,k) and another from (0,3,k) to (3,0,k) for fixed k. These are the only diagonals passing through four lattice points, as shorter diagonals would miss corners.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "Each coordinate plane has two long diagonals connecting its corner lattice points."
            },
            {
                "step_id": 20,
                "edge": "Step 19's long diagonals traverse the full 4×4 grid, so they include all intermediate points. For example, (0,0,k) to (3,3,k) passes through (1,1,k) and (2,2,k), totaling four points. This matches Step 3's maximum and confirms the diagonal length.",
                "direct_dependent_steps": [
                    19
                ],
                "node": "Each long diagonal in a coordinate plane contains four lattice points."
            },
            {
                "step_id": 21,
                "edge": "Reiterating Step 18, there are 3 choices for v (x,y,z) and 4 for k (0,1,2,3), so 3 × 4 = 12 coordinate planes. This count is identical to Step 10 and forms the basis for aggregating plane-based diagonals.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "There are $3\\times4=12$ coordinate planes of the form $v=k$."
            },
            {
                "step_id": 22,
                "edge": "By Step 2's definition, any three distinct points on a straight line (like a long diagonal) form a collinear triple. Since Step 20 confirms these diagonals are straight lines with four points, all subsets of three points satisfy the collinearity condition.",
                "direct_dependent_steps": [
                    2
                ],
                "node": "Each unordered triple on a long diagonal is a collinear triple."
            },
            {
                "step_id": 23,
                "edge": "Step 20 establishes four points per diagonal, Step 22 confirms collinearity for any three, and Step 15 already computed C(4,3)=4 for such sets. Thus, each long diagonal contributes exactly four collinear triples, consistent with combinatorial principles for lines with four points.",
                "direct_dependent_steps": [
                    15,
                    20,
                    22
                ],
                "node": "There are $\\binom{4}{3}=4$ collinear triples on each long diagonal."
            },
            {
                "step_id": 24,
                "edge": "Combining Step 21 (12 planes), Step 19 (2 diagonals per plane), and Step 23 (4 triples per diagonal), we calculate 12 × 2 × 4 = 96. This multiplication accounts for all Type (b) triples, as each diagonal is unique to one plane and contributes independently.",
                "direct_dependent_steps": [
                    19,
                    21,
                    23
                ],
                "node": "Therefore, the total number of collinear triples on type (b) lines is $12\\times2\\times4=96$."
            },
            {
                "step_id": 25,
                "edge": "Completing the classification from Step 4, Type (c) lines are shorter diagonals within coordinate planes that contain exactly three lattice points. These do not span the full grid (e.g., from (0,0,k) to (2,2,k)) and are distinct from Type (b) full diagonals.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Type (c) lines are diagonals of length three contained in coordinate planes."
            },
            {
                "step_id": 26,
                "edge": "In a coordinate plane (Step 18), diagonals with exactly three points arise from offsets: for slope 1, diagonals like (0,0,k)-(1,1,k)-(2,2,k) and (1,1,k)-(2,2,k)-(3,3,k); similarly for slope -1. Inspection of the 4×4 grid confirms four such diagonals per plane (two per slope direction).",
                "direct_dependent_steps": [
                    18,
                    25
                ],
                "node": "For each coordinate plane $v=k$, inspection shows there are four diagonals containing exactly three lattice points."
            },
            {
                "step_id": 27,
                "edge": "As in Step 18 and Step 21, there are 3 × 4 = 12 coordinate planes. This count remains unchanged as we shift focus to shorter diagonals within the same planes.",
                "direct_dependent_steps": [
                    18
                ],
                "node": "There are $3\\times4=12$ such coordinate planes."
            },
            {
                "step_id": 28,
                "edge": "Step 26 specifies that Type (c) diagonals contain exactly three distinct points. Thus, there is only one way to choose all three points, forming a single unordered collinear triple per diagonal—no subset choices are possible beyond the full set.",
                "direct_dependent_steps": [
                    26
                ],
                "node": "Each three-point diagonal yields exactly one unordered collinear triple."
            },
            {
                "step_id": 29,
                "edge": "Aggregating Step 27 (12 planes), Step 26 (4 diagonals per plane), and Step 28 (1 triple per diagonal), we compute 12 × 4 = 48. Each diagonal is unique to its plane, and the count is direct since triples per diagonal are fixed at one.",
                "direct_dependent_steps": [
                    26,
                    27,
                    28
                ],
                "node": "Hence the total number of collinear triples on type (c) lines is $12\\times4=48$."
            },
            {
                "step_id": 30,
                "edge": "As part of Step 4's classification, Type (d) lines are the space diagonals connecting opposite corners of the entire 4×4×4 cube (e.g., (0,0,0) to (3,3,3)). A cube has exactly four such diagonals, each defined by a direction (±1,±1,±1) with consistent signs, and they pass through the cube's center.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Type (d) lines are the four main space diagonals of the cube connecting opposite corners."
            },
            {
                "step_id": 31,
                "edge": "For a Type (d) diagonal (Step 30), such as (0,0,0) to (3,3,3), the points are (0,0,0), (1,1,1), (2,2,2), (3,3,3). The integer steps in direction (1,1,1) yield exactly four lattice points, consistent with Step 3's maximum for grid-aligned diagonals.",
                "direct_dependent_steps": [
                    30
                ],
                "node": "Each main space diagonal contains four lattice points."
            },
            {
                "step_id": 32,
                "edge": "Step 31 confirms four points per main diagonal, and Step 15 established C(4,3)=4 triples for any four collinear points. Thus, each Type (d) line contributes four collinear triples, identical to the axis-aligned case in Step 15.",
                "direct_dependent_steps": [
                    15,
                    31
                ],
                "node": "Each main diagonal yields $\\binom{4}{3}=4$ collinear triples."
            },
            {
                "step_id": 33,
                "edge": "Step 30 states there are four main space diagonals, and Step 32 gives four triples per diagonal. Multiplying these yields 4 × 4 = 16. This is straightforward since each diagonal is distinct and contributes independently to the total.",
                "direct_dependent_steps": [
                    30,
                    32
                ],
                "node": "Therefore, the total number of collinear triples on type (d) lines is $4\\times4=16$."
            },
            {
                "step_id": 34,
                "edge": "Finalizing Step 4's classification, Type (e) lines are space diagonals with exactly three lattice points that do not span the full cube (unlike Type (d)). These are shorter diagonals, often with endpoints on cube faces but not corners, and are critical for completeness.",
                "direct_dependent_steps": [
                    4
                ],
                "node": "Type (e) lines are space diagonals containing exactly three lattice points and not spanning the full cube."
            },
            {
                "step_id": 35,
                "edge": "Given the grid in Step 1 (coordinates 0–3), interior points avoid boundary values, so each coordinate must be in {1,2}. Thus, the interior subgrid is {1,2}³, as boundary points (with 0 or 3 in any coordinate) are excluded from this set.",
                "direct_dependent_steps": [
                    1,
                    34
                ],
                "node": "The set of interior lattice points is $\\{1,2\\}^3$."
            },
            {
                "step_id": 36,
                "edge": "Step 35 defines the interior as {1,2}³, so with 2 choices per coordinate, the count is 2 × 2 × 2 = 8 points. These points (e.g., (1,1,1), (1,1,2)) are central to identifying Type (e) diagonals.",
                "direct_dependent_steps": [
                    35
                ],
                "node": "There are $2^3=8$ interior lattice points."
            },
            {
                "step_id": 37,
                "edge": "For any interior point (Step 35), space diagonals in directions (±1,±1,±1) pass through it. Since direction and opposite direction define the same line, there are 8/2 = 4 distinct lines per point (e.g., through (1,1,1): (1,1,1)±t(1,1,1), (1,1,1)±t(1,1,-1), etc.).",
                "direct_dependent_steps": [
                    35
                ],
                "node": "Each interior point is the midpoint of four potential space diagonal lines in directions $(\\pm1,\\pm1,\\pm1)$."
            },
            {
                "step_id": 38,
                "edge": "Among the four diagonal lines through an interior point (Step 37), one aligns with a main space diagonal (Type d). For example, through (1,1,1), the direction (1,1,1) extends to (0,0,0) and (3,3,3), forming a Type (d) line as defined in Step 30.",
                "direct_dependent_steps": [
                    37
                ],
                "node": "One of these four lines through an interior point is a main diagonal of the cube."
            },
            {
                "step_id": 39,
                "edge": "Step 37 gives four lines per interior point, and Step 38 identifies one as Type (d). Thus, 4 - 1 = 3 lines per point are non-main space diagonals. Each such line contains exactly three lattice points (the interior point and two boundary points), making them Type (e) lines as per Step 34.",
                "direct_dependent_steps": [
                    37,
                    38
                ],
                "node": "Therefore, each interior point is the midpoint of exactly three non-main space diagonals containing three lattice points."
            },
            {
                "step_id": 40,
                "edge": "Step 39 confirms Type (e) diagonals have exactly three distinct points, so there is precisely one unordered triple per diagonal—the entire set of points. No additional combinations are possible, as subsets would require fewer points.",
                "direct_dependent_steps": [
                    39
                ],
                "node": "Each such non-main space diagonal yields exactly one unordered collinear triple."
            },
            {
                "step_id": 41,
                "edge": "Step 36 gives 8 interior points, Step 39 states 3 Type (e) lines per point, and Step 40 confirms 1 triple per line. Since each Type (e) line has a unique interior midpoint (endpoints are boundary points), no overcounting occurs. Thus, 8 × 3 = 24 triples.",
                "direct_dependent_steps": [
                    36,
                    39,
                    40
                ],
                "node": "Thus the total number of collinear triples on type (e) lines is $8\\times3=24$."
            },
            {
                "step_id": 42,
                "edge": "Summing contributions: Step 16 (192 for Type a), Step 24 (96 for Type b), Step 29 (48 for Type c), Step 33 (16 for Type d), and Step 41 (24 for Type e). Arithmetic: 192 + 96 = 288; 288 + 48 = 336; 336 + 16 = 352; 352 + 24 = 376. This total is exhaustive, as Step 4's classification covers all collinear triples without overlap.",
                "direct_dependent_steps": [
                    16,
                    24,
                    29,
                    33,
                    41
                ],
                "node": "Summing the contributions from types (a) through (e) gives $192+96+48+16+24=376$."
            }
        ]
    }
]
