Platform
Resources
Pricing
Sign in
Get started
julesallegre
Workspace
Fork
Published
Sports
By
julesallegre
Edited
Jul 24, 2020
3 stars
4
Sports
NBA Player Shot Charts
Plot: LeBron James’ shots
U.S. Major League Sports Teams
Which NBA Basketball Team is ACTUALLY the GOAT?
Shortest F1 Races by Distance
IMSA 2022 Championship Race Durations
Is Connor McDavid Really THAT Good?
World Stadium Location Visualization Tutorial
Custom Match Picture Generator
Worldcup 2022 visualisation
Results of international football matches from 1872 to 2021
FIFA World Cups, 1930 - 2018
NBA Referee Movement
Zones data visualisation from conflict zone model: soccer application
Visualising and Quantifying Space Control in Soccer
Bump Charts: English Premier League
Visualizing Running - Part I
Visualizing Running - Splits
Watch the NBA Finals Players Data Jam on Observable
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
spreadFactor
=
match
==
"Liverpool [2] - 1 Newcastle"
?
5
:
3
;
Insert cell
widthA
=
MZ
.
length
*
spreadFactor
+
marginA
.
left
+
marginA
.
right
Insert cell
heightA
=
MZ
[
0
]
.
length
*
50
+
marginA
.
top
+
marginA
.
bottom
Insert cell
marginA
=
(
{
left
:
25
,
right
:
25
,
top
:
25
,
bottom
:
50
}
)
Insert cell
dataMatch
=
rawData
.
filter
(
object
=>
object
.
play
==
match
)
Insert cell
getFrame
=
(
dataMatch
,
n_frame
)
=>
{
let
temp
=
[
...
dataMatch
.
filter
(
object
=>
parseFloat
(
object
.
frame
)
==
n_frame
)
]
;
temp
.
forEach
(
(
A
,
i
)
=>
{
let
B
=
Object
.
assign
(
{
}
,
A
)
;
B
.
y
=
100
-
B
.
y
;
B
.
dy
=
-
B
.
dy
;
temp
[
i
]
=
B
;
}
)
return
temp
;
}
Insert cell
frame
=
getFrame
(
dataMatch
,
n_frame
)
Insert cell
Agents
=
frameToAgent
(
frame
)
;
Insert cell
rawData
=
d3
.
csv
(
"https://raw.githubusercontent.com/Friends-of-Tracking-Data-FoTD/Last-Row/master/datasets/positional_data/liverpool_2019.csv"
)
;
Insert cell
d3
=
require
(
'd3'
,
'd3-polygon'
)
Insert cell
textures
=
require
(
'textures@1.2.0/dist/textures.js'
)
Insert cell
embed
=
require
(
"vega-embed@6"
)
Insert cell
import
{
multipleZones2
,
getNodes
,
timeNodes
,
drawZone
,
barycenter
}
from
'@julesallegre/conflict-zone-model'
Insert cell
import
{
frameToAgent
,
innerSize
,
width
,
height
}
from
'@julesallegre/conflict-zone-model-soccer-application'
Insert cell
import
{
drawfield
,
drawPlayer
,
margin
,
addSpeedPlayer
,
line
,
xReal
,
yReal
,
closer
,
posX
,
posY
}
from
'@julesallegre/liverpool-goal-2019'
Insert cell
import
{
checkbox
,
select
}
from
"@jashkenas/inputs"
;
Insert cell
import
{
Scrubber
}
from
"@mbostock/scrubber"
Insert cell
import
{
vl
}
from
'@vega/vega-lite-api'
Insert cell
Purpose-built for displays of data
Observable is your go-to platform for exploring data and creating expressive data visualizations. Use reactive JavaScript notebooks for prototyping and a collaborative canvas for visual data exploration and dashboard creation.
Try it for free
Learn more
Fork
View
Export
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
match
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
n_frame
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
opts
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
plot
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
drawTimeLine
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
idx
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
areas
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
multipleZonesArea
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
owners
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
getOwners
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
drawOwners
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
rel
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
view
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
timeline
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
getSpeed
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
dSpeed
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
drawTrajPlayer
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
trajPlayer
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
nameFile
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
MZ
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
combi
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
indexlist
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
spreadFactor
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
widthA
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
heightA
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
marginA
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
dataMatch
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
getFrame
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
frame
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Agents
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
rawData
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
d3
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
textures
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
embed
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML