Platform
Solutions
Resources
Pricing
Sign in
Sign up
John Alexis Guerra Gómez
I love to build dataviz for insight discovery. I also love to put technology to the service of humanity
Workspace
Fork
Public
By
John Alexis Guerra Gómez
Edited
Jul 27, 2024
BSD 3-Clause
Fork of
Hello, Reorder.js
•
1 fork
Importers
5 stars
2
Insert cell
Insert cell
Insert cell
Insert cell
Insert cell
orderGraph
=
(
{
nodes
,
links
}
,
{
distance
=
"manhattan"
,
ordering
=
"leafOrder"
,
id
=
null
}
=
{
}
)
=>
{
const
n
=
nodes
.
length
;
if
(
id
)
{
links
=
convertLinksToIndexes
(
{
nodes
,
links
}
,
{
id
}
)
;
}
// console.log("links after 👏🏼", links);
const
graph
=
reorder
.
graph
(
)
.
nodes
(
nodes
)
.
links
(
links
)
.
init
(
)
;
let
dist_adjacency
;
const
leafOrder
=
reorder
.
optimal_leaf_order
(
)
.
distance
(
reorder
.
distance
[
distance
]
)
;
function
computeLeaforder
(
)
{
const
adjacency
=
reorder
.
graph2mat
(
graph
)
;
return
leafOrder
(
adjacency
)
;
}
function
computeLeaforderDist
(
)
{
if
(
!
dist_adjacency
)
dist_adjacency
=
reorder
.
graph2valuemats
(
graph
)
;
return
reorder
.
valuemats_reorder
(
dist_adjacency
,
leafOrder
)
;
}
function
computeBarycenter
(
)
{
const
barycenter
=
reorder
.
barycenter_order
(
graph
)
;
return
reorder
.
adjacent_exchange
(
graph
,
...
barycenter
)
;
}
function
computeRCM
(
)
{
return
reorder
.
reverse_cuthill_mckee_order
(
graph
)
;
}
function
computeSpectral
(
)
{
return
reorder
.
spectral_order
(
graph
)
;
}
switch
(
ordering
)
{
case
"leafOrder"
:
return
computeLeaforder
(
)
;
case
"leafOrderDist"
:
return
computeLeaforderDist
(
)
;
case
"barycenter"
:
return
computeBarycenter
(
)
;
case
"rcm"
:
return
computeRCM
(
)
;
case
"spectral"
:
return
computeSpectral
(
)
;
default
:
return
computeLeaforder
(
)
;
}
}
Insert cell
current
=
setup
.
update
(
orderGraph
(
graph
,
{
distance
,
ordering
:
sorting
}
)
)
Insert cell
// note: here the graph expect source and target to be 0-based and correspond to existing nodes.
graph
=
FileAttachment
(
"miserables.json"
)
.
json
(
)
Insert cell
function
orderMatrix
(
matrix
)
{
const
before
=
performance
.
now
(
)
;
const
transpose
=
reorder
.
transpose
(
matrix
)
;
console
.
log
(
"transpose"
,
performance
.
now
(
)
-
before
)
;
const
dist_rows
=
reorder
.
dist
(
)
(
matrix
)
;
console
.
log
(
"dist_rows"
,
performance
.
now
(
)
-
before
)
;
const
dist_cols
=
reorder
.
dist
(
)
(
transpose
)
;
console
.
log
(
"dist_cols"
,
performance
.
now
(
)
-
before
)
;
const
order
=
reorder
.
optimal_leaf_order
(
)
;
console
.
log
(
"order"
,
performance
.
now
(
)
-
before
)
;
const
row_perm
=
order
.
distanceMatrix
(
dist_rows
)
(
matrix
)
;
console
.
log
(
"row_perm"
,
performance
.
now
(
)
-
before
)
;
const
col_perm
=
order
.
distanceMatrix
(
dist_cols
)
(
transpose
)
;
console
.
log
(
"col_perm"
,
performance
.
now
(
)
-
before
)
;
return
{
row_perm
,
col_perm
}
;
}
Insert cell
toyMatrix
=
[
[
1
,
0
,
0
,
0
,
1
,
0
,
0
,
0
]
,
[
0
,
1
,
1
,
0
,
0
,
1
,
0
,
1
]
,
[
0
,
1
,
1
,
0
,
1
,
0
,
0
,
0
]
,
[
0
,
0
,
0
,
1
,
0
,
0
,
1
,
0
]
,
[
1
,
0
,
1
,
0
,
1
,
0
,
0
,
0
]
,
[
0
,
1
,
0
,
0
,
0
,
1
,
0
,
1
]
,
[
0
,
0
,
0
,
1
,
0
,
0
,
1
,
0
]
,
[
0
,
1
,
0
,
0
,
0
,
1
,
0
,
1
]
]
Insert cell
orderMatrix
(
toyMatrix
)
Insert cell
orderingsOptions
=
[
"leafOrder"
,
"leafOrderDist"
,
"barycenter"
,
"rcm"
,
"spectral"
]
Insert cell
distanceOptions
=
(
{
euclidean
:
"Euclidean (L2) distance."
,
manhattan
:
"Manhattan (L1) distance."
,
minkowski
:
"Minkowski distance."
,
chebyshev
:
"Chebyshev distance."
,
hamming
:
"Hamming distance."
,
jaccard
:
"Jaccard distance."
,
braycurtis
:
"Braycurtis distance."
}
)
Insert cell
reorder
=
require
(
"reorder.js@2.2.4"
)
Insert cell
function
tableToMatrix
(
data
)
{
// Get quantitative attributes
const
cols
=
Object
.
keys
(
data
[
0
]
)
.
filter
(
(
c
)
=>
!
isNaN
(
data
[
0
]
[
c
]
)
)
;
const
catMatrix
=
data
.
map
(
(
v
)
=>
cols
.
map
(
(
c
)
=>
v
[
c
]
)
)
;
// Array.from(d3.group(dataAsMatrix.flat(), d => d).keys())
catMatrix
.
columns
=
cols
;
return
catMatrix
;
}
Insert cell
import
{
convertLinksToIndexes
}
from
"@john-guerra/network-utilities"
Insert cell
{
const
before
=
performance
.
now
(
)
;
const
res
=
orderMatrix
(
fifaMatrix
)
;
mutable
time
=
performance
.
now
(
)
-
before
;
return
res
;
}
Insert cell
mutable
time
=
null
;
Insert cell
fifaData
=
FileAttachment
(
"fifaData.csv.zip"
)
.
zip
(
)
.
then
(
res
=>
res
.
file
(
"fifaData.csv"
)
.
csv
(
{
typed
:
true
}
)
)
Insert cell
fifaMatrix
=
tableToMatrix
(
fifaData
.
slice
(
0
,
20
)
)
Insert cell
Insert cell
One platform
to build and deploy the best data apps
Experiment and prototype by building visualizations in live JavaScript notebooks. Collaborate with your team and decide which concepts to build out.
Use Observable Framework to build data apps locally. Use data loaders to build in any language or library, including Python, SQL, and R.
Seamlessly deploy to Observable. Test before you ship, use automatic deploy-on-commit, and ensure your projects are always up-to-date.
Try it for free
Learn more
Compare fork
Fork
View
Export
Edit
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
sorting
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
distance
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
setup
Edit
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
orderGraph
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
current
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
graph
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
orderMatrix
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
toyMatrix
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
Add comment
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
orderingsOptions
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
distanceOptions
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
reorder
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
tableToMatrix
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
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
time
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
fifaData
Add comment
Copy import
Select
Duplicate
Copy link
Embed
Delete
JavaScript
Markdown
HTML
fifaMatrix
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