import%20marimo%0A%0A__generated_with%20%3D%20%220.23.4%22%0Aapp%20%3D%20marimo.App(width%3D%22medium%22)%0A%0A%0A%40app.cell%0Adef%20_()%3A%0A%20%20%20%20import%20marimo%20as%20mo%0A%0A%20%20%20%20return%20(mo%2C)%0A%0A%0A%40app.cell%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(r%22%22%22%0A%20%20%20%20%23%20Chapter%201%3A%20The%20Baseball%20Datasets%20%2F%20%E9%87%8E%E7%90%83%E3%83%87%E3%83%BC%E3%82%BF%E3%82%BB%E3%83%83%E3%83%88%E5%85%A5%E9%96%80%0A%0A%20%20%20%20**%E5%8E%9F%E8%91%97**%3A%20*Analyzing%20Baseball%20Data%20with%20R%2C%203rd%20ed.*%20Chapter%201%0A%0A%20%20%20%20**%E5%8E%9F%E8%91%97URL**%3A%20https%3A%2F%2Fbeanumber.github.io%2Fabdwr3e%2F01-datasets.html%0A%0A%20%20%20%20%23%23%20%E6%A6%82%E8%A6%81%0A%20%20%20%20%E9%87%8E%E7%90%83%E3%83%87%E3%83%BC%E3%82%BF%E3%81%AE%E4%B8%BB%E8%A6%81%E3%82%BD%E3%83%BC%E3%82%B9%E3%82%92%E7%B4%B9%E4%BB%8B%E3%81%97%E3%80%81Python%20(pybaseball)%20%E3%81%A7%E5%8F%96%E5%BE%97%E3%81%99%E3%82%8B%E6%96%B9%E6%B3%95%E3%82%92%E7%A4%BA%E3%81%99%E3%80%82%0A%0A%20%20%20%20%7C%20%E3%83%87%E3%83%BC%E3%82%BF%E3%82%BD%E3%83%BC%E3%82%B9%20%7C%20%E7%B2%92%E5%BA%A6%20%7C%20%E6%9C%9F%E9%96%93%20%7C%20%E7%89%B9%E5%BE%B4%20%7C%0A%20%20%20%20%7C---%7C---%7C---%7C---%7C%0A%20%20%20%20%7C%20**Lahman%20Database**%20%7C%20%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%E9%9B%86%E8%A8%88%20%7C%201871%E5%B9%B4%E3%80%9C%E7%8F%BE%E5%9C%A8%20%7C%20%E6%89%93%E6%92%83%E3%83%BB%E6%8A%95%E7%90%83%E3%83%BB%E5%AE%88%E5%82%99%E3%83%BB%E3%83%81%E3%83%BC%E3%83%A0%20%7C%0A%20%20%20%20%7C%20**Retrosheet**%20%7C%20%E8%A9%A6%E5%90%88%E3%83%AD%E3%82%B0%20%7C%201871%E5%B9%B4%E3%80%9C%E7%8F%BE%E5%9C%A8%20%7C%201%E8%A9%A6%E5%90%88%E5%8D%98%E4%BD%8D%E3%81%AE%E8%A9%B3%E7%B4%B0%E8%A8%98%E9%8C%B2%20%7C%0A%20%20%20%20%7C%20**Statcast**%20%7C%20%E6%8A%95%E7%90%83%E3%83%88%E3%83%A9%E3%83%83%E3%82%AD%E3%83%B3%E3%82%B0%20%7C%202015%E5%B9%B4%E3%80%9C%E7%8F%BE%E5%9C%A8%20%7C%20%E7%90%83%E9%80%9F%E3%83%BB%E5%9B%9E%E8%BB%A2%E6%95%B0%E3%83%BB%E6%89%93%E7%90%83%E8%A7%92%E5%BA%A6%20%7C%0A%20%20%20%20%7C%20**FanGraphs**%20%7C%20%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%E9%9B%86%E8%A8%88%20%7C%202002%E5%B9%B4%E3%80%9C%E7%8F%BE%E5%9C%A8%20%7C%20wRC%2B%2C%20FIP%2C%20WAR%20%E3%81%AA%E3%81%A9%E3%81%AE%E6%8C%87%E6%A8%99%20%7C%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_()%3A%0A%20%20%20%20import%20altair%20as%20alt%0A%20%20%20%20import%20polars%20as%20pl%0A%0A%20%20%20%20from%20baseball.data%20import%20(%0A%20%20%20%20%20%20%20%20load_lahman_batting%2C%0A%20%20%20%20%20%20%20%20load_statcast%2C%0A%20%20%20%20)%0A%0A%20%20%20%20return%20alt%2C%20load_lahman_batting%2C%20load_statcast%2C%20pl%0A%0A%0A%40app.cell%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(%22%22%22%0A%20%20%20%20%23%23%201.%20Lahman%20Database%0A%0A%20%20%20%20%E6%9C%80%E3%82%82%E6%AD%B4%E5%8F%B2%E3%81%AE%E6%B7%B1%E3%81%84%E9%87%8E%E7%90%83%E7%B5%B1%E8%A8%88%E3%83%87%E3%83%BC%E3%82%BF%E3%83%99%E3%83%BC%E3%82%B9%E3%80%821871%E5%B9%B4%E3%81%8B%E3%82%89%E7%8F%BE%E5%9C%A8%E3%81%BE%E3%81%A7%E3%80%81MLB%20%E5%85%A8%E9%81%B8%E6%89%8B%E3%81%AE%0A%20%20%20%20%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%E9%9B%86%E8%A8%88%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E5%8F%8E%E9%8C%B2%E3%80%82%60batting%60%20%E3%83%86%E3%83%BC%E3%83%96%E3%83%AB%E3%81%AE%E4%B8%BB%E8%A6%81%E5%88%97%E3%82%92%E7%A2%BA%E8%AA%8D%E3%81%99%E3%82%8B%E3%80%82%0A%0A%20%20%20%20%7C%20%E5%88%97%20%7C%20%E8%AA%AC%E6%98%8E%20%7C%0A%20%20%20%20%7C---%7C---%7C%0A%20%20%20%20%7C%20%60playerID%60%20%7C%20%E9%81%B8%E6%89%8B%E5%9B%BA%E6%9C%89ID%EF%BC%88lahman%E5%BD%A2%E5%BC%8F%EF%BC%89%20%7C%0A%20%20%20%20%7C%20%60yearID%60%20%7C%20%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%E5%B9%B4%20%7C%0A%20%20%20%20%7C%20%60teamID%60%20%7C%20%E3%83%81%E3%83%BC%E3%83%A0ID%20%7C%0A%20%20%20%20%7C%20%60G%60%20%7C%20%E8%A9%A6%E5%90%88%E6%95%B0%20%7C%0A%20%20%20%20%7C%20%60AB%60%20%7C%20%E6%89%93%E6%95%B0%20%7C%0A%20%20%20%20%7C%20%60H%60%20%7C%20%E5%AE%89%E6%89%93%20%7C%0A%20%20%20%20%7C%20%60HR%60%20%7C%20%E6%9C%AC%E5%A1%81%E6%89%93%20%7C%0A%20%20%20%20%7C%20%60RBI%60%20%7C%20%E6%89%93%E7%82%B9%20%7C%0A%20%20%20%20%7C%20%60BB%60%20%7C%20%E5%9B%9B%E7%90%83%20%7C%0A%20%20%20%20%7C%20%60SO%60%20%7C%20%E4%B8%89%E6%8C%AF%20%7C%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(load_lahman_batting)%3A%0A%20%20%20%20batting%20%3D%20load_lahman_batting()%0A%20%20%20%20latest_year%20%3D%20batting%5B%22yearID%22%5D.max()%0A%20%20%20%20season_games%20%3D%20batting.filter(batting%5B%22yearID%22%5D%20%3D%3D%20latest_year)%5B%22G%22%5D.max()%0A%20%20%20%20qualifying_ab%20%3D%20int(season_games%20*%202.7)%0A%20%20%20%20batting.tail(20)%0A%20%20%20%20return%20batting%2C%20latest_year%2C%20qualifying_ab%0A%0A%0A%40app.cell%0Adef%20_(batting%2C%20mo)%3A%0A%20%20%20%20mo.md(f%22%22%22%0A%20%20%20%20**%E8%A1%8C%E6%95%B0**%3A%20%7Bbatting.height%3A%2C%7D%20%20%7C%20%20**%E5%88%97%E6%95%B0**%3A%20%7Bbatting.width%7D%0A%20%20%20%20%EF%BC%881%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%20%C3%97%201%E3%83%81%E3%83%BC%E3%83%A0%20%C3%97%201%E9%81%B8%E6%89%8B%20%3D%201%E8%A1%8C%EF%BC%89%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(batting%2C%20latest_year%2C%20mo)%3A%0A%20%20%20%20top_hr%20%3D%20(%0A%20%20%20%20%20%20%20%20batting.filter(batting%5B%22yearID%22%5D%20%3D%3D%20latest_year)%0A%20%20%20%20%20%20%20%20.sort(%22HR%22%2C%20descending%3DTrue)%0A%20%20%20%20%20%20%20%20.head(10)%0A%20%20%20%20%20%20%20%20.select(%5B%22playerID%22%2C%20%22teamID%22%2C%20%22G%22%2C%20%22AB%22%2C%20%22H%22%2C%20%22HR%22%2C%20%22RBI%22%2C%20%22BB%22%2C%20%22SO%22%5D)%0A%20%20%20%20)%0A%20%20%20%20mo.vstack(%5Bmo.md(f%22%23%23%23%20%E6%9C%AC%E5%A1%81%E6%89%93%E4%B8%8A%E4%BD%8D10%E5%90%8D%EF%BC%88%7Blatest_year%7D%E5%B9%B4%EF%BC%89%22)%2C%20top_hr%5D)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(alt%2C%20batting%2C%20pl)%3A%0A%20%20%20%20%23%20%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%E7%B7%8F%E6%9C%AC%E5%A1%81%E6%89%93%E6%95%B0%E3%81%AE%E6%8E%A8%E7%A7%BB%EF%BC%881960%E5%B9%B4%E3%80%9C%EF%BC%89%0A%20%20%20%20hr_trend%20%3D%20(%0A%20%20%20%20%20%20%20%20batting.filter(batting%5B%22yearID%22%5D%20%3E%3D%201960)%0A%20%20%20%20%20%20%20%20.group_by(%22yearID%22)%0A%20%20%20%20%20%20%20%20.agg(pl.col(%22HR%22).sum().alias(%22pl_HR%22))%0A%20%20%20%20%20%20%20%20.sort(%22yearID%22)%0A%20%20%20%20)%0A%20%20%20%20chart_hr%20%3D%20(%0A%20%20%20%20%20%20%20%20alt.Chart(hr_trend)%0A%20%20%20%20%20%20%20%20.mark_line(point%3DTrue)%0A%20%20%20%20%20%20%20%20.encode(%0A%20%20%20%20%20%20%20%20%20%20%20%20x%3Dalt.X(%22yearID%3AQ%22%2C%20title%3D%22%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%22)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20y%3Dalt.Y(%22pl_HR%3AQ%22%2C%20title%3D%22%E7%B7%8F%E6%9C%AC%E5%A1%81%E6%89%93%E6%95%B0%22)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20tooltip%3D%5B%22yearID%22%2C%20%22pl_HR%22%5D%2C%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.properties(%0A%20%20%20%20%20%20%20%20%20%20%20%20title%3D%22MLB%20%E3%82%B7%E3%83%BC%E3%82%BA%E3%83%B3%E7%B7%8F%E6%9C%AC%E5%A1%81%E6%89%93%E6%95%B0%E3%81%AE%E6%8E%A8%E7%A7%BB%EF%BC%881960%E5%B9%B4%E3%80%9C%EF%BC%89%22%2C%20width%3D640%2C%20height%3D300%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20)%0A%20%20%20%20chart_hr%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(batting%2C%20latest_year%2C%20pl%2C%20qualifying_ab)%3A%0A%20%20%20%20batting_avg%20%3D%20(%0A%20%20%20%20%20%20%20%20batting.filter(%0A%20%20%20%20%20%20%20%20%20%20%20%20(batting%5B%22yearID%22%5D%20%3D%3D%20latest_year)%20%26%20(batting%5B%22AB%22%5D%20%3E%3D%20qualifying_ab)%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.with_columns((pl.col(%22H%22)%20%2F%20pl.col(%22AB%22)).alias(%22AVG%22))%0A%20%20%20%20%20%20%20%20.sort(%22AVG%22%2C%20descending%3DTrue)%0A%20%20%20%20%20%20%20%20.head(10)%0A%20%20%20%20%20%20%20%20.select(%5B%22playerID%22%2C%20%22teamID%22%2C%20%22AB%22%2C%20%22H%22%2C%20%22HR%22%2C%20%22AVG%22%5D)%0A%20%20%20%20)%0A%0A%20%20%20%20batting_avg%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(%22%22%22%0A%20%20%20%20%23%23%202.%20FanGraphs%EF%BC%88%E7%8F%BE%E5%9C%A8%E3%82%A2%E3%82%AF%E3%82%BB%E3%82%B9%E4%B8%8D%E5%8F%AF%EF%BC%89%0A%0A%20%20%20%20%E5%8E%9F%E8%91%97%E3%81%A7%E3%81%AF%20FanGraphs%20%E3%81%8B%E3%82%89%20wRC%2B%E3%83%BBwOBA%E3%83%BBWAR%20%E3%81%AA%E3%81%A9%E3%81%AE%E3%82%BB%E3%82%A4%E3%83%90%E3%83%BC%E3%83%A1%E3%83%88%E3%83%AA%E3%82%AF%E3%82%B9%E6%8C%87%E6%A8%99%E3%82%92%E5%8F%96%E5%BE%97%E3%81%97%E3%81%A6%E3%81%84%E3%82%8B%E3%80%82%0A%20%20%20%20%E3%81%9F%E3%81%A0%E3%81%97%202025%E5%B9%B4%E6%99%82%E7%82%B9%E3%81%A7%20%60pybaseball.batting_stats()%60%20%E3%81%8C%20FanGraphs%20%E3%81%AE%0A%20%20%20%20%60leaders-legacy.aspx%60%20%E3%82%A8%E3%83%B3%E3%83%89%E3%83%9D%E3%82%A4%E3%83%B3%E3%83%88%E3%81%8B%E3%82%89%20**HTTP%20403**%20%E3%82%92%E5%8F%97%E3%81%91%E5%8F%96%E3%82%8B%E3%81%9F%E3%82%81%E5%88%A9%E7%94%A8%E4%B8%8D%E5%8F%AF%E3%80%82%0A%20%20%20%20pybaseball%202.2.7%20%E3%81%8C%E6%9C%80%E6%96%B0%E7%89%88%E3%81%A0%E3%81%8C%E6%9C%AA%E4%BF%AE%E6%AD%A3%E3%80%82%0A%0A%20%20%20%20%E4%BB%A3%E6%9B%BF%E3%81%A8%E3%81%97%E3%81%A6%20Lahman%20%E3%81%AE%E7%94%9F%E3%83%87%E3%83%BC%E3%82%BF%E3%81%8B%E3%82%89%20OBP%E3%83%BBSLG%E3%83%BBOPS%20%E3%82%92%E8%87%AA%E5%89%8D%E8%A8%88%E7%AE%97%E3%81%99%E3%82%8B%E3%80%82%0A%0A%20%20%20%20%7C%20%E6%8C%87%E6%A8%99%20%7C%20%E8%A8%88%E7%AE%97%E5%BC%8F%20%7C%0A%20%20%20%20%7C---%7C---%7C%0A%20%20%20%20%7C%20%60OBP%60%20%7C%20(H%20%2B%20BB%20%2B%20HBP)%20%2F%20(AB%20%2B%20BB%20%2B%20HBP%20%2B%20SF)%20%7C%0A%20%20%20%20%7C%20%60SLG%60%20%7C%20(1B%20%2B%202%C3%972B%20%2B%203%C3%973B%20%2B%204%C3%97HR)%20%2F%20AB%E3%80%80%E2%80%BB%201B%20%3D%20H%20%E2%88%92%202B%20%E2%88%92%203B%20%E2%88%92%20HR%20%7C%0A%20%20%20%20%7C%20%60OPS%60%20%7C%20OBP%20%2B%20SLG%20%7C%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(batting%2C%20latest_year%2C%20pl%2C%20qualifying_ab)%3A%0A%20%20%20%20ops_stats%20%3D%20(%0A%20%20%20%20%20%20%20%20batting.filter(%0A%20%20%20%20%20%20%20%20%20%20%20%20(batting%5B%22yearID%22%5D%20%3D%3D%20latest_year)%20%26%20(pl.col(%22AB%22)%20%3E%3D%20qualifying_ab)%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.with_columns(%0A%20%20%20%20%20%20%20%20%20%20%20%20%5B%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20(pl.col(%22H%22)%20%2B%20pl.col(%22BB%22)%20%2B%20pl.col(%22HBP%22).fill_null(0))%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%2F%20(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20pl.col(%22AB%22)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%2B%20pl.col(%22BB%22)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%2B%20pl.col(%22HBP%22).fill_null(0)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%2B%20pl.col(%22SF%22).fill_null(0)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20).alias(%22OBP%22)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%23%20SLG%20%3D%20Total%20Bases%20%2F%20AB%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%23%20H%20%E3%81%A7%E5%85%A8%E3%83%92%E3%83%83%E3%83%88%E3%82%921%E5%A1%81%E5%88%86%E8%A8%88%E4%B8%8A%E6%B8%88%E3%81%BF%E3%81%AA%E3%81%AE%E3%81%A7%E8%BF%BD%E5%8A%A0%E5%A1%81%E6%95%B0%E3%81%A0%E3%81%91%E8%B6%B3%E3%81%99%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%23%20(2B%3A%2B1%2C%203B%3A%2B2%2C%20HR%3A%2B3)%20%E2%89%A1%201B%20%2B%202%C3%972B%20%2B%203%C3%973B%20%2B%204%C3%97HR%20%E3%82%92%E5%B1%95%E9%96%8B%E3%81%97%E3%81%9F%E5%BD%A2%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20(pl.col(%22H%22)%20%2B%20pl.col(%222B%22)%20%2B%202%20*%20pl.col(%223B%22)%20%2B%203%20*%20pl.col(%22HR%22))%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%2F%20pl.col(%22AB%22)%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20).alias(%22SLG%22)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%5D%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.with_columns((pl.col(%22OBP%22)%20%2B%20pl.col(%22SLG%22)).alias(%22OPS%22))%0A%20%20%20%20%20%20%20%20.sort(%22OPS%22%2C%20descending%3DTrue)%0A%20%20%20%20%20%20%20%20.head(20)%0A%20%20%20%20%20%20%20%20.select(%5B%22playerID%22%2C%20%22teamID%22%2C%20%22AB%22%2C%20%22H%22%2C%20%22HR%22%2C%20%22OBP%22%2C%20%22SLG%22%2C%20%22OPS%22%5D)%0A%20%20%20%20)%0A%20%20%20%20ops_stats%0A%20%20%20%20return%20(ops_stats%2C)%0A%0A%0A%40app.cell%0Adef%20_(alt%2C%20ops_stats)%3A%0A%20%20%20%20%23%20OBP%20vs%20SLG%20%E3%81%AE%E6%95%A3%E5%B8%83%E5%9B%B3%EF%BC%88HR%20%E3%81%A7%E3%82%AB%E3%83%A9%E3%83%BC%EF%BC%89%0A%20%20%20%20scatter_ops%20%3D%20(%0A%20%20%20%20%20%20%20%20alt.Chart(ops_stats)%0A%20%20%20%20%20%20%20%20.mark_circle(size%3D80%2C%20opacity%3D0.7)%0A%20%20%20%20%20%20%20%20.encode(%0A%20%20%20%20%20%20%20%20%20%20%20%20x%3Dalt.X(%22OBP%3AQ%22%2C%20title%3D%22%E5%87%BA%E5%A1%81%E7%8E%87%20(OBP)%22%2C%20scale%3Dalt.Scale(zero%3DFalse))%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20y%3Dalt.Y(%22SLG%3AQ%22%2C%20title%3D%22%E9%95%B7%E6%89%93%E7%8E%87%20(SLG)%22%2C%20scale%3Dalt.Scale(zero%3DFalse))%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20color%3Dalt.Color(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%22HR%3AQ%22%2C%20scale%3Dalt.Scale(scheme%3D%22orangered%22)%2C%20title%3D%22%E6%9C%AC%E5%A1%81%E6%89%93%22%0A%20%20%20%20%20%20%20%20%20%20%20%20)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20tooltip%3D%5B%22playerID%22%2C%20%22teamID%22%2C%20%22OBP%22%2C%20%22SLG%22%2C%20%22OPS%22%2C%20%22HR%22%5D%2C%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.properties(title%3D%22%E5%87%BA%E5%A1%81%E7%8E%87%20vs%20%E9%95%B7%E6%89%93%E7%8E%87%EF%BC%88%E8%A6%8F%E5%AE%9A%E6%89%93%E5%B8%AD%E4%BB%A5%E4%B8%8A%EF%BC%89%22%2C%20width%3D520%2C%20height%3D360)%0A%20%20%20%20%20%20%20%20.interactive()%0A%20%20%20%20)%0A%20%20%20%20scatter_ops%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(%22%22%22%0A%20%20%20%20%23%23%203.%20Statcast%0A%0A%20%20%20%202015%E5%B9%B4%E3%81%8B%E3%82%89%20MLB%20%E5%85%A8%E7%90%83%E5%A0%B4%E3%81%AB%E8%A8%AD%E7%BD%AE%E3%81%95%E3%82%8C%E3%81%9F%E3%83%88%E3%83%A9%E3%83%83%E3%82%AD%E3%83%B3%E3%82%B0%E3%82%B7%E3%82%B9%E3%83%86%E3%83%A0%E3%80%82%0A%20%20%20%20%E6%8A%95%E7%90%83%E3%83%BB%E6%89%93%E7%90%83%E3%81%AE%E7%89%A9%E7%90%86%E9%87%8F%E3%82%92%E3%83%94%E3%83%83%E3%83%81%E5%8D%98%E4%BD%8D%E3%81%A7%E8%A8%98%E9%8C%B2%E3%81%99%E3%82%8B%E3%80%82%0A%0A%20%20%20%20%7C%20%E5%88%97%20%7C%20%E8%AA%AC%E6%98%8E%20%7C%0A%20%20%20%20%7C---%7C---%7C%0A%20%20%20%20%7C%20%60pitch_type%60%20%7C%20%E7%90%83%E7%A8%AE%EF%BC%88FF%3D4%E3%82%B7%E3%83%BC%E3%83%A0%E3%80%81SL%3D%E3%82%B9%E3%83%A9%E3%82%A4%E3%83%80%E3%83%BC%E3%80%81CH%3D%E3%83%81%E3%82%A7%E3%83%B3%E3%82%B8%E3%82%A2%E3%83%83%E3%83%97%E2%80%A6%EF%BC%89%20%7C%0A%20%20%20%20%7C%20%60release_speed%60%20%7C%20%E7%90%83%E9%80%9F%20(mph)%20%7C%0A%20%20%20%20%7C%20%60release_spin_rate%60%20%7C%20%E5%9B%9E%E8%BB%A2%E6%95%B0%20(rpm)%20%7C%0A%20%20%20%20%7C%20%60launch_speed%60%20%7C%20%E6%89%93%E7%90%83%E5%88%9D%E9%80%9F%20(mph)%20%7C%0A%20%20%20%20%7C%20%60launch_angle%60%20%7C%20%E6%89%93%E7%90%83%E8%A7%92%E5%BA%A6%20(%C2%B0)%20%7C%0A%20%20%20%20%7C%20%60hit_distance_sc%60%20%7C%20%E6%89%93%E7%90%83%E8%B7%9D%E9%9B%A2%20(ft)%20%7C%0A%20%20%20%20%7C%20%60events%60%20%7C%20%E6%89%93%E5%B8%AD%E7%B5%90%E6%9E%9C%EF%BC%88home_run%2C%20strikeout%2C%20%E2%80%A6%EF%BC%89%20%7C%0A%0A%20%20%20%20%3E%20**%E6%B3%A8%E6%84%8F**%3A%20Statcast%20%E3%81%AF1%E6%97%A5%E5%88%86%E3%81%A7%E3%82%82%E6%95%B0%E5%8D%83%E8%A1%8C%E3%81%82%E3%82%8B%E3%81%9F%E3%82%81%E3%80%81%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%E3%81%A8%E3%81%97%E3%81%A61%E6%97%A5%E3%82%92%E5%8F%96%E5%BE%97%E3%81%99%E3%82%8B%E3%80%82%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(load_statcast)%3A%0A%20%20%20%20statcast%20%3D%20load_statcast(%222023-07-04%22%2C%20%222023-07-04%22)%0A%20%20%20%20statcast.select(%0A%20%20%20%20%20%20%20%20%5B%0A%20%20%20%20%20%20%20%20%20%20%20%20%22player_name%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22pitch_type%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22release_speed%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22release_spin_rate%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22launch_speed%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22launch_angle%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%22events%22%2C%0A%20%20%20%20%20%20%20%20%5D%0A%20%20%20%20).drop_nulls(subset%3D%5B%22pitch_type%22%5D).head(20)%0A%20%20%20%20return%20(statcast%2C)%0A%0A%0A%40app.cell%0Adef%20_(mo%2C%20statcast)%3A%0A%20%20%20%20mo.md(f%22%22%22%0A%20%20%20%20**%E8%A1%8C%E6%95%B0%EF%BC%88%E6%8A%95%E7%90%83%E6%95%B0%EF%BC%89**%3A%20%7Bstatcast.height%3A%2C%7D%20%20%7C%20%20**%E5%88%97%E6%95%B0**%3A%20%7Bstatcast.width%7D%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(alt%2C%20pl%2C%20statcast)%3A%0A%20%20%20%20%23%20%E7%90%83%E7%A8%AE%E5%88%A5%20%E7%90%83%E9%80%9F%E5%88%86%E5%B8%83%0A%20%20%20%20sc_pitch%20%3D%20statcast.filter(%0A%20%20%20%20%20%20%20%20pl.col(%22pitch_type%22).is_not_null()%20%26%20pl.col(%22release_speed%22).is_not_null()%0A%20%20%20%20).filter(pl.col(%22pitch_type%22).is_in(%5B%22FF%22%2C%20%22SL%22%2C%20%22CH%22%2C%20%22CU%22%2C%20%22SI%22%2C%20%22FC%22%5D))%0A%20%20%20%20chart_speed%20%3D%20(%0A%20%20%20%20%20%20%20%20alt.Chart(sc_pitch.select(%5B%22pitch_type%22%2C%20%22release_speed%22%5D))%0A%20%20%20%20%20%20%20%20.mark_boxplot()%0A%20%20%20%20%20%20%20%20.encode(%0A%20%20%20%20%20%20%20%20%20%20%20%20x%3Dalt.X(%22pitch_type%3AN%22%2C%20title%3D%22%E7%90%83%E7%A8%AE%22)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20y%3Dalt.Y(%22release_speed%3AQ%22%2C%20title%3D%22%E7%90%83%E9%80%9F%20(mph)%22%2C%20scale%3Dalt.Scale(zero%3DFalse))%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20color%3D%22pitch_type%3AN%22%2C%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.properties(title%3D%22%E7%90%83%E7%A8%AE%E5%88%A5%20%E7%90%83%E9%80%9F%E5%88%86%E5%B8%83%EF%BC%882023-07-04%EF%BC%89%22%2C%20width%3D500%2C%20height%3D300)%0A%20%20%20%20)%0A%20%20%20%20chart_speed%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(alt%2C%20pl%2C%20statcast)%3A%0A%20%20%20%20%23%20%E6%89%93%E7%90%83%3A%20launch_speed%20vs%20launch_angle%EF%BC%88%E6%9C%AC%E5%A1%81%E6%89%93%E3%81%AE%E3%81%BF%E5%BC%B7%E8%AA%BF%EF%BC%89%0A%20%20%20%20hits%20%3D%20statcast.filter(%0A%20%20%20%20%20%20%20%20pl.col(%22launch_speed%22).is_not_null()%20%26%20pl.col(%22launch_angle%22).is_not_null()%0A%20%20%20%20).with_columns(%0A%20%20%20%20%20%20%20%20pl.when(pl.col(%22events%22)%20%3D%3D%20%22home_run%22)%0A%20%20%20%20%20%20%20%20.then(pl.lit(%22%E6%9C%AC%E5%A1%81%E6%89%93%22))%0A%20%20%20%20%20%20%20%20.otherwise(pl.lit(%22%E3%81%9D%E3%81%AE%E4%BB%96%22))%0A%20%20%20%20%20%20%20%20.alias(%22is_hr%22)%0A%20%20%20%20)%0A%20%20%20%20chart_la%20%3D%20(%0A%20%20%20%20%20%20%20%20alt.Chart(%0A%20%20%20%20%20%20%20%20%20%20%20%20hits.select(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%5B%22player_name%22%2C%20%22events%22%2C%20%22launch_speed%22%2C%20%22launch_angle%22%2C%20%22is_hr%22%5D%0A%20%20%20%20%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.mark_circle(opacity%3D0.5%2C%20size%3D30)%0A%20%20%20%20%20%20%20%20.encode(%0A%20%20%20%20%20%20%20%20%20%20%20%20x%3Dalt.X(%22launch_speed%3AQ%22%2C%20title%3D%22%E6%89%93%E7%90%83%E5%88%9D%E9%80%9F%20(mph)%22)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20y%3Dalt.Y(%22launch_angle%3AQ%22%2C%20title%3D%22%E6%89%93%E7%90%83%E8%A7%92%E5%BA%A6%20(%C2%B0)%22)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20color%3Dalt.Color(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%22is_hr%3AN%22%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20scale%3Dalt.Scale(%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20domain%3D%5B%22%E6%9C%AC%E5%A1%81%E6%89%93%22%2C%20%22%E3%81%9D%E3%81%AE%E4%BB%96%22%5D%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20range%3D%5B%22%23e74c3c%22%2C%20%22%23aaa%22%5D%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20%20)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20)%2C%0A%20%20%20%20%20%20%20%20%20%20%20%20tooltip%3D%5B%22player_name%22%2C%20%22events%22%2C%20%22launch_speed%22%2C%20%22launch_angle%22%5D%2C%0A%20%20%20%20%20%20%20%20)%0A%20%20%20%20%20%20%20%20.properties(title%3D%22%E6%89%93%E7%90%83%E5%88%9D%E9%80%9F%20vs%20%E6%89%93%E7%90%83%E8%A7%92%E5%BA%A6%EF%BC%882023-07-04%EF%BC%89%22%2C%20width%3D580%2C%20height%3D350)%0A%20%20%20%20%20%20%20%20.interactive()%0A%20%20%20%20)%0A%20%20%20%20chart_la%0A%20%20%20%20return%0A%0A%0A%40app.cell%0Adef%20_(mo)%3A%0A%20%20%20%20mo.md(%22%22%22%0A%20%20%20%20%23%23%20%E3%81%BE%E3%81%A8%E3%82%81%0A%0A%20%20%20%20%7C%20%E3%83%87%E3%83%BC%E3%82%BF%E3%82%BD%E3%83%BC%E3%82%B9%20%7C%20%E5%8F%96%E5%BE%97%E9%96%A2%E6%95%B0%20%7C%20%E7%94%A8%E9%80%94%20%7C%0A%20%20%20%20%7C---%7C---%7C---%7C%0A%20%20%20%20%7C%20Lahman%20batting%20%7C%20%60load_lahman_batting()%60%20%7C%20%E9%81%B8%E6%89%8B%E3%81%AE%E9%95%B7%E6%9C%9F%E3%83%88%E3%83%AC%E3%83%B3%E3%83%89%E5%88%86%E6%9E%90%20%7C%0A%20%20%20%20%7C%20Lahman%20people%20%7C%20%60load_lahman_people()%60%20%7C%20%E9%81%B8%E6%89%8B%E5%90%8D%E3%83%BB%E7%94%9F%E5%B9%B4%E6%9C%88%E6%97%A5%20%7C%0A%20%20%20%20%7C%20FanGraphs%20%7C%20%60load_fangraphs_batting(year)%60%20%7C%20%E9%AB%98%E5%BA%A6%E3%81%AA%E3%82%BB%E3%82%A4%E3%83%90%E3%83%BC%E3%83%A1%E3%83%88%E3%83%AA%E3%82%AF%E3%82%B9%E6%8C%87%E6%A8%99%20%7C%0A%20%20%20%20%7C%20Statcast%20%7C%20%60load_statcast(start%2C%20end)%60%20%7C%20%E6%8A%95%E7%90%83%E3%83%BB%E6%89%93%E7%90%83%E3%81%AE%E7%89%A9%E7%90%86%E9%87%8F%E5%88%86%E6%9E%90%20%7C%0A%0A%20%20%20%20%E6%AC%A1%E7%AB%A0%E4%BB%A5%E9%99%8D%E3%81%A7%E3%81%AF%E3%80%81%E3%81%93%E3%82%8C%E3%82%89%E3%81%AE%E3%83%87%E3%83%BC%E3%82%BF%E3%82%92%E7%B5%84%E3%81%BF%E5%90%88%E3%82%8F%E3%81%9B%E3%81%A6%E3%82%88%E3%82%8A%E6%B7%B1%E3%81%84%E5%88%86%E6%9E%90%E3%82%92%E8%A1%8C%E3%81%86%E3%80%82%0A%20%20%20%20%22%22%22)%0A%20%20%20%20return%0A%0A%0Aif%20__name__%20%3D%3D%20%22__main__%22%3A%0A%20%20%20%20app.run()%0A
210f06fdddc140c06d2462f6a55ee1a8