Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
haskell-gargantext
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
153
Issues
153
List
Board
Labels
Milestones
Merge Requests
9
Merge Requests
9
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
gargantext
haskell-gargantext
Commits
ebcee352
Commit
ebcee352
authored
Sep 26, 2022
by
qlobbe
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
still refactoring
parent
8790c9de
Pipeline
#3212
failed with stage
in 72 minutes and 40 seconds
Changes
6
Pipelines
1
Expand all
Show whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
127 additions
and
88 deletions
+127
-88
Main.hs
bin/gargantext-phylo/Main.hs
+5
-5
Phylo.hs
src/Gargantext/Core/Viz/Phylo.hs
+9
-19
PhyloExport.hs
src/Gargantext/Core/Viz/Phylo/PhyloExport.hs
+6
-6
PhyloTools.hs
src/Gargantext/Core/Viz/Phylo/PhyloTools.hs
+33
-14
SynchronicClustering.hs
src/Gargantext/Core/Viz/Phylo/SynchronicClustering.hs
+2
-2
TemporalMatching.hs
src/Gargantext/Core/Viz/Phylo/TemporalMatching.hs
+72
-42
No files found.
bin/gargantext-phylo/Main.hs
View file @
ebcee352
...
@@ -153,9 +153,9 @@ seaToLabel config = case (seaElevation config) of
...
@@ -153,9 +153,9 @@ seaToLabel config = case (seaElevation config) of
sensToLabel
::
PhyloConfig
->
[
Char
]
sensToLabel
::
PhyloConfig
->
[
Char
]
sensToLabel
config
=
case
(
phyloProximity
config
)
of
sensToLabel
config
=
case
(
phyloProximity
config
)
of
Hamming
_
->
undefined
Hamming
_
_
->
undefined
WeightedLogJaccard
s
->
(
"WeightedLogJaccard_"
<>
show
s
)
WeightedLogJaccard
s
_
->
(
"WeightedLogJaccard_"
<>
show
s
)
WeightedLogSim
s
->
(
"WeightedLogSim-sens_"
<>
show
s
)
WeightedLogSim
s
_
->
(
"WeightedLogSim-sens_"
<>
show
s
)
cliqueToLabel
::
PhyloConfig
->
[
Char
]
cliqueToLabel
::
PhyloConfig
->
[
Char
]
...
@@ -196,11 +196,11 @@ configToSha stage config = unpack
...
@@ -196,11 +196,11 @@ configToSha stage config = unpack
where
where
label
::
[
Char
]
label
::
[
Char
]
label
=
case
stage
of
label
=
case
stage
of
p
hyloWithoutLink
->
(
corpusPath
config
)
BackupP
hyloWithoutLink
->
(
corpusPath
config
)
<>
(
listPath
config
)
<>
(
listPath
config
)
<>
(
timeToLabel
config
)
<>
(
timeToLabel
config
)
<>
(
cliqueToLabel
config
)
<>
(
cliqueToLabel
config
)
p
hylo
->
(
corpusPath
config
)
BackupP
hylo
->
(
corpusPath
config
)
<>
(
listPath
config
)
<>
(
listPath
config
)
<>
(
timeToLabel
config
)
<>
(
timeToLabel
config
)
<>
(
cliqueToLabel
config
)
<>
(
cliqueToLabel
config
)
...
...
src/Gargantext/Core/Viz/Phylo.hs
View file @
ebcee352
...
@@ -73,23 +73,13 @@ instance ToSchema SeaElevation
...
@@ -73,23 +73,13 @@ instance ToSchema SeaElevation
data
Proximity
=
data
Proximity
=
WeightedLogJaccard
WeightedLogJaccard
{
_wlj_sensibility
::
Double
{
_wlj_sensibility
::
Double
{-
,
_wlj_minSharedNgrams
::
Int
}
-- , _wlj_thresholdInit :: Double
-- , _wlj_thresholdStep :: Double
-- | max height for sea level in temporal matching
-- , _wlj_elevation :: Double
-}
}
|
WeightedLogSim
|
WeightedLogSim
{
_wlj_sensibility
::
Double
{
_wls_sensibility
::
Double
{-
,
_wls_minSharedNgrams
::
Int
}
-- , _wlj_thresholdInit :: Double
|
Hamming
-- , _wlj_thresholdStep :: Double
{
_hmg_sensibility
::
Double
-- | max height for sea level in temporal matching
,
_hmg_minSharedNgrams
::
Int
}
-- , _wlj_elevation :: Double
-}
}
|
Hamming
{
_wlj_sensibility
::
Double
}
deriving
(
Show
,
Generic
,
Eq
)
deriving
(
Show
,
Generic
,
Eq
)
...
@@ -214,7 +204,7 @@ data PhyloSubConfig =
...
@@ -214,7 +204,7 @@ data PhyloSubConfig =
subConfig2config
::
PhyloSubConfig
->
PhyloConfig
subConfig2config
::
PhyloSubConfig
->
PhyloConfig
subConfig2config
subConfig
=
defaultConfig
{
phyloProximity
=
WeightedLogJaccard
$
_sc_phyloProximity
subConfig
subConfig2config
subConfig
=
defaultConfig
{
phyloProximity
=
WeightedLogJaccard
(
_sc_phyloProximity
subConfig
)
1
,
phyloSynchrony
=
ByProximityThreshold
(
_sc_phyloSynchrony
subConfig
)
0
AllBranches
MergeAllGroups
,
phyloSynchrony
=
ByProximityThreshold
(
_sc_phyloSynchrony
subConfig
)
0
AllBranches
MergeAllGroups
,
phyloQuality
=
Quality
(
_sc_phyloQuality
subConfig
)
1
,
phyloQuality
=
Quality
(
_sc_phyloQuality
subConfig
)
1
,
timeUnit
=
_sc_timeUnit
subConfig
,
timeUnit
=
_sc_timeUnit
subConfig
...
@@ -232,7 +222,7 @@ defaultConfig =
...
@@ -232,7 +222,7 @@ defaultConfig =
,
listParser
=
V4
,
listParser
=
V4
,
phyloName
=
pack
"Phylo Name"
,
phyloName
=
pack
"Phylo Name"
,
phyloScale
=
2
,
phyloScale
=
2
,
phyloProximity
=
WeightedLogJaccard
0.5
,
phyloProximity
=
WeightedLogJaccard
0.5
1
,
seaElevation
=
Constante
0.1
0.1
,
seaElevation
=
Constante
0.1
0.1
,
findAncestors
=
False
,
findAncestors
=
False
,
phyloSynchrony
=
ByProximityThreshold
0.5
0
AllBranches
MergeAllGroups
,
phyloSynchrony
=
ByProximityThreshold
0.5
0
AllBranches
MergeAllGroups
...
...
src/Gargantext/Core/Viz/Phylo/PhyloExport.hs
View file @
ebcee352
...
@@ -222,8 +222,8 @@ exportToDot phylo export =
...
@@ -222,8 +222,8 @@ exportToDot phylo export =
,(
toAttr
(
fromStrict
"phyloTimeScale"
)
$
pack
$
getTimeScale
phylo
)
,(
toAttr
(
fromStrict
"phyloTimeScale"
)
$
pack
$
getTimeScale
phylo
)
,(
toAttr
(
fromStrict
"PhyloScale"
)
$
pack
$
show
(
_qua_granularity
$
phyloQuality
$
getConfig
phylo
))
,(
toAttr
(
fromStrict
"PhyloScale"
)
$
pack
$
show
(
_qua_granularity
$
phyloQuality
$
getConfig
phylo
))
,(
toAttr
(
fromStrict
"phyloQuality"
)
$
pack
$
show
(
phylo
^.
phylo_quality
))
,(
toAttr
(
fromStrict
"phyloQuality"
)
$
pack
$
show
(
phylo
^.
phylo_quality
))
,(
toAttr
(
fromStrict
"phyloSeaRiseStart"
)
$
pack
$
show
(
_cons_start
$
getSeaElevation
phylo
))
,(
toAttr
(
fromStrict
"phyloSeaRiseStart"
)
$
pack
$
show
(
getPhyloSeaRiseStart
phylo
))
,(
toAttr
(
fromStrict
"phyloSeaRiseSteps"
)
$
pack
$
show
(
_cons_step
$
getSeaElevation
phylo
))
,(
toAttr
(
fromStrict
"phyloSeaRiseSteps"
)
$
pack
$
show
(
getPhyloSeaRiseSteps
phylo
))
-- ,(toAttr (fromStrict "phyloTermsFreq") $ pack $ show (toList $ _phylo_lastTermFreq phylo))
-- ,(toAttr (fromStrict "phyloTermsFreq") $ pack $ show (toList $ _phylo_lastTermFreq phylo))
])
])
...
@@ -373,9 +373,9 @@ sortByBirthDate order export =
...
@@ -373,9 +373,9 @@ sortByBirthDate order export =
processSort
::
Sort
->
SeaElevation
->
PhyloExport
->
PhyloExport
processSort
::
Sort
->
SeaElevation
->
PhyloExport
->
PhyloExport
processSort
sort'
elev
export
=
case
sort'
of
processSort
sort'
elev
export
=
case
sort'
of
ByBirthDate
o
->
sortByBirthDate
o
export
ByBirthDate
o
->
sortByBirthDate
o
export
ByHierarchy
_
->
export
&
export_branches
.~
(
branchToIso'
(
_cons_start
elev
)
(
_cons_step
elev
)
ByHierarchy
_
->
case
elev
of
$
sortByHierarchy
0
(
export
^.
export_branches
))
Constante
s
s'
->
export
&
export_branches
.~
(
branchToIso'
s
s'
$
sortByHierarchy
0
(
export
^.
export_branches
))
Adaptative
_
->
export
&
export_branches
.~
(
branchToIso
$
sortByHierarchy
0
(
export
^.
export_branches
))
-----------------
-----------------
-- | Metrics | --
-- | Metrics | --
...
@@ -647,7 +647,7 @@ toHorizon phylo =
...
@@ -647,7 +647,7 @@ toHorizon phylo =
proximity
=
(
phyloProximity
$
getConfig
phylo
)
proximity
=
(
phyloProximity
$
getConfig
phylo
)
step
=
case
getSeaElevation
phylo
of
step
=
case
getSeaElevation
phylo
of
Constante
_
s
->
s
Constante
_
s
->
s
Adaptative
_
->
undefined
Adaptative
_
->
0
-- in headsToAncestors nbDocs diago proximity heads groups []
-- in headsToAncestors nbDocs diago proximity heads groups []
in
map
(
\
ego
->
toAncestor
nbDocs
diago
proximity
step
noHeads
ego
)
in
map
(
\
ego
->
toAncestor
nbDocs
diago
proximity
step
noHeads
ego
)
$
headsToAncestors
nbDocs
diago
proximity
step
heads
[]
$
headsToAncestors
nbDocs
diago
proximity
step
heads
[]
...
...
src/Gargantext/Core/Viz/Phylo/PhyloTools.hs
View file @
ebcee352
...
@@ -334,16 +334,16 @@ getPeriodPointers fil g =
...
@@ -334,16 +334,16 @@ getPeriodPointers fil g =
filterProximity
::
Proximity
->
Double
->
Double
->
Bool
filterProximity
::
Proximity
->
Double
->
Double
->
Bool
filterProximity
proximity
thr
local
=
filterProximity
proximity
thr
local
=
case
proximity
of
case
proximity
of
WeightedLogJaccard
_
->
local
>=
thr
WeightedLogJaccard
_
_
->
local
>=
thr
WeightedLogSim
_
->
local
>=
thr
WeightedLogSim
_
_
->
local
>=
thr
Hamming
_
->
undefined
Hamming
_
_
->
undefined
getProximityName
::
Proximity
->
String
getProximityName
::
Proximity
->
String
getProximityName
proximity
=
getProximityName
proximity
=
case
proximity
of
case
proximity
of
WeightedLogJaccard
_
->
"WLJaccard"
WeightedLogJaccard
_
_
->
"WLJaccard"
WeightedLogSim
_
->
"WeightedLogSim"
WeightedLogSim
_
_
->
"WeightedLogSim"
Hamming
_
->
"Hamming"
Hamming
_
_
->
"Hamming"
---------------
---------------
-- | Phylo | --
-- | Phylo | --
...
@@ -400,6 +400,17 @@ getSeaElevation :: Phylo -> SeaElevation
...
@@ -400,6 +400,17 @@ getSeaElevation :: Phylo -> SeaElevation
getSeaElevation
phylo
=
seaElevation
(
getConfig
phylo
)
getSeaElevation
phylo
=
seaElevation
(
getConfig
phylo
)
getPhyloSeaRiseStart
::
Phylo
->
Double
getPhyloSeaRiseStart
phylo
=
case
(
getSeaElevation
phylo
)
of
Constante
s
_
->
s
Adaptative
_
->
0
getPhyloSeaRiseSteps
::
Phylo
->
Double
getPhyloSeaRiseSteps
phylo
=
case
(
getSeaElevation
phylo
)
of
Constante
_
s
->
s
Adaptative
s
->
s
getConfig
::
Phylo
->
PhyloConfig
getConfig
::
Phylo
->
PhyloConfig
getConfig
phylo
=
(
phylo
^.
phylo_param
)
^.
phyloParam_config
getConfig
phylo
=
(
phylo
^.
phylo_param
)
^.
phyloParam_config
...
@@ -533,13 +544,15 @@ groupsToBranches' groups =
...
@@ -533,13 +544,15 @@ groupsToBranches' groups =
bId
=
mergeBranchIds
$
map
(
\
g
->
snd
$
g
^.
phylo_groupBranchId
)
groups'
bId
=
mergeBranchIds
$
map
(
\
g
->
snd
$
g
^.
phylo_groupBranchId
)
groups'
in
map
(
\
g
->
g
&
phylo_groupBranchId
%~
(
\
(
lvl
,
_
)
->
(
lvl
,
bId
)))
groups'
)
graph
in
map
(
\
g
->
g
&
phylo_groupBranchId
%~
(
\
(
lvl
,
_
)
->
(
lvl
,
bId
)))
groups'
)
graph
relatedComponents
::
Ord
a
=>
[[
a
]]
->
[[
a
]]
relatedComponents
::
Ord
a
=>
[[
a
]]
->
[[
a
]]
relatedComponents
graph
=
foldl'
(
\
acc
groups
->
relatedComponents
graph
=
foldl'
(
\
branches
groups
->
if
(
null
acc
)
if
(
null
branches
)
then
acc
++
[
groups
]
then
branches
++
[
groups
]
else
else
let
acc'
=
partition
(
\
groups'
->
disjoint
(
Set
.
fromList
groups'
)
(
Set
.
fromList
groups
))
acc
let
branchPart
=
partition
(
\
branch
->
disjoint
(
Set
.
fromList
branch
)
(
Set
.
fromList
groups
))
branches
in
(
fst
acc'
)
++
[
nub
$
concat
$
(
snd
acc'
)
++
[
groups
]])
[]
graph
in
(
fst
branchPart
)
++
[
nub
$
concat
$
(
snd
branchPart
)
++
[
groups
]])
[]
graph
toRelatedComponents
::
[
PhyloGroup
]
->
[((
PhyloGroup
,
PhyloGroup
),
Double
)]
->
[[
PhyloGroup
]]
toRelatedComponents
::
[
PhyloGroup
]
->
[((
PhyloGroup
,
PhyloGroup
),
Double
)]
->
[[
PhyloGroup
]]
toRelatedComponents
nodes
edges
=
toRelatedComponents
nodes
edges
=
...
@@ -569,9 +582,15 @@ traceSynchronyStart phylo =
...
@@ -569,9 +582,15 @@ traceSynchronyStart phylo =
getSensibility
::
Proximity
->
Double
getSensibility
::
Proximity
->
Double
getSensibility
proxi
=
case
proxi
of
getSensibility
proxi
=
case
proxi
of
WeightedLogJaccard
s
->
s
WeightedLogJaccard
s
_
->
s
WeightedLogSim
s
->
s
WeightedLogSim
s
_
->
s
Hamming
_
->
undefined
Hamming
_
_
->
undefined
getMinSharedNgrams
::
Proximity
->
Int
getMinSharedNgrams
proxi
=
case
proxi
of
WeightedLogJaccard
_
m
->
m
WeightedLogSim
_
m
->
m
Hamming
_
_
->
undefined
----------------
----------------
-- | Branch | --
-- | Branch | --
...
...
src/Gargantext/Core/Viz/Phylo/SynchronicClustering.hs
View file @
ebcee352
...
@@ -140,10 +140,10 @@ groupsToEdges prox sync nbDocs diago groups =
...
@@ -140,10 +140,10 @@ groupsToEdges prox sync nbDocs diago groups =
toEdges
::
Double
->
[(
PhyloGroup
,
PhyloGroup
)]
->
[((
PhyloGroup
,
PhyloGroup
),
Double
)]
toEdges
::
Double
->
[(
PhyloGroup
,
PhyloGroup
)]
->
[((
PhyloGroup
,
PhyloGroup
),
Double
)]
toEdges
sens
edges
=
toEdges
sens
edges
=
case
prox
of
case
prox
of
WeightedLogJaccard
_
->
map
(
\
(
g
,
g'
)
->
WeightedLogJaccard
_
_
->
map
(
\
(
g
,
g'
)
->
((
g
,
g'
),
weightedLogJaccard'
(
sens
)
nbDocs
diago
((
g
,
g'
),
weightedLogJaccard'
(
sens
)
nbDocs
diago
(
g
^.
phylo_groupNgrams
)
(
g'
^.
phylo_groupNgrams
)))
edges
(
g
^.
phylo_groupNgrams
)
(
g'
^.
phylo_groupNgrams
)))
edges
WeightedLogSim
_
->
map
(
\
(
g
,
g'
)
->
WeightedLogSim
_
_
->
map
(
\
(
g
,
g'
)
->
((
g
,
g'
),
weightedLogJaccard'
(
1
/
sens
)
nbDocs
diago
((
g
,
g'
),
weightedLogJaccard'
(
1
/
sens
)
nbDocs
diago
(
g
^.
phylo_groupNgrams
)
(
g'
^.
phylo_groupNgrams
)))
edges
(
g
^.
phylo_groupNgrams
)
(
g'
^.
phylo_groupNgrams
)))
edges
...
...
src/Gargantext/Core/Viz/Phylo/TemporalMatching.hs
View file @
ebcee352
This diff is collapsed.
Click to expand it.
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment