{"id":16952,"date":"2026-06-14T18:42:31","date_gmt":"2026-06-14T09:42:31","guid":{"rendered":"https:\/\/f1-lap-time.com\/?p=16952"},"modified":"2026-06-14T18:42:32","modified_gmt":"2026-06-14T09:42:32","slug":"%e3%80%90%e3%83%90%e3%83%ab%e3%82%bb%e3%83%ad%e3%83%8a%e3%83%bb%e3%82%ab%e3%82%bf%e3%83%ab%e3%83%bc%e3%83%8b%e3%83%a3gp%e3%80%91-fp2%e3%83%ad%e3%83%b3%e3%82%b0%e3%83%a9%e3%83%b3%e5%88%86%e6%9e%90","status":"publish","type":"post","link":"https:\/\/f1-lap-time.com\/?p=16952","title":{"rendered":"\u3010\u30d0\u30eb\u30bb\u30ed\u30ca\u30fb\u30ab\u30bf\u30eb\u30fc\u30cb\u30e3GP\u3011 FP2\u30ed\u30f3\u30b0\u30e9\u30f3\u5206\u6790"},"content":{"rendered":"\n<p class=\"wp-block-paragraph\">\u4eca\u56de\u306f\u4e45\u3005\u306b\u30c7\u30b0\u30e9\u30c7\u30fc\u30b7\u30e7\u30f3\u304c\u5927\u304d\u304f\u3001\u30ed\u30f3\u30b0\u30e9\u30f3\u5206\u6790\u304c\u610f\u5473\u3092\u306a\u3059\u5c55\u958b\u3060\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u4ee5\u4e0b\u306f\u3001\u5404\u8eca\u306e\u30ed\u30f3\u30b0\u30e9\u30f3\u30da\u30fc\u30b9\u3092\u793a\u3059\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u30b0\u30e9\u30d5\u3060\u3002\u30dc\u30bf\u30f3\u64cd\u4f5c\u3067\u898b\u305f\u3044\u30c9\u30e9\u30a4\u30d0\u30fc\u3060\u3051\u3092\u8868\u793a\u3067\u304d\u308b\u3002<\/p>\n\n\n\n<meta charset=\"utf-8\">\n<title>Race Lap Time Interactive Graph<\/title>\n<script src=\"https:\/\/cdn.plot.ly\/plotly-2.26.0.min.js\"><\/script>\n\n<style>\n body{\n   margin:20px;\n   background:#fff;\n   color:#000;\n   font-family:\"Times New Roman\", Times, serif;\n }\n\n .driver-toggle{\n   display:inline-block;\n   padding:4px 8px;\n   margin:2px 4px;\n   border:1px solid #ccc;\n   border-radius:4px;\n   cursor:pointer;\n   user-select:none;\n   font-weight:bold;\n   color:#000;\n }\n\n .driver-toggle.active{\n   border:2px solid #000;\n }\n\n button{\n   margin-left:6px;\n   padding:6px 12px;\n   cursor:pointer;\n   font-size:1.0em;\n   font-family:\"Times New Roman\", Times, serif;\n }\n\n input,\n select{\n   font-family:\"Times New Roman\", Times, serif;\n   padding:4px 6px;\n   font-size:1.0em;\n }\n\n #controls,\n #adjustPanel{\n   font-family:\"Times New Roman\", Times, serif;\n }\n\n .row{\n   margin:8px 0;\n }\n\n #adjustPanel{\n   max-width:1200px;\n   margin-top:18px;\n   padding:12px;\n   border:1px solid #ccc;\n }\n\n #adjustPanel label{\n   display:inline-block;\n   margin-right:12px;\n   margin-bottom:8px;\n }\n\n #adjustPanel input[type=\"number\"]{\n   width:76px;\n }\n\n #adjustPanel select{\n   min-width:95px;\n }\n\n .small-note{\n   color:#555;\n   font-size:0.92em;\n }\n\n .status{\n   margin-top:6px;\n   font-size:0.95em;\n }\n\n .warn{\n   color:#b00000;\n }\n\n .ok{\n   color:#006000;\n }\n<\/style>\n\n\n\n\n<h2>Lap Times<\/h2>\n\n<div id=\"controls\">\n  <strong>Drivers:<\/strong>\n  <span id=\"driverButtons\"><\/span>\n  <button id=\"selectAll\">Select All<\/button>\n  <button id=\"clearAll\">Clear All<\/button>\n<\/div>\n\n<div id=\"status\" class=\"status\"><\/div>\n\n<div id=\"lapChart\" style=\"width:100%;max-width:1200px;height:520px;\"><\/div>\n\n<div id=\"adjustPanel\">\n  <h3 style=\"margin-top:0;\">Selected driver adjustment<\/h3>\n\n  <div class=\"row\">\n    <label>\n      Driver:\n      <select id=\"editDriver\"><\/select>\n    <\/label>\n\n    <label>\n      From Lap:\n      <input id=\"fromLap\" type=\"number\" step=\"1\" value=\"1\">\n    <\/label>\n\n    <label>\n      To Lap:\n      <input id=\"toLap\" type=\"number\" step=\"1\" value=\"5\">\n    <\/label>\n\n    <label>\n      Align start to Lap:\n      <input id=\"alignLap\" type=\"number\" step=\"1\" value=\"1\">\n    <\/label>\n\n    <label>\n      X offset:\n      <input id=\"xOffset\" type=\"number\" step=\"1\" value=\"0\">\n    <\/label>\n  <\/div>\n\n  <div class=\"row\">\n    <label>\n      Y correction:\n      <select id=\"yMode\">\n        <option value=\"none\">none<\/option>\n        <option value=\"manual\">manual<\/option>\n        <option value=\"auto\">auto fuel<\/option>\n        <option value=\"autoPlusManual\">auto fuel + manual<\/option>\n      <\/select>\n    <\/label>\n\n    <label>\n      Manual Y offset [s]:\n      <input id=\"manualY\" type=\"number\" step=\"0.001\" value=\"0\">\n    <\/label>\n\n    <label>\n      Fuel effect [s\/lap]:\n      <input id=\"fuelEffect\" type=\"number\" step=\"0.001\" value=\"0.041\">\n    <\/label>\n\n    <label>\n      Auto fuel laps = From Lap \u2212\n      <input id=\"fuelMinus\" type=\"number\" step=\"1\" value=\"2\">\n    <\/label>\n\n    <span id=\"autoFuelPreview\" class=\"small-note\"><\/span>\n  <\/div>\n\n  <div class=\"row\">\n    <button id=\"applyAdjustment\">Apply to selected driver<\/button>\n    <button id=\"resetSelected\">Reset selected driver to full laps<\/button>\n    <button id=\"resetAllAdjustments\">Reset all adjustments<\/button>\n  <\/div>\n\n  <div class=\"row small-note\">\n    \u4f8b\uff1aFrom Lap 12\u3001Fuel effect 0.041\u3001Auto fuel laps = From Lap \u2212 2 \u306a\u3089\u300110\u5468\u5206\u3068\u3057\u3066 +0.410s \u3092\u52a0\u7b97\u3002\n  <\/div>\n<\/div>\n\n<script>\nconst DATA_FILE = \"barcelona_2026_FP2_lap_times.tsv\";\n\n\/*\n  \u4e26\u3073\u9806\u306f\u3053\u3053\u3067\u7ba1\u7406\u3002\n  TSV\u306b\u5b58\u5728\u3057\u306a\u3044\u30c9\u30e9\u30a4\u30d0\u30fc\u306f\u81ea\u52d5\u7684\u306b\u7121\u52b9\u6271\u3044\u3002\n*\/\nconst DRIVERS = [\n  {code:\"NOR\", full:\"Lando NORRIS\"},\n  {code:\"PIA\", full:\"Oscar PIASTRI\"},\n\n  {code:\"RUS\", full:\"George RUSSELL\"},\n  {code:\"ANT\", full:\"Kimi ANTONELLI\"},\n\n  {code:\"VER\", full:\"Max VERSTAPPEN\"},\n  {code:\"PER\", full:\"Sergio PEREZ\"},\n\n  {code:\"LEC\", full:\"Charles LECLERC\"},\n  {code:\"HAM\", full:\"Lewis HAMILTON\"},\n\n  {code:\"ALB\", full:\"Alexander ALBON\"},\n  {code:\"SAI\", full:\"Carlos SAINZ\"},\n\n  {code:\"LAW\", full:\"Liam LAWSON\"},\n  {code:\"HAD\", full:\"Isack HADJAR\"},\n  {code:\"LIN\", full:\"Arvid LINDBLAD\"},\n\n  {code:\"ALO\", full:\"Fernando ALONSO\"},\n  {code:\"STR\", full:\"Lance STROLL\"},\n\n  {code:\"OCO\", full:\"Esteban OCON\"},\n  {code:\"BEA\", full:\"Oliver BEARMAN\"},\n\n  {code:\"HUL\", full:\"Nico HULKENBERG\"},\n  {code:\"BOR\", full:\"Gabriel BORTOLETO\"},\n\n  {code:\"GAS\", full:\"Pierre GASLY\"},\n  {code:\"COL\", full:\"Franco COLAPINTO\"},\n\n  {code:\"BOT\", full:\"Valtteri BOTTAS\"}\n];\n\nconst DRIVER_COLORS = {\n  NOR:\"rgb(255,128,0)\",\n  PIA:\"rgb(255,192,128)\",\n\n  RUS:\"rgb(166,166,166)\",\n  ANT:\"rgb(0,176,80)\",\n\n  VER:\"rgb(0,32,96)\",\n  PER:\"rgb(150,75,0)\",\n\n  LEC:\"rgb(255,0,0)\",\n  HAM:\"rgb(255,192,192)\",\n\n  ALB:\"rgb(192,176,224)\",\n  SAI:\"rgb(0,112,192)\",\n\n  LAW:\"rgb(180,198,231)\",\n  HAD:\"rgb(102,255,0)\",\n  LIN:\"rgb(112,48,160)\",\n\n  ALO:\"rgb(0,176,240)\",\n  STR:\"rgb(0,112,112)\",\n\n  OCO:\"rgb(0,0,0)\",\n  BEA:\"rgb(128,128,128)\",\n\n  HUL:\"rgb(255,193,37)\",\n  BOR:\"rgb(192,0,0)\",\n\n  GAS:\"rgb(0,128,255)\",\n  COL:\"rgb(255,0,255)\",\n\n  BOT:\"rgb(120,120,120)\"\n};\n\nconst WHITE_TEXT = new Set([\n  \"VER\",\"PER\",\"LIN\",\"STR\",\"OCO\",\"BEA\",\"SAI\",\"GAS\",\"BOR\",\"BOT\"\n]);\n\nlet rows = [];\nlet headers = [];\nlet availableDrivers = [];\nlet visibleOrder = [];\nlet state = {};\n\nDRIVERS.forEach(d => {\n  state[d.code] = {\n    visible:false,\n\n    \/\/ null\u306a\u3089\u5168\u5468\u8868\u793a\n    fromLap:null,\n    toLap:null,\n\n    alignLap:1,\n    xOffset:0,\n\n    yMode:\"none\",\n    manualY:0,\n    fuelMinus:2\n  };\n});\n\nfetch(DATA_FILE, {cache:\"no-store\"})\n  .then(r => {\n    if(!r.ok) throw new Error(\"HTTP \" + r.status);\n    return r.text();\n  })\n  .then(tsv => {\n    parseTSV(tsv);\n    buildDriverButtons();\n    buildEditDriverSelect();\n    bindControls();\n    updateAutoFuelPreview();\n    updatePlot();\n    setStatus(`Loaded: ${DATA_FILE}`, true);\n  })\n  .catch(e => {\n    console.error(e);\n    setStatus(`TSV\u8aad\u307f\u8fbc\u307f\u306b\u5931\u6557\u3057\u307e\u3057\u305f: ${DATA_FILE}`, false);\n  });\n\nfunction parseTSV(tsv){\n  const lines = tsv\n    .replace(\/^\\uFEFF\/, \"\")\n    .trim()\n    .split(\/\\r?\\n\/)\n    .filter(Boolean);\n\n  const table = lines.map(line => line.split(\"\\t\").map(v => String(v ?? \"\").trim()));\n\n  headers = table[0];\n\n  const lapIndex = headers.findIndex(h => h.toLowerCase() === \"lap\");\n  const realLapIndex = lapIndex >= 0 ? lapIndex : 0;\n\n  rows = [];\n\n  for(let i = 1; i < table.length; i++){\n    const cells = table[i];\n    const lap = parseInt(cells[realLapIndex], 10);\n\n    if(!Number.isFinite(lap)) continue;\n\n    const times = {};\n\n    headers.forEach((h, idx) => {\n      if(idx === realLapIndex) return;\n      times[h] = timeStrToSec(cells[idx]);\n    });\n\n    rows.push({lap, times});\n  }\n\n  availableDrivers = DRIVERS.filter(d => headers.includes(d.full));\n}\n\nfunction buildDriverButtons(){\n  const box = document.getElementById(\"driverButtons\");\n  box.innerHTML = \"\";\n\n  DRIVERS.forEach(d => {\n    const b = document.createElement(\"span\");\n    b.textContent = d.code;\n    b.className = \"driver-toggle\";\n    b.dataset.driver = d.code;\n    b.style.backgroundColor = DRIVER_COLORS[d.code] || \"#ddd\";\n\n    if(WHITE_TEXT.has(d.code)){\n      b.style.color = \"#fff\";\n    }\n\n    const exists = availableDrivers.some(x => x.code === d.code);\n\n    if(!exists){\n      b.style.opacity = \"0.25\";\n      b.style.cursor = \"not-allowed\";\n      b.title = \"This driver column is not in the TSV.\";\n    }else{\n      b.onclick = () => toggleDriver(d.code);\n    }\n\n    box.appendChild(b);\n  });\n}\n\nfunction buildEditDriverSelect(){\n  const select = document.getElementById(\"editDriver\");\n  select.innerHTML = \"\";\n\n  availableDrivers.forEach(d => {\n    const opt = document.createElement(\"option\");\n    opt.value = d.code;\n    opt.textContent = d.code;\n    select.appendChild(opt);\n  });\n\n  if(availableDrivers.length > 0){\n    select.value = availableDrivers[0].code;\n    loadStateToForm(select.value);\n  }\n}\n\nfunction bindControls(){\n  document.getElementById(\"editDriver\").onchange = e => {\n    loadStateToForm(e.target.value);\n  };\n\n  [\"fromLap\",\"toLap\",\"fuelEffect\",\"fuelMinus\"].forEach(id => {\n    document.getElementById(id).oninput = updateAutoFuelPreview;\n  });\n\n  document.getElementById(\"applyAdjustment\").onclick = applyAdjustment;\n  document.getElementById(\"resetSelected\").onclick = resetSelected;\n  document.getElementById(\"resetAllAdjustments\").onclick = resetAllAdjustments;\n\n  document.getElementById(\"selectAll\").onclick = () => {\n    visibleOrder = [];\n    availableDrivers.forEach(d => {\n      state[d.code].visible = true;\n      visibleOrder.push(d.code);\n    });\n    refreshDriverButtons();\n    updatePlot();\n  };\n\n  document.getElementById(\"clearAll\").onclick = () => {\n    DRIVERS.forEach(d => state[d.code].visible = false);\n    visibleOrder = [];\n    refreshDriverButtons();\n    updatePlot();\n  };\n}\n\nfunction toggleDriver(code){\n  const s = state[code];\n\n  s.visible = !s.visible;\n\n  if(s.visible){\n    visibleOrder = visibleOrder.filter(c => c !== code);\n    visibleOrder.push(code);\n    document.getElementById(\"editDriver\").value = code;\n    loadStateToForm(code);\n  }else{\n    visibleOrder = visibleOrder.filter(c => c !== code);\n  }\n\n  refreshDriverButtons();\n  updatePlot();\n}\n\nfunction refreshDriverButtons(){\n  document.querySelectorAll(\".driver-toggle\").forEach(b => {\n    const code = b.dataset.driver;\n    b.classList.toggle(\"active\", Boolean(state[code]?.visible));\n  });\n}\n\nfunction loadStateToForm(code){\n  const s = state[code];\n\n  const laps = rows.map(r => r.lap);\n  const minLap = Math.min(...laps);\n  const maxLap = Math.max(...laps);\n\n  document.getElementById(\"fromLap\").value = s.fromLap ?? minLap;\n  document.getElementById(\"toLap\").value = s.toLap ?? maxLap;\n  document.getElementById(\"alignLap\").value = s.alignLap;\n  document.getElementById(\"xOffset\").value = s.xOffset;\n\n  document.getElementById(\"yMode\").value = s.yMode;\n  document.getElementById(\"manualY\").value = s.manualY;\n  document.getElementById(\"fuelMinus\").value = s.fuelMinus;\n\n  updateAutoFuelPreview();\n}\n\nfunction applyAdjustment(){\n  const code = document.getElementById(\"editDriver\").value;\n  if(!code) return;\n\n  const s = state[code];\n\n  s.fromLap = parseInt(document.getElementById(\"fromLap\").value, 10);\n  s.toLap = parseInt(document.getElementById(\"toLap\").value, 10);\n\n  if(s.fromLap > s.toLap){\n    const tmp = s.fromLap;\n    s.fromLap = s.toLap;\n    s.toLap = tmp;\n  }\n\n  s.alignLap = parseInt(document.getElementById(\"alignLap\").value, 10) || 1;\n  s.xOffset = parseFloat(document.getElementById(\"xOffset\").value) || 0;\n\n  s.yMode = document.getElementById(\"yMode\").value;\n  s.manualY = parseFloat(document.getElementById(\"manualY\").value) || 0;\n  s.fuelMinus = parseFloat(document.getElementById(\"fuelMinus\").value) || 0;\n\n  if(!s.visible){\n    s.visible = true;\n    visibleOrder = visibleOrder.filter(c => c !== code);\n    visibleOrder.push(code);\n  }\n\n  refreshDriverButtons();\n  updateAutoFuelPreview();\n  updatePlot();\n}\n\nfunction resetSelected(){\n  const code = document.getElementById(\"editDriver\").value;\n  if(!code) return;\n\n  state[code].fromLap = null;\n  state[code].toLap = null;\n  state[code].alignLap = 1;\n  state[code].xOffset = 0;\n  state[code].yMode = \"none\";\n  state[code].manualY = 0;\n  state[code].fuelMinus = 2;\n\n  loadStateToForm(code);\n  updatePlot();\n}\n\nfunction resetAllAdjustments(){\n  DRIVERS.forEach(d => {\n    state[d.code].fromLap = null;\n    state[d.code].toLap = null;\n    state[d.code].alignLap = 1;\n    state[d.code].xOffset = 0;\n    state[d.code].yMode = \"none\";\n    state[d.code].manualY = 0;\n    state[d.code].fuelMinus = 2;\n  });\n\n  const code = document.getElementById(\"editDriver\").value;\n  if(code) loadStateToForm(code);\n\n  updatePlot();\n}\n\nfunction updateAutoFuelPreview(){\n  const fromLap = parseFloat(document.getElementById(\"fromLap\").value) || 0;\n  const fuelMinus = parseFloat(document.getElementById(\"fuelMinus\").value) || 0;\n  const fuelEffect = parseFloat(document.getElementById(\"fuelEffect\").value) || 0;\n\n  const fuelLaps = Math.max(0, fromLap - fuelMinus);\n  const offset = fuelLaps * fuelEffect;\n\n  document.getElementById(\"autoFuelPreview\").textContent =\n    `Auto: ${fuelLaps.toFixed(0)} laps \u00d7 ${fuelEffect.toFixed(3)} = +${offset.toFixed(3)}s`;\n}\n\nfunction updatePlot(){\n  const traces = [];\n\n  const order = visibleOrder.filter(code => state[code]?.visible);\n\n  order.forEach(code => {\n    const d = DRIVERS.find(x => x.code === code);\n    if(!d) return;\n\n    const trace = buildTrace(d);\n    if(trace.x.length > 0){\n      traces.push(trace);\n    }\n  });\n\n  const yRange = calculateYRange(traces);\n  const tickVals = makeTickVals(yRange.min, yRange.max);\n\n  Plotly.react(\"lapChart\", traces, {\n    font: {\n      family:\"Times New Roman, Times, serif\"\n    },\n    legend: {\n      itemclick:false,\n      itemdoubleclick:false\n    },\n    xaxis: {\n      title: {\n        text:\"Lap\"\n      },\n      tickfont: {\n        family:\"Times New Roman, Times, serif\"\n      },\n      dtick: 1\n    },\n    yaxis: {\n      title: {\n        text:\"Time (m:s)\"\n      },\n      tickfont: {\n        family:\"Times New Roman, Times, serif\"\n      },\n      range: [yRange.max, yRange.min],\n      autorange: false,\n      tickvals: tickVals,\n      ticktext: tickVals.map(secToTime)\n    },\n    margin: {\n      t:40,\n      r:30,\n      b:50,\n      l:70\n    },\n    hovermode:\"closest\"\n  }, {\n    responsive:true\n  });\n}\n\nfunction buildTrace(driver){\n  const s = state[driver.code];\n\n  const fuelEffect = parseFloat(document.getElementById(\"fuelEffect\").value) || 0;\n\n  const hasSegment = s.fromLap !== null && s.toLap !== null;\n\n  const from = hasSegment ? s.fromLap : -Infinity;\n  const to = hasSegment ? s.toLap : Infinity;\n\n  const fuelLaps = hasSegment\n    ? Math.max(0, s.fromLap - s.fuelMinus)\n    : 0;\n\n  const autoY = fuelLaps * fuelEffect;\n\n  let yOffset = 0;\n\n  if(s.yMode === \"manual\"){\n    yOffset = s.manualY;\n  }else if(s.yMode === \"auto\"){\n    yOffset = autoY;\n  }else if(s.yMode === \"autoPlusManual\"){\n    yOffset = autoY + s.manualY;\n  }\n\n  const xs = [];\n  const ys = [];\n  const custom = [];\n\n  rows.forEach(row => {\n    if(row.lap < from || row.lap > to) return;\n\n    const raw = row.times[driver.full];\n\n    if(raw === null || !Number.isFinite(raw)) return;\n\n    const x = hasSegment\n      ? row.lap - s.fromLap + s.alignLap + s.xOffset\n      : row.lap + s.xOffset;\n\n    const y = raw + yOffset;\n\n    xs.push(x);\n    ys.push(y);\n\n    custom.push([\n      row.lap,\n      secToTime(raw),\n      secToTime(y),\n      yOffset.toFixed(3),\n      autoY.toFixed(3),\n      s.manualY.toFixed(3)\n    ]);\n  });\n\n  let name = driver.code;\n\n  if(hasSegment){\n    name += ` L${s.fromLap}-${s.toLap}`;\n  }\n\n  if(Math.abs(yOffset) > 0.0005){\n    name += ` (+${yOffset.toFixed(3)}s)`;\n  }\n\n  return {\n    name,\n    x: xs,\n    y: ys,\n    mode:\"lines+markers\",\n    line: {\n      color: DRIVER_COLORS[driver.code],\n      width: 2\n    },\n    marker: {\n      size: 6,\n      color: DRIVER_COLORS[driver.code],\n      symbol:\"circle\",\n      line: {\n        color: DRIVER_COLORS[driver.code],\n        width: 1.5\n      }\n    },\n    customdata: custom,\n    hovertemplate:\n      `<b>${driver.code}<\/b><br>` +\n      `Displayed Lap: %{x}<br>` +\n      `Original Lap: %{customdata[0]}<br>` +\n      `Raw time: %{customdata[1]}<br>` +\n      `Shown time: %{customdata[2]}<br>` +\n      `Y offset: %{customdata[3]}s<br>` +\n      `Auto fuel offset: %{customdata[4]}s<br>` +\n      `Manual offset: %{customdata[5]}s` +\n      `<extra><\/extra>`\n  };\n}\n\nfunction calculateYRange(traces){\n  const values = [];\n\n  traces.forEach(t => {\n    t.y.forEach(v => {\n      if(Number.isFinite(v)) values.push(v);\n    });\n  });\n\n  if(values.length === 0){\n    return {\n      min:80,\n      max:88\n    };\n  }\n\n  const fastest = Math.min(...values);\n  const yMin = Math.floor(fastest);\n  const yMax = yMin + 8;\n\n  return {\n    min:yMin,\n    max:yMax\n  };\n}\n\nfunction makeTickVals(min, max){\n  const vals = [];\n\n  for(let v = Math.ceil(min); v <= Math.floor(max); v++){\n    vals.push(v);\n  }\n\n  return vals;\n}\n\nfunction timeStrToSec(value){\n  const s = String(value ?? \"\").trim();\n\n  if(!s) return null;\n\n  if(s.includes(\":\")){\n    const [mStr, secStr] = s.split(\":\");\n    const m = parseInt(mStr, 10);\n    const sec = parseFloat(secStr);\n\n    if(!Number.isFinite(m) || !Number.isFinite(sec)) return null;\n\n    return m * 60 + sec;\n  }\n\n  const n = parseFloat(s);\n  return Number.isFinite(n) ? n : null;\n}\n\nfunction secToTime(sec){\n  if(!Number.isFinite(sec)) return \"\";\n\n  const m = Math.floor(sec \/ 60);\n  const s = sec - m * 60;\n\n  return m + \":\" + (\"0\" + s.toFixed(3)).slice(-6);\n}\n\nfunction setStatus(message, ok){\n  const el = document.getElementById(\"status\");\n  el.className = ok ? \"status ok\" : \"status warn\";\n  el.textContent = message;\n}\n<\/script>\n\n\n\n<p class=\"wp-block-paragraph\">\u5404\u8eca\u306e\u30bf\u30a4\u30e4\u306f\u4ee5\u4e0b\u306e\u901a\u308a\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Lando Norris\uff1aSoft<\/li>\n\n\n\n<li>Oscar Piastri\uff1aMedium<\/li>\n\n\n\n<li>George Russell\uff1aMedium \u2192 Soft<\/li>\n\n\n\n<li>Kimi Antonelli\uff1aSoft \u2192 Medium<\/li>\n\n\n\n<li>Max Verstappen\uff1aHard \u2192 Soft<\/li>\n\n\n\n<li>Isack Hadjar\uff1aMedium \u2192 Soft<\/li>\n\n\n\n<li>Charles Leclerc\uff1aMedium<\/li>\n\n\n\n<li>Lewis Hamilton\uff1aMedium<\/li>\n\n\n\n<li>Alexander Albon\uff1aSoft<\/li>\n\n\n\n<li>Carlos Sainz\uff1aMedium<\/li>\n\n\n\n<li>Arvid Lindblad\uff1aMedium<\/li>\n\n\n\n<li>Esteban Ocon\uff1aMedium<\/li>\n\n\n\n<li>Oliver Bearman\uff1aSoft<\/li>\n\n\n\n<li>Nico H\u00fclkenberg\uff1aMedium<\/li>\n\n\n\n<li>Gabriel Bortoleto\uff1aMedium<\/li>\n\n\n\n<li>Pierre Gasly\uff1aMedium<\/li>\n\n\n\n<li>Franco Colapinto\uff1aMedium<\/li>\n\n\n\n<li>Sergio Perez\uff1aMedium<\/li>\n\n\n\n<li>\u6ce8\uff1aAston Martin\u52e2\u306f\u30ed\u30f3\u30b0\u30e9\u30f3\u533a\u9593\u304c\u77ed\u304f\u3001\u30b3\u30f3\u30d1\u30a6\u30f3\u30c9\u306f\u76f4\u63a5\u78ba\u8a8d\u3067\u306f\u306a\u304f\u63a8\u5b9a\u6271\u3044\u3002<\/li>\n\n\n\n<li>Fernando Alonso\uff1aMedium\uff08\u63a8\u5b9a\uff09<\/li>\n\n\n\n<li>Lance Stroll\uff1aMedium\uff08\u63a8\u5b9a\uff09<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">\u7ba1\u7406\u4eba\u306e\u6240\u611f<\/h2>\n\n\n\n<p class=\"wp-block-paragraph\">\u56f31\u306b\u30bd\u30d5\u30c8\u30bf\u30a4\u30e4\u3067\u306e\u30da\u30fc\u30b9\u3092\u793a\u3059\u3002\u30e9\u30c3\u30bb\u30eb\u3068\u30d5\u30a7\u30eb\u30b9\u30bf\u30c3\u30da\u30f3\u306f\u4e00\u5ea6\u30bf\u30a4\u30e4\u3092\u66ff\u3048\u3066\u304b\u3089\u306e\u30b9\u30c6\u30a3\u30f3\u30c8\u3067\u3042\u308b\u305f\u3081\u3001\u30d5\u30e5\u30fc\u30a8\u30eb\u30a8\u30d5\u30a7\u30af\u30c8\u3092\u88dc\u6b63\u3057\u305f\u5024\u3060\u3002<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"954\" height=\"520\" src=\"https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-4.png\" alt=\"\" class=\"wp-image-16959\" srcset=\"https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-4.png 954w, https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-4-300x164.png 300w, https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-4-768x419.png 768w\" sizes=\"auto, (max-width: 954px) 100vw, 954px\" \/><figcaption class=\"wp-element-caption\">\u56f31 \u30bd\u30d5\u30c8\u3067\u306e\u30ed\u30f3\u30b0\u30e9\u30f3<\/figcaption><\/figure>\n<\/div>\n\n\n<p class=\"wp-block-paragraph\">\u30e9\u30c3\u30bb\u30eb\u306e\u30da\u30fc\u30b9\u304c\u51b4\u3048\u306a\u3044\u306e\u304c\u6c17\u306b\u306a\u308b\u304c\u3001\u30a2\u30f3\u30c8\u30cd\u30c3\u30ea\u306f\u30ce\u30ea\u30b9\u306b\u5dee\u3092\u3064\u3051\u3066\u304a\u308a\u3001\u30d5\u30a7\u30eb\u30b9\u30bf\u30c3\u30da\u30f3\u306f\u30de\u30af\u30e9\u30fc\u30ec\u30f3\u306b\u5c4a\u3044\u3066\u3044\u306a\u3044\u3002\u91d1\u66dc\u65e5\u306e\u6bb5\u968e\u3067\u306f\u3042\u308b\u304c\u3001\u3053\u308c\u3092\u4fe1\u3058\u308b\u306a\u3089\u3070\u30ec\u30fc\u30b9\u30da\u30fc\u30b9\u3067\u3082\u30e1\u30eb\u30bb\u30c7\u30b9\u306f\u76e4\u77f3\u3060\u308d\u3046\u3002<br>\u3061\u306a\u307f\u306b\u30d5\u30a7\u30eb\u30b9\u30bf\u30c3\u30da\u30f3\u3067\u30c7\u30b0\u30e9\u30c7\u30fc\u30b7\u30e7\u30f3\u306f0.12[s\/lap]\u7a0b\u5ea6\u3060\u3002<\/p>\n\n\n\n<p class=\"wp-block-paragraph\">\u6b21\u306b\u30df\u30c7\u30a3\u30a2\u30e0\u30bf\u30a4\u30e4\u3067\u306e\u30da\u30fc\u30b9\u3092\u793a\u3059\u3002<\/p>\n\n\n<div class=\"wp-block-image\">\n<figure class=\"aligncenter size-full\"><img loading=\"lazy\" decoding=\"async\" width=\"954\" height=\"520\" src=\"https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-3-1.png\" alt=\"\" class=\"wp-image-16958\" srcset=\"https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-3-1.png 954w, https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-3-1-300x164.png 300w, https:\/\/f1-lap-time.com\/wp-content\/uploads\/2026\/06\/newplot-3-1-768x419.png 768w\" sizes=\"auto, (max-width: 954px) 100vw, 954px\" \/><figcaption class=\"wp-element-caption\">\u56f32 \u30df\u30c7\u30a3\u30a2\u30e0\u3067\u306e\u30ed\u30f3\u30b0\u30e9\u30f3<\/figcaption><\/figure>\n<\/div>\n\n\n<p class=\"wp-block-paragraph\">\u3053\u3061\u3089\u3067\u306f\u30e9\u30c3\u30bb\u30eb\u3082\u597d\u30da\u30fc\u30b9\u3092\u523b\u3093\u3067\u304a\u308a\u3001\u30bd\u30d5\u30c8\u3067\u306f\u4f55\u304b\u3092\u8a66\u3057\u3066\u3044\u305f\u3082\u306e\u3068\u601d\u308f\u308c\u308b\u3002\u305f\u3060\u3057\u30eb\u30af\u30ec\u30fc\u30eb\u3082\u304b\u306a\u308a\u306e\u30da\u30fc\u30b9\u3067\u3001\u4eca\u56de\u306e\u30d5\u30a7\u30e9\u30fc\u30ea\u306f\u7af6\u4e89\u529b\u304c\u3042\u308a\u305d\u3046\u3060\u3002\u30de\u30af\u30e9\u30fc\u30ec\u30f3\u306f\u96e2\u308c\u305f\u304c\u3001\u30c7\u30b0\u30e9\u30c7\u30fc\u30b7\u30e7\u30f3\u304c\u5c0f\u3055\u304f\u3001\u30bf\u30a4\u30e4\u30de\u30cd\u30b8\u30e1\u30f3\u30c8\u306e\u65b9\u91dd\u304c\u7570\u306a\u308b\u3082\u306e\u3068\u601d\u308f\u308c\u308b\u3002<br>\u3061\u306a\u307f\u306b\u3001\u30c7\u30b0\u30e9\u30c7\u30fc\u30b7\u30e7\u30f3\u306f\u30e9\u30c3\u30bb\u30eb\u30670.028[s\/lap]\u7a0b\u5ea6\u3067\u3001\u3053\u308c\u306f\u304b\u306a\u308a\u5927\u304d\u3044\u3002\u305f\u3060\u3057\u3001\u901a\u5e38\u30ec\u30fc\u30b9\u3067\u306fFP2\u3088\u308a\u30de\u30cd\u30b8\u30e1\u30f3\u30c8\u304c\u5927\u304d\u304f\u306a\u308a\u30c7\u30b0\u30e9\u30c7\u30fc\u30b7\u30e7\u30f3\u304c\u5c0f\u3055\u304f\u306a\u308b\u50be\u5411\u304c\u3042\u308b\u306e\u3067\u3001\u5404\u8eca\u305d\u3053\u307e\u3067\u6975\u7aef\u306b\u306f\u306a\u3089\u306a\u3044\u3068\u4e88\u60f3\u3055\u308c\u308b\u3002<\/p>\n\n\n\n<p class=\"has-text-align-right wp-block-paragraph\">Takumi<\/p>\n<!-- AddThis Advanced Settings generic via filter on the_content --><!-- AddThis Share Buttons generic via filter on the_content -->","protected":false},"excerpt":{"rendered":"<p>\u4eca\u56de\u306f\u4e45\u3005\u306b\u30c7\u30b0\u30e9\u30c7\u30fc\u30b7\u30e7\u30f3\u304c\u5927\u304d\u304f\u3001\u30ed\u30f3\u30b0\u30e9\u30f3\u5206\u6790\u304c\u610f\u5473\u3092\u306a\u3059\u5c55\u958b\u3060\u3002 \u4ee5\u4e0b\u306f\u3001\u5404\u8eca\u306e\u30ed\u30f3\u30b0\u30e9\u30f3\u30da\u30fc\u30b9\u3092\u793a\u3059\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u30b0\u30e9\u30d5\u3060\u3002\u30dc\u30bf\u30f3\u64cd\u4f5c\u3067\u898b\u305f\u3044\u30c9\u30e9\u30a4\u30d0\u30fc\u3060\u3051\u3092\u8868\u793a\u3067\u304d\u308b\u3002 Race Lap Time Int [&hellip;]<!-- AddThis Advanced Settings generic via filter on get_the_excerpt --><!-- AddThis Share Buttons generic via filter on get_the_excerpt --><\/p>\n","protected":false},"author":1,"featured_media":16959,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-16952","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-uncategorized"],"aioseo_notices":[],"_links":{"self":[{"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=\/wp\/v2\/posts\/16952","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=16952"}],"version-history":[{"count":5,"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=\/wp\/v2\/posts\/16952\/revisions"}],"predecessor-version":[{"id":16960,"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=\/wp\/v2\/posts\/16952\/revisions\/16960"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=\/wp\/v2\/media\/16959"}],"wp:attachment":[{"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=16952"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=16952"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/f1-lap-time.com\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=16952"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}