{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 31,
   "id": "2ddc1af8",
   "metadata": {},
   "outputs": [],
   "source": [
    "folderPath = 'NONEcode/verl-fork/verl/scripts/train/verlCheckpoint/Summary/qwen4b_dapo_math_10k_context_linear_reward_with_summary_attention_loss_original/rollout'\n",
    "import os\n",
    "import json\n",
    "files = os.listdir(folderPath)\n",
    "data = []\n",
    "for file in files:\n",
    "    if file.endswith('.jsonl'):\n",
    "        temp = []\n",
    "        with open(os.path.join(folderPath, file), 'r') as f:\n",
    "            for line in f:\n",
    "                temp.append(json.loads(line))\n",
    "        data.append(temp)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "b4024a67",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{'data_source': 'DAPO-Math-17k',\n",
       " 'prompt': \"user\\nIn triangle $ABC$, $\\\\sin \\\\angle A = \\\\frac{4}{5}$ and $\\\\angle A < 90^\\\\circ$. Let $D$ be a point outside triangle $ABC$ such that $\\\\angle BAD = \\\\angle DAC$ and $\\\\angle BDC = 90^\\\\circ$. Suppose that $AD = 1$ and that $\\\\frac{BD}{CD} = \\\\frac{3}{2}$. If $AB + AC$ can be expressed in the form $\\\\frac{a\\\\sqrt{b}}{c}$ where $a, b, c$ are pairwise relatively prime integers, find $a + b + c$. Let's think step by step and output the final answer within \\\\boxed{}.\\nassistant\\n\",\n",
       " 'response': \"<think>\\nOkay, let's try to tackle this geometry problem. It seems a bit complex, but if I break it down step by step, maybe I can figure it out. Let me start by writing down all the given information and see what I can derive from it.\\n\\nFirst, triangle ABC with angle A having sine 4/5 and angle A is less than 90 degrees. So angle A is acute. Then there's a point D outside the triangle such that angle BAD equals angle DAC, so D is on the angle bisector of angle A. Also, angle BDC is 90 degrees. AD is given as 1, and the ratio BD/CD is 3/2. We need to find AB + AC expressed in the form a√b/c and then find a + b + c.\\n\\nLet me try to visualize this. Triangle ABC, with A at the top, angle A acute. Point D is outside the triangle, on the angle bisector of A. So if I imagine angle bisector from A, and D is somewhere along that bisector. Also, angle BDC is 90 degrees, so D lies somewhere such that when connected to B and C, triangle BDC is right-angled at D. Also, BD/CD is 3/2. And AD is 1. We need to find AB + AC.\\n\\nHmm. Let me try to draw a rough sketch mentally. Maybe coordinate geometry can help here? Or maybe using the angle bisector theorem, or trigonometric identities?\\n\\nGiven that AD = 1 and angle BAD = angle DAC, so AD is the angle bisector. So maybe we can use the angle bisector theorem? But D is outside the triangle. Hmm. The angle bisector theorem usually applies when the bisector intersects the opposite side, but here D is outside. So maybe we need to adjust the theorem for external points?\\n\\nAlternatively, maybe using coordinates. Let me try coordinates. Let me place point A at the origin? Or maybe at some convenient position.\\n\\nAlternatively, since we have some trigonometric information about angle A. Since sin A = 4/5 and angle A is acute, then cos A is 3/5, because sin²A + cos²A = 1. So cos A = 3/5. That might come in handy.\\n\\nAlso, since AD is the angle bisector, and AD = 1, perhaps we can use the angle bisector length formula? Wait, but D is outside the triangle. The angle bisector formula is usually for internal bisectors. Maybe I need to adjust for external?\\n\\nAlternatively, maybe use coordinates. Let me try that.\\n\\nLet me place point A at the origin (0,0). Let me assume that angle A is between two sides AB and AC. Let me try to assign coordinates to points B and C such that angle A has sine 4/5. Since angle A is between AB and AC, maybe I can assign coordinates to B and C such that AB and AC make an angle whose sine is 4/5. Alternatively, maybe set coordinates based on vectors?\\n\\nAlternatively, maybe use the Law of Sines or Law of Cosines.\\n\\nAlternatively, since D is on the angle bisector of angle A, and AD = 1. Also, BD/CD = 3/2, and angle BDC = 90 degrees.\\n\\nLet me think about triangle BDC. It is right-angled at D. So BD/CD = 3/2, so BD = 3k, CD = 2k for some k. Then by Pythagoras, BD² + CD² = BC². So (3k)^2 + (2k)^2 = BC² => 9k² + 4k² = 13k² = BC², so BC = k√13. But I don't know if that helps directly. But maybe we can relate BC to AB and AC?\\n\\nAlternatively, since D is on the angle bisector of angle A, and AD = 1, maybe we can use coordinates.\\n\\nLet me try coordinates again. Let me place point A at (0,0). Let me let the angle bisector AD be along the x-axis, since AD is the angle bisector. Wait, but angle BAD equals angle DAC. So if I take AD as x-axis, then AB and AC would make angles of α/2 each, where α is angle A. But angle A is given with sin α = 4/5. So angle A is acute. Let me try to set coordinates accordingly.\\n\\nLet me suppose that AD is along the positive x-axis. Then point A is at (0,0), and D is at (d, 0). Wait, but AD = 1. So point D is at (1, 0). Wait, but D is outside triangle ABC. Hmm. So if AD is the angle bisector, and D is outside, then maybe triangle ABC is such that the angle bisector of A meets the extension of BC? Wait, but the angle bisector theorem says that if the bisector meets BC at some point, but here D is outside. Maybe BD/CD = 3/2? But D is outside, so the ratio BD/CD is 3/2. So perhaps D is located such that BD/CD = 3/2, meaning that D is on the extension of BC beyond C or beyond B?\\n\\nWait, the problem says D is outside triangle ABC. Let me think: if D is on the angle bisector of angle A, then if the triangle is such that the angle bisector goes outside? Wait, angle bisector from A always goes inside the triangle if the triangle is acute. But since angle A is acute, and D is outside, then D must be on the extension of the angle bisector beyond A? Or beyond some other point?\\n\\nWait, if angle bisector of angle A is AD, and D is outside the triangle. So if we have triangle ABC with angle A, then the angle bisector of angle A would typically go towards the opposite side BC. But if D is outside, then maybe it's on the extension of the angle bisector beyond A? Or beyond some other point?\\n\\nAlternatively, maybe D is on the other side of the angle bisector? Maybe not. Let me try to think with coordinates.\\n\\nLet me suppose that AD is the angle bisector, and D is outside the triangle. Let me suppose that AD is an external bisector? Wait, but the problem says that angle BAD = angle DAC, so D is on the internal angle bisector. If D is outside, then maybe the internal angle bisector extended beyond A?\\n\\nBut then BD and CD would be lines from B and C to D which is outside. Hmm. Maybe that is possible.\\n\\nAlternatively, perhaps D is located such that when you extend the angle bisector of angle A beyond A to a point D outside the triangle. Then BD and CD would form the right angle at D.\\n\\nSo let me try that approach. Let me suppose that D is on the extension of the angle bisector of angle A beyond A, so that AD = 1. So AD is 1, from A to D, with D outside the triangle.\\n\\nWait, but angle BAD = angle DAC. If D is on the extension of the angle bisector beyond A, then angle BAD and angle DAC would be supplementary? Wait, no. Wait, if D is on the angle bisector, then angle BAD = angle DAC. But if D is on the angle bisector extended beyond A, then angle BAD and angle DAC would still be equal? Wait, maybe not. Wait, angle BAD is the angle between BA and DA, and angle DAC is the angle between DA and CA. If D is on the angle bisector, then those two angles should be equal. If D is on the angle bisector extended beyond A, then DA is still the bisector. So angle BAD and angle DAC should still be equal. So D is on the angle bisector of angle A, extended beyond A.\\n\\nBut then triangle BDC is right-angled at D. So point D is such that when connected to B and C, angle BDC is 90 degrees.\\n\\nAlternatively, maybe D is on the other side? Wait, but if D is on the angle bisector of angle A, and angle BAD = angle DAC, then if D is not on the extension beyond A, but on the other side? Wait, but that would be inside the triangle. Since angle A is acute, the angle bisector is inside. But the problem says D is outside. So D must be on the extension of the angle bisector beyond A.\\n\\nOkay, so let me assign coordinates accordingly.\\n\\nLet me set coordinate system with point A at (0, 0). Let me take the angle bisector AD along the positive x-axis. Then D is at (1, 0) since AD = 1. The angle bisector of angle A is the x-axis. Then points B and C lie such that AB and AC make angles of α/2 with the x-axis, where α is angle A.\\n\\nBut since AD is the angle bisector, angle between AB and AD is α/2, and same with AC. Also, we know that sin α = 4/5, so α is arcsin(4/5). Therefore, cos α = 3/5.\\n\\nSo maybe I can parametrize points B and C. Let me assume that AB = c, AC = b, and BC = a (using standard notation, but I need to check if that conflicts). However, maybe it's better not to use standard notation because we need to find AB + AC.\\n\\nAlternatively, since we have coordinates, maybe assign coordinates to B and C.\\n\\nLet me let AB make an angle of α/2 above the x-axis, and AC make an angle of α/2 below the x-axis? Wait, no, since angle BAD = angle DAC, so if AD is the x-axis, then AB and AC are symmetric with respect to AD. Since angle A is between AB and AC, and AD is the bisector. Therefore, if AD is the x-axis, then AB can be in the upper half-plane and AC in the lower half-plane, symmetric with respect to the x-axis. That might make sense. Therefore, coordinates of B and C can be parametrized as follows.\\n\\nLet me suppose that point B is at some coordinate (x1, y1) and point C is at (x2, y2), such that angle between AB and AD is α/2, and angle between AC and AD is α/2, and AB and AC are symmetric with respect to AD (the x-axis). Therefore, coordinates of B can be written in terms of AB's length and angle α/2, and coordinates of C can be reflections over x-axis.\\n\\nLet me denote AB = c, AC = b. Then coordinates of B would be (c cos(α/2), c sin(α/2)), and coordinates of C would be (b cos(α/2), -b sin(α/2)). Wait, because if angle between AB and AD is α/2, then the coordinates of B would be AB length times cos(α/2) and sin(α/2). Similarly for C, but mirrored over x-axis.\\n\\nBut AD is along the x-axis, from (0,0) to (1,0). But if D is outside the triangle, then maybe the triangle is such that points B and C are on either side of the x-axis, with AD being the angle bisector.\\n\\nBut since angle A is acute, and D is outside, meaning that D is beyond A? Wait, if D is on the angle bisector, and AD is length 1. If D is beyond A, then coordinates of D would be at (-1, 0), but the problem says AD = 1. Wait, but AD is the segment from A to D. If D is on the extension of the angle bisector beyond A, then AD is from A to D, so if A is at (0,0), then D is at (-1, 0). But the problem says that D is outside the triangle. So if the triangle is on one side of the x-axis, then D is on the other side? Not sure. Wait, but if I have coordinates for B and C as (c cos(α/2), c sin(α/2)) and (b cos(α/2), -b sin(α/2)), then the triangle ABC is sitting above and below the x-axis. Then point D at (-1, 0) is on the x-axis, outside the triangle. That seems possible.\\n\\nBut we also have the condition that angle BDC is 90 degrees. So points B, D, C with D at (-1, 0), and angle at D is 90 degrees. Therefore, BD is perpendicular to CD.\\n\\nAlternatively, coordinates of D is (-1, 0). Then coordinates of B is (c cos(α/2), c sin(α/2)), coordinates of C is (b cos(α/2), -b sin(α/2)).\\n\\nSo BD vector is from D(-1, 0) to B(c cos(α/2), c sin(α/2)), so BD vector is (c cos(α/2) + 1, c sin(α/2) - 0) = (c cos(α/2) + 1, c sin(α/2)).\\n\\nSimilarly, CD vector is from D(-1, 0) to C(b cos(α/2), -b sin(α/2)), so CD vector is (b cos(α/2) + 1, -b sin(α/2) - 0) = (b cos(α/2) + 1, -b sin(α/2)).\\n\\nSince angle BDC is 90 degrees, vectors BD and CD are perpendicular, so their dot product is zero:\\n\\n[BD • CD] = 0.\\n\\nSo compute:\\n\\n(c cos(α/2) + 1)(b cos(α/2) + 1) + [c sin(α/2)][-b sin(α/2)] = 0.\\n\\nLet me compute this:\\n\\nFirst term: (c cos(α/2) + 1)(b cos(α/2) + 1) = c b cos²(α/2) + c cos(α/2) + b cos(α/2) + 1\\n\\nSecond term: -c b sin²(α/2)\\n\\nTherefore, total is:\\n\\nc b cos²(α/2) + c cos(α/2) + b cos(α/2) + 1 - c b sin²(α/2) = 0.\\n\\nCombine terms:\\n\\nc b [cos²(α/2) - sin²(α/2)] + [c cos(α/2) + b cos(α/2)] + 1 = 0.\\n\\nNote that cos²x - sin²x = cos(2x), so:\\n\\nc b cos(α) + (c + b) cos(α/2) + 1 = 0.\\n\\nBecause cos(α) = cos(2*(α/2)) = 2cos²(α/2) - 1, but here it's cos² - sin² = cos(2x). So cos(α) = cos(2*(α/2)) = cos(α). So that term is c b cos α + (c + b) cos(α/2) + 1 = 0.\\n\\nBut we know that cos α = 3/5. Therefore:\\n\\nc b*(3/5) + (c + b) cos(α/2) + 1 = 0.\\n\\nSo that's one equation. Now, we need more equations. Also, we know that BD / CD = 3/2. Let's compute BD and CD lengths.\\n\\nBD is the distance from D(-1, 0) to B(c cos(α/2), c sin(α/2)):\\n\\nBD² = [c cos(α/2) + 1]^2 + [c sin(α/2)]^2\\n\\nSimilarly for CD²:\\n\\nCD² = [b cos(α/2) + 1]^2 + [ - b sin(α/2) ]^2 = [b cos(α/2) + 1]^2 + [b sin(α/2)]^2\\n\\nTherefore, BD² = (c cos(α/2) + 1)^2 + (c sin(α/2))^2 = c² cos²(α/2) + 2c cos(α/2) + 1 + c² sin²(α/2) = c² [cos²(α/2) + sin²(α/2)] + 2c cos(α/2) + 1 = c² + 2c cos(α/2) + 1.\\n\\nSimilarly, CD² = b² + 2b cos(α/2) + 1.\\n\\nTherefore, BD / CD = 3/2 implies BD² / CD² = 9/4.\\n\\nSo:\\n\\n[c² + 2c cos(α/2) + 1] / [b² + 2b cos(α/2) + 1] = 9/4.\\n\\nSo that's another equation.\\n\\nSo we have two equations:\\n\\n1) (3/5) c b + (c + b) cos(α/2) + 1 = 0.\\n\\n2) [c² + 2c cos(α/2) + 1] / [b² + 2b cos(α/2) + 1] = 9/4.\\n\\nAlso, we need to find cos(α/2). Since we know cos α = 3/5, we can compute cos(α/2).\\n\\nRecall that cos α = 2 cos²(α/2) - 1. Therefore:\\n\\n3/5 = 2 cos²(α/2) - 1 => 2 cos²(α/2) = 3/5 + 1 = 8/5 => cos²(α/2) = 4/5 => cos(α/2) = 2/√5 or -2/√5. But since α is acute, angle α is between 0 and 90 degrees, so α/2 is between 0 and 45 degrees, so cos(α/2) is positive. Therefore, cos(α/2) = 2/√5. Therefore, cos(α/2) = 2√5 / 5. Let me rationalize that: 2/√5 = 2√5 / 5.\\n\\nTherefore, cos(α/2) = 2√5 / 5. Let me note that value.\\n\\nSo now, substituting cos(α/2) = 2√5 / 5 into equations 1 and 2.\\n\\nEquation 1:\\n\\n(3/5) c b + (c + b)(2√5 / 5) + 1 = 0.\\n\\nMultiply both sides by 5:\\n\\n3 c b + 2√5 (c + b) + 5 = 0.\\n\\nEquation 1: 3cb + 2√5 (c + b) + 5 = 0. Equation (1)\\n\\nEquation 2:\\n\\n[c² + 2c*(2√5 / 5) + 1] / [b² + 2b*(2√5 / 5) + 1] = 9/4.\\n\\nSimplify numerator and denominator:\\n\\nNumerator: c² + (4√5 / 5)c + 1\\n\\nDenominator: b² + (4√5 / 5)b + 1\\n\\nSo:\\n\\n[ c² + (4√5 / 5)c + 1 ] / [ b² + (4√5 / 5)b + 1 ] = 9/4. Equation (2)\\n\\nSo now, we have two equations with variables c and b. We need to solve for c and b. Then AB + AC = c + b, which is what we need to find.\\n\\nSo let me denote c and b as variables. Let me try to denote variables to make equations easier.\\n\\nLet me set variables:\\n\\nLet me denote x = c, y = b.\\n\\nThen equation (1): 3xy + 2√5 (x + y) + 5 = 0.\\n\\nEquation (2): [x² + (4√5 / 5)x + 1] / [y² + (4√5 / 5)y + 1] = 9/4.\\n\\nSo we need to solve for x and y.\\n\\nThis seems complicated, but maybe we can find a relation between x and y. Let me think.\\n\\nAlternatively, maybe assume that c and b are related in some way? Let me think. Maybe from the angle bisector theorem? Wait, the angle bisector theorem states that AB/AC = BD/DC if the angle bisector meets BC at some point. But here D is outside, so maybe the external angle bisector theorem?\\n\\nAlternatively, since D is on the angle bisector, and BD/CD = 3/2. Maybe there's a relation here? But not sure.\\n\\nAlternatively, note that in equation (1), 3xy is a term, and in equation (2), there is a ratio between x² and y² terms. Let me think of equation (2):\\n\\nLet me denote A = 4√5 / 5.\\n\\nThen equation (2):\\n\\n(x² + A x + 1) / (y² + A y + 1) = 9/4 => 4(x² + A x + 1) = 9(y² + A y + 1).\\n\\nTherefore:\\n\\n4x² + 4A x + 4 = 9y² + 9A y + 9.\\n\\nRearranged:\\n\\n4x² - 9y² + 4A x - 9A y + 4 - 9 = 0 =>\\n\\n4x² - 9y² + 4A(x - y) - 5 = 0.\\n\\nHmm. Not sure if that helps.\\n\\nAlternatively, maybe express equation (2) as 4(x² + A x + 1) = 9(y² + A y + 1). Let me note that.\\n\\nLet me write equation (1):\\n\\n3xy + 2√5(x + y) + 5 = 0. Let me note that A = 4√5 / 5. Therefore, 2√5 = (5/2) * A? Wait, 2√5 = 2√5, and A is 4√5 /5, so 2√5 = (2√5)*(5/4) / (A / (4√5 /5))? Maybe not helpful. Alternatively, maybe express 2√5 in terms of A.\\n\\nLet me note that A = 4√5 / 5, so √5 = (5A)/4. Therefore, 2√5 = 2*(5A)/4 = (5A)/2.\\n\\nSo equation (1):\\n\\n3xy + (5A)/2 (x + y) + 5 = 0.\\n\\nBut I don't know if that helps. Maybe not.\\n\\nAlternatively, maybe assume that c and b are proportional? Let me think. Suppose that c = k b. Then maybe we can write equations in terms of k.\\n\\nLet me assume that c = k b, where k is some constant. Then, substituting into equation (1):\\n\\n3*(k b)*b + 2√5 (k b + b) + 5 = 0 => 3k b² + 2√5 b(k + 1) + 5 = 0.\\n\\nEquation (2):\\n\\n[ (k b)^2 + (4√5 / 5)(k b) + 1 ] / [ b² + (4√5 / 5)b + 1 ] = 9/4.\\n\\nThis might be complicated, but maybe we can find k?\\n\\nAlternatively, maybe find another relation. Let me think about equation (1):\\n\\n3xy + 2√5(x + y) = -5. Let me call this equation (1).\\n\\nLet me denote S = x + y, P = x y.\\n\\nThen equation (1) becomes 3P + 2√5 S = -5. Equation (1).\\n\\nBut equation (2) is [x² + A x + 1] / [y² + A y + 1] = 9/4, where A = 4√5 /5.\\n\\nAlternatively, maybe express x² + A x + 1 as (x² + A x + (A²)/4) + 1 - (A²)/4 = (x + A/2)^2 + 1 - A²/4. Not sure.\\n\\nAlternatively, maybe write equation (2) as:\\n\\n4(x² + A x + 1) = 9(y² + A y + 1).\\n\\nWhich can be rewritten as:\\n\\n4x² + 4A x + 4 = 9y² + 9A y + 9.\\n\\nWhich is:\\n\\n4x² - 9y² + 4A x - 9A y + 4 - 9 = 0 => 4x² - 9y² + 4A(x - y) - 5 = 0.\\n\\nBut from equation (1), we have 3xy + 2√5 S = -5, where S = x + y.\\n\\nAlternatively, perhaps think of 4x² - 9y² as (2x)^2 - (3y)^2 = (2x - 3y)(2x + 3y). Maybe?\\n\\nSo:\\n\\n(2x - 3y)(2x + 3y) + 4A(x - y) - 5 = 0.\\n\\nNot sure. Alternatively, maybe assume that 2x - 3y is proportional to something?\\n\\nAlternatively, maybe consider that if we have expressions involving x and y, and we need to find x + y.\\n\\nAlternatively, think of equation (1): 3xy + 2√5(x + y) = -5.\\n\\nLet me note that equation (2) can be written as 4x² + 4A x + 4 = 9y² + 9A y + 9 => 4x² - 9y² + 4A x - 9A y = 5.\\n\\nAlternatively, factor 4x² - 9y² as (2x - 3y)(2x + 3y). Then:\\n\\n(2x - 3y)(2x + 3y) + 4A(x - y) = 5.\\n\\nBut I don't know if that helps. Maybe not.\\n\\nAlternatively, can we find x and y?\\n\\nAlternatively, maybe set variables u = x + y and v = x - y. But not sure.\\n\\nAlternatively, notice that equations (1) and (2) are two equations with two variables, so maybe try solving them.\\n\\nLet me first handle equation (2):\\n\\nLet me write equation (2) as 4x² + (4A)x + 4 = 9y² + (9A)y + 9.\\n\\nBut with A = 4√5 / 5, which is approximately... but exact expressions are better.\\n\\nAlternatively, let me compute 4A:\\n\\n4A = 4*(4√5 /5) = 16√5 /5.\\n\\nSimilarly, 9A = 9*(4√5 /5) = 36√5 /5.\\n\\nTherefore, equation (2):\\n\\n4x² + (16√5 /5)x + 4 = 9y² + (36√5 /5)y + 9.\\n\\nMultiply both sides by 5 to eliminate denominators:\\n\\n20x² + 16√5 x + 20 = 45y² + 36√5 y + 45.\\n\\nRearranged:\\n\\n20x² - 45y² + 16√5 x - 36√5 y + 20 - 45 = 0 =>\\n\\n20x² - 45y² + 16√5 x - 36√5 y - 25 = 0.\\n\\nHmm, complicated.\\n\\nAlternatively, maybe express y from equation (1) in terms of x? Let's try.\\n\\nFrom equation (1):\\n\\n3xy + 2√5(x + y) = -5.\\n\\nLet me write this as:\\n\\n3xy + 2√5 x + 2√5 y = -5.\\n\\nLet me collect terms with y:\\n\\ny(3x + 2√5) + 2√5 x = -5.\\n\\nTherefore,\\n\\ny(3x + 2√5) = -5 - 2√5 x.\\n\\nTherefore,\\n\\ny = [ -5 - 2√5 x ] / (3x + 2√5).\\n\\nSo we have y in terms of x. Then we can substitute this into equation (2). That might be messy, but perhaps manageable.\\n\\nLet me note that equation (2) is:\\n\\n[ x² + (4√5 /5)x + 1 ] / [ y² + (4√5 /5)y + 1 ] = 9/4.\\n\\nLet me call this equation (2). Let me denote:\\n\\nLet me denote N = x² + (4√5 /5)x + 1,\\n\\nD = y² + (4√5 /5)y + 1,\\n\\nthen N/D = 9/4 => 4N = 9D.\\n\\nSo, 4N - 9D = 0.\\n\\nSo substituting N and D with expressions in terms of x.\\n\\nBut since y is expressed in terms of x, this will be complex, but let's try.\\n\\nFirst, compute N:\\n\\nN = x² + (4√5 /5)x + 1.\\n\\nCompute D:\\n\\nD = y² + (4√5 /5)y + 1.\\n\\nBut y is [ -5 - 2√5 x ] / (3x + 2√5 ). Let me denote that as y = (-5 - 2√5 x) / (3x + 2√5).\\n\\nLet me compute D:\\n\\nD = y² + (4√5 /5)y + 1.\\n\\nLet me compute this:\\n\\nLet me first compute y:\\n\\nLet me denote numerator: -5 - 2√5 x,\\n\\ndenominator: 3x + 2√5.\\n\\nLet me call denominator as D1 = 3x + 2√5.\\n\\nThen y = (-5 - 2√5 x)/D1.\\n\\nTherefore, y² = [ ( -5 - 2√5 x )² ] / D1²,\\n\\nand (4√5 /5)y = (4√5 /5) * (-5 - 2√5 x)/D1.\\n\\nSo D = [ ( -5 - 2√5 x )² ] / D1² + (4√5 /5) * (-5 - 2√5 x)/D1 + 1.\\n\\nThis seems very complicated, but let's compute step by step.\\n\\nFirst, compute (-5 - 2√5 x)^2:\\n\\n= 25 + 20√5 x + (2√5 x)^2\\n\\n= 25 + 20√5 x + 4*5 x²\\n\\n= 25 + 20√5 x + 20x².\\n\\nTherefore, y² = [20x² + 20√5 x + 25]/D1².\\n\\nNext, compute (4√5 /5)y:\\n\\n(4√5 /5) * (-5 - 2√5 x)/D1.\\n\\nLet me compute numerator:\\n\\n(4√5 /5) * (-5 - 2√5 x) = (4√5 /5)*(-5) + (4√5 /5)*(-2√5 x)\\n\\n= -4√5 + (-8*5 x)/5\\n\\n= -4√5 - 8x.\\n\\nTherefore, (4√5 /5)y = (-4√5 - 8x)/D1.\\n\\nTherefore, D is:\\n\\n[20x² + 20√5 x + 25]/D1² + [(-4√5 - 8x)/D1] + 1.\\n\\nSo D = [20x² + 20√5 x + 25]/D1² + [(-4√5 - 8x)/D1] + 1.\\n\\nNow, compute 4N - 9D = 0, which is 4N = 9D.\\n\\nBut N = x² + (4√5 /5)x + 1.\\n\\nCompute 4N:\\n\\n4x² + (16√5 /5)x + 4.\\n\\nTherefore, equation 4N = 9D becomes:\\n\\n4x² + (16√5 /5)x + 4 = 9D,\\n\\nwhere D is the expression above. Therefore:\\n\\n4x² + (16√5 /5)x + 4 = 9*[ (20x² + 20√5 x + 25)/D1² + (-4√5 - 8x)/D1 + 1 ].\\n\\nThis seems extremely complicated, but perhaps we can plug in D1 = 3x + 2√5 and simplify term by term. This might take some time, but let's try to do it step by step.\\n\\nFirst, compute 9D:\\n\\n9D = 9*[ (20x² + 20√5 x + 25)/D1² + (-4√5 - 8x)/D1 + 1 ]\\n\\n= 9*(20x² + 20√5 x + 25)/D1² + 9*(-4√5 - 8x)/D1 + 9*1.\\n\\nLet me note that D1 = 3x + 2√5, so D1² = (3x + 2√5)^2 = 9x² + 12√5 x + 20.\\n\\nTherefore, we can write:\\n\\n9D = 9*(20x² + 20√5 x + 25)/(9x² + 12√5 x + 20) + 9*(-4√5 - 8x)/(3x + 2√5) + 9.\\n\\nTherefore, our equation is:\\n\\n4x² + (16√5 /5)x + 4 = [9*(20x² + 20√5 x + 25)/(9x² + 12√5 x + 20)] + [9*(-4√5 - 8x)/(3x + 2√5)] + 9.\\n\\nThis is very complex, but maybe simplify term by term.\\n\\nLet me first compute each term:\\n\\nFirst term: 9*(20x² + 20√5 x + 25)/(9x² + 12√5 x + 20).\\n\\nLet me note that denominator is 9x² + 12√5 x + 20, which is the square of D1: (3x + 2√5)^2 = 9x² + 12√5 x + 20.\\n\\nNumerator: 20x² + 20√5 x + 25.\\n\\nLet me check if numerator is related to denominator. Maybe not directly.\\n\\nAlternatively, perform polynomial division or see if there's a relation.\\n\\nAlternatively, note that 20x² + 20√5 x + 25 = 5*(4x² + 4√5 x + 5). Hmm, not sure.\\n\\nAlternatively, let me try to write numerator as something times denominator + something.\\n\\nAlternatively, let me compute the first term:\\n\\nLet me call the first term as T1 = 9*(20x² + 20√5 x + 25)/(9x² + 12√5 x + 20).\\n\\nSimilarly, T2 = 9*(-4√5 - 8x)/(3x + 2√5), and T3 = 9.\\n\\nSo equation: 4x² + (16√5 /5)x + 4 = T1 + T2 + T3.\\n\\nThis seems too complicated. Maybe instead of going this way, maybe assume specific values? Or maybe there's a better approach?\\n\\nAlternatively, maybe go back to equations (1) and (2) with variables x and y. Let me think again. Maybe there is a relation from equation (1) that can be used?\\n\\nEquation (1): 3xy + 2√5(x + y) = -5.\\n\\nLet me think of this as 3xy = -5 - 2√5(x + y). Maybe use this in equation (2). Let me recall that equation (2) after multiplying by 5 was:\\n\\n20x² - 45y² + 16√5 x - 36√5 y - 25 = 0.\\n\\nAlternatively, let me write equation (2) as:\\n\\n20x² - 45y² + 16√5 x - 36√5 y = 25.\\n\\nBut from equation (1), we have 3xy = -5 - 2√5(x + y). Maybe square both sides of equation (1) or find another relation?\\n\\nAlternatively, maybe express x in terms of y or vice versa.\\n\\nAlternatively, think of equation (1) as:\\n\\nLet me write equation (1): 3xy + 2√5 x + 2√5 y = -5.\\n\\nLet me factor:\\n\\nx(3y + 2√5) + 2√5 y = -5.\\n\\nBut maybe this is not helpful.\\n\\nAlternatively, note that if we have two variables x and y, and two equations, we can attempt substitution. However, the equations seem too complex for manual solving. Maybe there's a better way.\\n\\nWait, maybe we can use the first equation to express something, and plug it into the second equation.\\n\\nAlternatively, maybe make substitution variables.\\n\\nLet me think. Let me denote S = x + y and P = xy.\\n\\nThen, equation (1): 3P + 2√5 S = -5.\\n\\nBut also, in equation (2), which is:\\n\\n[ x² + (4√5 /5)x + 1 ] / [ y² + (4√5 /5)y + 1 ] = 9/4.\\n\\nBut x² + (4√5 /5)x + 1 can be expressed in terms of S and P?\\n\\nNote that x² = (x + y)^2 - 2xy - y² = S² - 2P - y². Not sure.\\n\\nAlternatively, we can write x² + (4√5 /5)x + 1 = x² + (4√5 /5)x + 1. Similarly for y.\\n\\nAlternatively, express x² + (4√5 /5)x + 1 = x² + (4√5 /5)x + 1.\\n\\nBut if we consider that x² + (4√5 /5)x + 1 is part of equation (2), and we have S and P, maybe express in terms of S and P?\\n\\nAlternatively, maybe not. It's complicated.\\n\\nAlternatively, maybe consider that equation (2) can be manipulated as follows:\\n\\nLet me write 4(x² + (4√5 /5)x + 1) = 9(y² + (4√5 /5)y + 1)\\n\\nExpanding both sides:\\n\\n4x² + (16√5 /5)x + 4 = 9y² + (36√5 /5)y + 9.\\n\\nBring all terms to left side:\\n\\n4x² - 9y² + (16√5 /5)x - (36√5 /5)y + 4 - 9 = 0 =>\\n\\n4x² - 9y² + (16√5 /5)x - (36√5 /5)y - 5 = 0.\\n\\nBut from equation (1), we have 3xy + 2√5(x + y) = -5 => 3xy = -5 - 2√5(x + y).\\n\\nMaybe express 4x² - 9y² in terms of something? For example, note that 4x² - 9y² = (2x - 3y)(2x + 3y). But how does that help?\\n\\nAlternatively, maybe assume that 2x + 3y = k( some expression )?\\n\\nAlternatively, think of 4x² - 9y² + ... = 0 as:\\n\\nMaybe express in terms of (2x - 3y):\\n\\n(2x - 3y)(2x + 3y) + (16√5 /5)x - (36√5 /5)y = 5.\\n\\nLet me see, from above:\\n\\n4x² - 9y² + (16√5 /5)x - (36√5 /5)y = 5.\\n\\nWhich is (2x - 3y)(2x + 3y) + (16√5 /5)x - (36√5 /5)y = 5.\\n\\nLet me factor the terms involving x and y:\\n\\nNote that (16√5 /5)x - (36√5 /5)y = (16√5 /5)x - (36√5 /5)y = (16√5 /5)x - (36√5 /5)y = (16√5 /5)x - (36√5 /5)y.\\n\\nLet me factor out 4√5 /5:\\n\\n(4√5 /5)(4x - 9y).\\n\\nSo, the equation becomes:\\n\\n(2x - 3y)(2x + 3y) + (4√5 /5)(4x - 9y) = 5.\\n\\nHmm. Interesting. So:\\n\\n(2x - 3y)(2x + 3y) + (4√5 /5)(4x - 9y) = 5.\\n\\nLet me denote u = 2x - 3y and v = 2x + 3y. But not sure. Let me see:\\n\\nAlternatively, notice that 4x - 9y = ?\\n\\nWait, if I have u = 2x - 3y, then 4x - 9y = 2*(2x) - 9y = 2*(something). Maybe not helpful.\\n\\nAlternatively, let me write 4x - 9y = 2*(2x - 3y) - 3y.\\n\\nWait, 2*(2x - 3y) = 4x - 6y, so 4x - 9y = 4x - 6y - 3y = 2*(2x - 3y) - 3y.\\n\\nBut not sure.\\n\\nAlternatively, let me consider that 2x + 3y and 4x - 9y are related. Maybe not.\\n\\nAlternatively, maybe assume that 2x + 3y is proportional to something?\\n\\nAlternatively, notice that if we have u = 2x - 3y, then maybe find relations.\\n\\nBut this is getting too abstract. Maybe take a different approach.\\n\\nLet me think back to the problem. We might need to use other relations. Let me recall that in triangle ABC, we know angle A, and we need AB + AC. Also, we have AD = 1, which is the angle bisector. Maybe use the formula for the length of the angle bisector?\\n\\nWait, but AD is the length of the angle bisector from A to point D, which is outside the triangle. The standard angle bisector length formula is for when the bisector meets the opposite side. But since D is outside, maybe we need to adjust the formula.\\n\\nAlternatively, use coordinates again. We had earlier expressions for y in terms of x. Let me try to substitute y = [ -5 - 2√5 x ] / (3x + 2√5) into equation (2). \\n\\nBut this seems very tedious, but maybe doable.\\n\\nLet me denote y = [ -5 - 2√5 x ] / (3x + 2√5). Let me call this expression as y.\\n\\nLet me note that D = y² + (4√5 /5)y + 1, and we need 4N = 9D where N = x² + (4√5 /5)x + 1.\\n\\nThis seems very complicated, but let me proceed step by step.\\n\\nLet me first compute 4N:\\n\\n4N = 4x² + (16√5 /5)x + 4.\\n\\nLet me compute 9D:\\n\\n9D = 9[y² + (4√5 /5)y + 1].\\n\\nWe already computed y² and (4√5 /5)y, so substitute:\\n\\n9D = 9*[ (20x² + 20√5 x + 25)/D1² + (-4√5 - 8x)/D1 + 1 ], where D1 = 3x + 2√5.\\n\\nSo, 9D = [9(20x² + 20√5 x + 25)] / D1² + 9*(-4√5 - 8x)/D1 + 9.\\n\\nLet me compute each part.\\n\\nFirst, compute 9(20x² + 20√5 x + 25) = 180x² + 180√5 x + 225.\\n\\nSecond, compute 9*(-4√5 - 8x) = -36√5 - 72x.\\n\\nThird, add 9.\\n\\nSo:\\n\\n9D = [180x² + 180√5 x + 225]/D1² + [-36√5 - 72x]/D1 + 9.\\n\\nNow, set 4N = 9D:\\n\\n4x² + (16√5 /5)x + 4 = [180x² + 180√5 x + 225]/D1² + [-36√5 - 72x]/D1 + 9.\\n\\nNow, let me multiply both sides by D1² to eliminate denominators:\\n\\nD1² [4x² + (16√5 /5)x + 4] = 180x² + 180√5 x + 225\",\n",
       " 'ground_truth': '34',\n",
       " 'score': {'score': 0.0,\n",
       "  'soft_format': 0.0,\n",
       "  'hard_format': 0.0,\n",
       "  'length_reward': 0},\n",
       " 'difficulty': 0.0,\n",
       " 'reason': \"score: {'score': 0.0, 'soft_format': 0.0, 'hard_format': 0.0}\",\n",
       " 'final_reward': 0.0}"
      ]
     },
     "execution_count": 32,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[0][0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "id": "a1cdaca6",
   "metadata": {},
   "outputs": [],
   "source": [
    "reward_original = []\n",
    "reward_compressed = []\n",
    "for d in data:\n",
    "    temp_original = []\n",
    "    temp_compressed = []\n",
    "    for line in d:\n",
    "        if '<think><think>' in line['response']:\n",
    "            temp_compressed.append(line['final_reward'])\n",
    "        else:\n",
    "            temp_original.append(line['final_reward'])\n",
    "    if len(temp_original) > 0:\n",
    "        reward_original.append(sum(temp_original) / len(temp_original))\n",
    "    # else:\n",
    "    #     reward_original.append(0)\n",
    "    if len(temp_compressed) > 0:\n",
    "        reward_compressed.append(sum(temp_compressed) / len(temp_compressed))\n",
    "    # else:\n",
    "    #     reward_compressed.append(0)\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "id": "dcbd8905",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot both the original and compressed reward\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "reward_original = np.array(reward_original)\n",
    "reward_compressed = np.array(reward_compressed)\n",
    "## smooth the plot, window size 10\n",
    "reward_original = np.convolve(reward_original, np.ones(10)/10, mode='valid')\n",
    "reward_compressed = np.convolve(reward_compressed, np.ones(10)/10, mode='valid')\n",
    "plt.plot(reward_original, label='original')\n",
    "plt.plot(reward_compressed, label='compressed')\n",
    "plt.legend()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5217088d",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "INFO 08-22 16:29:29 [importing.py:53] Triton module has been replaced with a placeholder.\n",
      "INFO 08-22 16:29:29 [__init__.py:239] Automatically detected platform cuda.\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "\n",
    "os.environ['HF_HOME'] = 'NONE.cache/huggingface'\n",
    "os.environ['CUDA_VISIBLE_DEVICES'] = '7'\n",
    "from transformers import AutoTokenizer, AutoModelForCausalLM\n",
    "from vllm import LLM\n",
    "\n",
    "tokenizer = AutoTokenizer.from_pretrained(\"Qwen/Qwen3-4B\")\n",
    "# model = LLM(model=\"Qwen/Qwen3-4B\", gpu_memory_utilization=0.95, tensor_parallel_size=1, task=\"embed\")\n",
    "\n",
    "\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "3f932fa0",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Processed prompts: 100%|██████████| 1/1 [00:00<00:00,  2.65it/s, est. speed input: 0.00 toks/s, output: 0.00 toks/s]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "[PoolingRequestOutput(request_id='0', outputs=PoolingOutput(data=tensor([ 0.0008,  0.0162, -0.0035,  ..., -0.0022, -0.0210,  0.0208])), prompt_token_ids=[9707, 11, 1879, 0, 220, 151668], finished=True)]"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "model.encode(\"Hello, world! </think>\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "739a2ddb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import json\n",
    "data = []\n",
    "with open('NONEcode/verl-fork/verl/scripts/eval/verlCheckpoint/mathbaseRun/qwen4b_10k_base_model/rollout/val_0.jsonl', 'r') as f:\n",
    "    for line in f:\n",
    "        data.append(json.loads(line))\n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ead5a0ce",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "math-aime 0.636\n",
      "gpqa 0.42\n",
      "math-amc 0.892\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "accuracy_by_source = {}\n",
    "for line in data:\n",
    "    if line['data_source'] not in accuracy_by_source:\n",
    "        accuracy_by_source[line['data_source']] = []\n",
    "    accuracy_by_source[line['data_source']].append(line['final_reward'])\n",
    "    \n",
    "for source in accuracy_by_source:\n",
    "    mean_accuracy = np.mean(accuracy_by_source[source])\n",
    "    print(source, mean_accuracy)\n",
    "    \n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "1e19a2fc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 750/750 [00:11<00:00, 62.88it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "math-aime 16270.376\n",
      "gpqa 10175.228\n",
      "math-amc 10342.512\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "response_length_list = {}\n",
    "from tqdm import tqdm\n",
    "for line in tqdm(data):\n",
    "    if line['data_source'] not in response_length_list:\n",
    "        response_length_list[line['data_source']] = []\n",
    "    response_length_list[line['data_source']].append(len(tokenizer.encode(line['response'])))\n",
    "    \n",
    "for source in response_length_list:\n",
    "    mean_response_length = np.mean(response_length_list[source])\n",
    "    print(source, mean_response_length)\n",
    "    \n",
    "    \n",
    "    \n",
    "            \n",
    "            \n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "id": "7828a9c2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"<think>\\nOkay, so I need to figure out for how many integers n between 1 and 22 inclusive, the denominator k_n of the harmonic series H_n = 1 + 1/2 + 1/3 + ... + 1/n is less than L_n, the least common multiple of 1 through n. \\n\\nFirst, I remember that when you add fractions, the denominator of the sum is the least common multiple of the denominators divided by some factors. But since the harmonic series is being expressed in reduced form, the denominator k_n is L_n divided by some factors that come from the numerator. So, k_n = L_n / d, where d is the greatest common divisor of the numerator and L_n. Therefore, k_n < L_n is equivalent to d > 1. So, the question becomes: for how many n between 1 and 22 is the numerator of H_n (when expressed in lowest terms) not coprime with L_n?\\n\\nAlternatively, since H_n = h_n / k_n = (sum_{i=1}^n 1/i) = (some numerator) / L_n, but reduced. Therefore, k_n = L_n / gcd(numerator, L_n). Therefore, k_n < L_n iff gcd(numerator, L_n) > 1.\\n\\nTherefore, the problem reduces to finding for how many n from 1 to 22, the numerator of H_n is not coprime with L_n.\\n\\nAlternatively, since L_n is the LCM of 1 to n, which is divisible by all numbers from 1 to n. Therefore, the numerator of H_n must be divisible by some prime p ≤ n. Wait, but how does that relate?\\n\\nAlternatively, maybe I need to think about when the harmonic number H_n has a denominator that is not equal to L_n. That is, when the numerator and L_n share a common factor.\\n\\nBut how can I compute this?\\n\\nAlternatively, I recall that for harmonic numbers, the denominator k_n is equal to L_n divided by the product of primes p where p^2 divides L_n. Wait, no, that's not exactly right. Wait, maybe not. Let me think.\\n\\nAlternatively, I remember that for H_n, the denominator k_n is equal to L_n divided by the product of primes p where p divides the numerator. Wait, not sure.\\n\\nAlternatively, maybe I need to look for primes p such that p divides the numerator of H_n. If such a prime p exists, then since L_n is divisible by p, then k_n = L_n / gcd(numerator, L_n) would be less than L_n.\\n\\nTherefore, the question is equivalent to: for how many n between 1 and 22 is there a prime p ≤ n such that p divides the numerator of H_n?\\n\\nAlternatively, since H_n = sum_{i=1}^n 1/i, then the numerator of H_n is equal to sum_{i=1}^n L_n / i, divided by L_n. Therefore, the numerator is sum_{i=1}^n L_n / i. Therefore, the numerator is an integer, and the denominator is L_n. Therefore, the numerator is equal to sum_{i=1}^n L_n / i. Therefore, the numerator is divisible by p if and only if sum_{i=1}^n L_n / i is divisible by p.\\n\\nTherefore, for a prime p ≤ n, if sum_{i=1}^n L_n / i ≡ 0 mod p, then p divides the numerator, hence gcd(numerator, L_n) is at least p, so k_n = L_n / gcd(...) < L_n.\\n\\nTherefore, the problem reduces to: for each n from 1 to 22, check if there exists a prime p ≤ n such that sum_{i=1}^n L_n / i ≡ 0 mod p.\\n\\nAlternatively, since L_n is divisible by p, L_n / i is divisible by p if and only if i is not divisible by p. Wait, no. Wait, L_n is divisible by p, so L_n / i is divisible by p if and only if i is not divisible by p? Wait, no. Let me think.\\n\\nLet me take p as a prime. Then L_n is divisible by p. Let me consider L_n / i. If i is divisible by p, then L_n / i is divisible by p^{k - m}, where k is the exponent of p in L_n and m is the exponent of p in i. But since L_n is divisible by p, and i is between 1 and n, so if i is divisible by p, then L_n / i is divisible by p^{k - m} where m ≥ 1. Therefore, L_n / i is divisible by p^{k - m}.\\n\\nBut if i is not divisible by p, then L_n / i is divisible by p^{k} / i, but since i is not divisible by p, then L_n / i is divisible by p^{k} / something not divisible by p, so L_n / i is divisible by p^{k - 0} = p^k? Wait, no. Wait, L_n is divisible by p^k, where k is the exponent of p in L_n. Then L_n / i is divisible by p^k / i. But since i is not divisible by p, then i is coprime to p, so L_n / i is divisible by p^k. Therefore, L_n / i is divisible by p^k.\\n\\nTherefore, if i is not divisible by p, then L_n / i is divisible by p^k, so sum_{i=1}^n L_n / i is congruent to sum_{i not divisible by p} (multiple of p) + sum_{i divisible by p} (L_n / i). Therefore, modulo p, the sum is congruent to sum_{i divisible by p} (L_n / i) mod p.\\n\\nBut L_n is divisible by p, so L_n / i is divisible by p if i is not divisible by p, but if i is divisible by p, then L_n / i is divisible by p^{k - m} where m is the exponent of p in i.\\n\\nBut since p divides L_n, and i is divisible by p, then L_n / i is divisible by p^{k - m} where m ≥ 1.\\n\\nTherefore, if p divides L_n / i, then L_n / i ≡ 0 mod p. Therefore, the sum over i divisible by p of L_n / i ≡ 0 mod p.\\n\\nTherefore, the entire sum is congruent to 0 mod p. Therefore, the numerator is divisible by p. Therefore, for any prime p ≤ n, the numerator is divisible by p. Therefore, gcd(numerator, L_n) is at least p, so k_n = L_n / gcd(...) < L_n.\\n\\nWait, that can't be. Because for example, when n=1, H_1 = 1/1, so k_1 = 1, L_1 = 1, so k_1 = L_1. Therefore, for n=1, k_n = L_n. Therefore, the above reasoning must be wrong.\\n\\nWait, so where is the mistake?\\n\\nLet me check for n=1. p=1? No, p is prime. So p=2? But n=1, so p=2 is not ≤ n. Therefore, there is no prime p ≤ n. Therefore, the sum is over primes p ≤ n, which is empty. Therefore, the numerator is not divisible by any prime p ≤ n, so gcd(numerator, L_n) = 1, so k_n = L_n.\\n\\nTherefore, for n=1, k_n = L_n.\\n\\nSimilarly, for n=2, primes p ≤ 2: p=2.\\n\\nCheck if sum_{i=1}^2 L_n / i is divisible by 2.\\n\\nL_2 = 2.\\n\\nsum_{i=1}^2 L_n / i = 2/1 + 2/2 = 2 + 1 = 3. 3 mod 2 = 1 ≠ 0. Therefore, numerator is 3, which is not divisible by 2. Therefore, gcd(3, 2) = 1, so k_n = 2 / 1 = 2 = L_n. Therefore, k_n = L_n.\\n\\nTherefore, for n=2, k_n = L_n.\\n\\nWait, but according to the previous reasoning, if p divides the numerator, then k_n < L_n. But here, p=2 does not divide the numerator, so k_n = L_n.\\n\\nTherefore, the previous conclusion that for any prime p ≤ n, the numerator is divisible by p is wrong.\\n\\nTherefore, my mistake was in the reasoning that sum_{i=1}^n L_n / i ≡ 0 mod p. That is not necessarily true.\\n\\nTherefore, need to re-examine.\\n\\nLet me take p as a prime ≤ n.\\n\\nLet me compute sum_{i=1}^n L_n / i mod p.\\n\\nNote that L_n is divisible by p, so L_n = p * m for some integer m.\\n\\nTherefore, L_n / i = p * m / i.\\n\\nTherefore, sum_{i=1}^n L_n / i = p * sum_{i=1}^n m / i.\\n\\nTherefore, modulo p, this is 0 * sum(...) = 0 mod p? Wait, no. Wait, p * sum(...) is congruent to 0 mod p. Therefore, the entire sum is divisible by p. Therefore, the numerator is divisible by p. Therefore, the numerator is divisible by p. Therefore, gcd(numerator, L_n) is at least p, so k_n = L_n / gcd(...) < L_n.\\n\\nBut this contradicts the case n=2, where p=2 divides the numerator?\\n\\nWait, for n=2, the numerator is 3, which is not divisible by 2. Therefore, there is a contradiction here.\\n\\nWait, so where is the mistake?\\n\\nWait, L_n is 2. Then sum_{i=1}^2 L_n / i = 2/1 + 2/2 = 2 + 1 = 3. Therefore, 3 is not divisible by 2. Therefore, the previous reasoning is wrong.\\n\\nWait, but according to the previous step, sum_{i=1}^n L_n / i = p * sum_{i=1}^n m / i. Therefore, this is p * something, so it is divisible by p. Therefore, 3 is divisible by 2? No, 3 is not divisible by 2. Therefore, there is a mistake here.\\n\\nWait, L_n is 2, which is p * m where p=2 and m=1. Therefore, sum_{i=1}^n L_n / i = 2 * sum_{i=1}^n (1 / i). Wait, no. Wait, L_n / i is 2 / i. Therefore, sum_{i=1}^2 2 / i = 2 + 1 = 3. Therefore, 3 is not divisible by 2. Therefore, the previous reasoning is wrong.\\n\\nTherefore, my mistake was in the step where I said that L_n / i = p * m / i. But m is not necessarily an integer. Wait, no, L_n is divisible by p, so m is integer. Therefore, L_n / i = p * m / i. Therefore, sum_{i=1}^n L_n / i = p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is divisible by 2? No. Therefore, contradiction.\\n\\nTherefore, my mistake is that m is not an integer? Wait, no. Wait, L_n is divisible by p, so m is integer. Therefore, L_n / i is p * m / i. Therefore, sum_{i=1}^n L_n / i is p * sum_{i=1}^n m / i. Therefore, this is p * something. Therefore, it is divisible by p. Therefore, 3 is\""
      ]
     },
     "execution_count": 60,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "line['response']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 61,
   "id": "fa28c910",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "10000"
      ]
     },
     "execution_count": 61,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(tokenizer.encode(line['response']))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d81e6485",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "venv",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
