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
154
Issues
154
List
Board
Labels
Milestones
Merge Requests
12
Merge Requests
12
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
4e9b6f41
Commit
4e9b6f41
authored
Jan 11, 2022
by
Alexandre Delanoë
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
[FIX] Ngrams in list
parent
04da4749
Changes
14
Hide whitespace changes
Inline
Side-by-side
Showing
14 changed files
with
63 additions
and
108 deletions
+63
-108
List.hs
src/Gargantext/API/Ngrams/List.hs
+2
-2
Export.hs
src/Gargantext/API/Node/Corpus/Export.hs
+11
-9
List.hs
src/Gargantext/Core/Text/List.hs
+4
-4
LegacyMain.hs
src/Gargantext/Core/Viz/Phylo/Legacy/LegacyMain.hs
+1
-1
Flow.hs
src/Gargantext/Database/Action/Flow.hs
+2
-3
List.hs
src/Gargantext/Database/Action/Flow/List.hs
+8
-6
NgramsByContext.hs
src/Gargantext/Database/Action/Metrics/NgramsByContext.hs
+14
-14
TFICF.hs
src/Gargantext/Database/Action/Metrics/TFICF.hs
+3
-0
ContextNodeNgrams.hs
src/Gargantext/Database/Admin/Trigger/ContextNodeNgrams.hs
+3
-1
NodesNodes.hs
src/Gargantext/Database/Admin/Trigger/NodesNodes.hs
+3
-2
NodeContext.hs
src/Gargantext/Database/Query/Table/NodeContext.hs
+2
-2
NodeNode.hs
src/Gargantext/Database/Query/Table/NodeNode.hs
+6
-60
Node_NodeNgramsNodeNgrams.hs
...gantext/Database/Query/Table/Node_NodeNgramsNodeNgrams.hs
+2
-3
Node_NodeNgramsNodeNgrams.hs
src/Gargantext/Database/Schema/Node_NodeNgramsNodeNgrams.hs
+2
-1
No files found.
src/Gargantext/API/Ngrams/List.hs
View file @
4e9b6f41
...
@@ -39,7 +39,7 @@ import Gargantext.Database.Action.Flow.Types (FlowCmdM)
...
@@ -39,7 +39,7 @@ import Gargantext.Database.Action.Flow.Types (FlowCmdM)
import
Gargantext.Database.Action.Metrics.NgramsByContext
(
getOccByNgramsOnlyFast'
)
import
Gargantext.Database.Action.Metrics.NgramsByContext
(
getOccByNgramsOnlyFast'
)
import
Gargantext.Database.Admin.Types.Hyperdata.Document
import
Gargantext.Database.Admin.Types.Hyperdata.Document
import
Gargantext.Database.Admin.Types.Node
import
Gargantext.Database.Admin.Types.Node
import
Gargantext.Database.Query.Table.Node
Node
(
selectDocNodes
)
import
Gargantext.Database.Query.Table.Node
Context
(
selectDocNodes
)
import
Gargantext.Database.Schema.Ngrams
import
Gargantext.Database.Schema.Ngrams
import
Gargantext.Database.Schema.Node
import
Gargantext.Database.Schema.Node
import
Gargantext.Database.Types
(
Indexed
(
..
))
import
Gargantext.Database.Types
(
Indexed
(
..
))
...
@@ -187,7 +187,7 @@ reIndexWith cId lId nt lts = do
...
@@ -187,7 +187,7 @@ reIndexWith cId lId nt lts = do
]
]
)
)
(
List
.
cycle
[
Map
.
fromList
$
[(
nt
,
Map
.
singleton
(
doc
^.
node_id
)
1
)]])
(
List
.
cycle
[
Map
.
fromList
$
[(
nt
,
Map
.
singleton
(
doc
^.
node_id
)
1
)]])
)
docs
)
(
map
context2node
docs
)
-- printDebug "ngramsByDoc" ngramsByDoc
-- printDebug "ngramsByDoc" ngramsByDoc
...
...
src/Gargantext/API/Node/Corpus/Export.hs
View file @
4e9b6f41
...
@@ -19,6 +19,7 @@ module Gargantext.API.Node.Corpus.Export
...
@@ -19,6 +19,7 @@ module Gargantext.API.Node.Corpus.Export
import
Data.Map
(
Map
)
import
Data.Map
(
Map
)
import
Data.Maybe
(
fromMaybe
)
import
Data.Maybe
(
fromMaybe
)
import
Data.Set
(
Set
)
import
Data.Set
(
Set
)
import
Data.Text
(
Text
)
import
qualified
Data.List
as
List
import
qualified
Data.List
as
List
import
qualified
Data.Map
as
Map
import
qualified
Data.Map
as
Map
import
qualified
Data.Set
as
Set
import
qualified
Data.Set
as
Set
...
@@ -39,9 +40,9 @@ import Gargantext.Database.Prelude (Cmd)
...
@@ -39,9 +40,9 @@ import Gargantext.Database.Prelude (Cmd)
import
Gargantext.Database.Query.Table.Node
import
Gargantext.Database.Query.Table.Node
import
Gargantext.Database.Query.Table.Node.Error
(
HasNodeError
)
import
Gargantext.Database.Query.Table.Node.Error
(
HasNodeError
)
import
Gargantext.Database.Query.Table.Node.Select
(
selectNodesWithUsername
)
import
Gargantext.Database.Query.Table.Node.Select
(
selectNodesWithUsername
)
import
Gargantext.Database.Query.Table.Node
Node
(
selectDocNodes
)
import
Gargantext.Database.Query.Table.Node
Context
(
selectDocNodes
)
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Database.Schema.
Node
(
_node_id
,
_node
_hyperdata
)
import
Gargantext.Database.Schema.
Context
(
_context_id
,
_context
_hyperdata
)
import
Gargantext.Prelude
import
Gargantext.Prelude
--------------------------------------------------
--------------------------------------------------
...
@@ -62,31 +63,32 @@ getCorpus cId lId nt' = do
...
@@ -62,31 +63,32 @@ getCorpus cId lId nt' = do
Just
l
->
pure
l
Just
l
->
pure
l
ns
<-
Map
.
fromList
ns
<-
Map
.
fromList
<$>
map
(
\
n
->
(
_
node
_id
n
,
n
))
<$>
map
(
\
n
->
(
_
context
_id
n
,
n
))
<$>
selectDocNodes
cId
<$>
selectDocNodes
cId
repo
<-
getRepo'
[
listId
]
repo
<-
getRepo'
[
listId
]
ngs
<-
get
Node
Ngrams
cId
listId
nt
repo
ngs
<-
get
Context
Ngrams
cId
listId
nt
repo
let
-- uniqId is hash computed already for each document imported in database
let
-- uniqId is hash computed already for each document imported in database
r
=
Map
.
intersectionWith
r
=
Map
.
intersectionWith
(
\
a
b
->
DocumentExport
.
Document
{
_d_document
=
a
(
\
a
b
->
DocumentExport
.
Document
{
_d_document
=
context2node
a
,
_d_ngrams
=
DocumentExport
.
Ngrams
(
Set
.
toList
b
)
(
hash
b
)
,
_d_ngrams
=
DocumentExport
.
Ngrams
(
Set
.
toList
b
)
(
hash
b
)
,
_d_hash
=
d_hash
a
b
}
,
_d_hash
=
d_hash
a
b
}
)
ns
(
Map
.
map
(
Set
.
map
unNgramsTerm
)
ngs
)
)
ns
(
Map
.
map
(
Set
.
map
unNgramsTerm
)
ngs
)
where
where
d_hash
a
b
=
hash
[
fromMaybe
""
(
_hd_uniqId
$
_node_hyperdata
a
)
d_hash
::
Context
HyperdataDocument
->
Set
Text
->
Text
d_hash
a
b
=
hash
[
fromMaybe
""
(
_hd_uniqId
$
_context_hyperdata
a
)
,
hash
b
,
hash
b
]
]
pure
$
Corpus
{
_c_corpus
=
Map
.
elems
r
pure
$
Corpus
{
_c_corpus
=
Map
.
elems
r
,
_c_hash
=
hash
$
List
.
map
DocumentExport
.
_d_hash
$
Map
.
elems
r
}
,
_c_hash
=
hash
$
List
.
map
DocumentExport
.
_d_hash
$
Map
.
elems
r
}
get
Node
Ngrams
::
HasNodeError
err
get
Context
Ngrams
::
HasNodeError
err
=>
CorpusId
=>
CorpusId
->
ListId
->
ListId
->
NgramsType
->
NgramsType
->
NodeListStory
->
NodeListStory
->
Cmd
err
(
Map
Node
Id
(
Set
NgramsTerm
))
->
Cmd
err
(
Map
Context
Id
(
Set
NgramsTerm
))
get
Node
Ngrams
cId
lId
nt
repo
=
do
get
Context
Ngrams
cId
lId
nt
repo
=
do
-- lId <- case lId' of
-- lId <- case lId' of
-- Nothing -> defaultList cId
-- Nothing -> defaultList cId
-- Just l -> pure l
-- Just l -> pure l
...
...
src/Gargantext/Core/Text/List.hs
View file @
4e9b6f41
...
@@ -159,11 +159,11 @@ buildNgramsTermsList user uCid mCid mfslw groupParams (nt, _mapListSize)= do
...
@@ -159,11 +159,11 @@ buildNgramsTermsList user uCid mCid mfslw groupParams (nt, _mapListSize)= do
-- Filter 0 With Double
-- Filter 0 With Double
-- Computing global speGen score
-- Computing global speGen score
printDebug
"[buldNgramsTermsList: Sample List] / start"
nt
printDebug
"[bu
i
ldNgramsTermsList: Sample List] / start"
nt
allTerms
::
HashMap
NgramsTerm
Double
<-
getTficf_withSample
uCid
mCid
nt
allTerms
::
HashMap
NgramsTerm
Double
<-
getTficf_withSample
uCid
mCid
nt
printDebug
"[buldNgramsTermsList: Sample List / end]"
nt
printDebug
"[bu
i
ldNgramsTermsList: Sample List / end]"
nt
printDebug
"[buldNgramsTermsList: Flow Social List / start]"
nt
printDebug
"[bu
i
ldNgramsTermsList: Flow Social List / start]"
nt
-- PrivateFirst for first developments since Public NodeMode is not implemented yet
-- PrivateFirst for first developments since Public NodeMode is not implemented yet
socialLists
::
FlowCont
NgramsTerm
FlowListScores
socialLists
::
FlowCont
NgramsTerm
FlowListScores
<-
flowSocialList
mfslw
user
nt
(
FlowCont
HashMap
.
empty
<-
flowSocialList
mfslw
user
nt
(
FlowCont
HashMap
.
empty
...
@@ -171,7 +171,7 @@ buildNgramsTermsList user uCid mCid mfslw groupParams (nt, _mapListSize)= do
...
@@ -171,7 +171,7 @@ buildNgramsTermsList user uCid mCid mfslw groupParams (nt, _mapListSize)= do
$
List
.
zip
(
HashMap
.
keys
allTerms
)
$
List
.
zip
(
HashMap
.
keys
allTerms
)
(
List
.
cycle
[
mempty
])
(
List
.
cycle
[
mempty
])
)
)
printDebug
"[buldNgramsTermsList: Flow Social List / end]"
nt
printDebug
"[bu
i
ldNgramsTermsList: Flow Social List / end]"
nt
let
ngramsKeys
=
HashMap
.
keysSet
allTerms
let
ngramsKeys
=
HashMap
.
keysSet
allTerms
...
...
src/Gargantext/Core/Viz/Phylo/Legacy/LegacyMain.hs
View file @
4e9b6f41
...
@@ -32,7 +32,7 @@ import Gargantext.Database.Action.Flow.Types
...
@@ -32,7 +32,7 @@ import Gargantext.Database.Action.Flow.Types
import
Gargantext.Core.Viz.LegacyPhylo
hiding
(
Svg
,
Dot
)
import
Gargantext.Core.Viz.LegacyPhylo
hiding
(
Svg
,
Dot
)
import
Gargantext.Database.Admin.Types.Hyperdata
import
Gargantext.Database.Admin.Types.Hyperdata
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Database.Query.Table.Node
Node
(
selectDocs
)
import
Gargantext.Database.Query.Table.Node
Context
(
selectDocs
)
import
Gargantext.Core.Types
import
Gargantext.Core.Types
import
Gargantext.Core
(
HasDBid
)
import
Gargantext.Core
(
HasDBid
)
...
...
src/Gargantext/Database/Action/Flow.hs
View file @
4e9b6f41
...
@@ -268,7 +268,7 @@ flowCorpusUser l user corpusName ctype ids mfslw = do
...
@@ -268,7 +268,7 @@ flowCorpusUser l user corpusName ctype ids mfslw = do
let
gp
=
GroupWithPosTag
l
CoreNLP
HashMap
.
empty
let
gp
=
GroupWithPosTag
l
CoreNLP
HashMap
.
empty
ngs
<-
buildNgramsLists
user
userCorpusId
masterCorpusId
mfslw
gp
ngs
<-
buildNgramsLists
user
userCorpusId
masterCorpusId
mfslw
gp
printDebug
"flowCorpusUser:ngs"
ngs
--
printDebug "flowCorpusUser:ngs" ngs
_userListId
<-
flowList_DbRepo
listId
ngs
_userListId
<-
flowList_DbRepo
listId
ngs
_mastListId
<-
getOrMkList
masterCorpusId
masterUserId
_mastListId
<-
getOrMkList
masterCorpusId
masterUserId
...
@@ -329,8 +329,7 @@ saveDocNgramsWith lId mapNgramsDocs' = do
...
@@ -329,8 +329,7 @@ saveDocNgramsWith lId mapNgramsDocs' = do
$
map
(
first
_ngramsTerms
.
second
Map
.
keys
)
$
map
(
first
_ngramsTerms
.
second
Map
.
keys
)
$
HashMap
.
toList
mapNgramsDocs
$
HashMap
.
toList
mapNgramsDocs
printDebug
"saveDocNgramsWith"
mapCgramsId
-- printDebug "saveDocNgramsWith" mapCgramsId
-- insertDocNgrams
-- insertDocNgrams
_return
<-
insertContextNodeNgrams2
_return
<-
insertContextNodeNgrams2
$
catMaybes
[
ContextNodeNgrams2
<$>
Just
nId
$
catMaybes
[
ContextNodeNgrams2
<$>
Just
nId
...
...
src/Gargantext/Database/Action/Flow/List.hs
View file @
4e9b6f41
...
@@ -21,7 +21,6 @@ import Control.Concurrent
...
@@ -21,7 +21,6 @@ import Control.Concurrent
import
Control.Lens
((
^.
),
(
+~
),
(
%~
),
at
,
(
.~
),
_Just
)
import
Control.Lens
((
^.
),
(
+~
),
(
%~
),
at
,
(
.~
),
_Just
)
import
Control.Monad.Reader
import
Control.Monad.Reader
import
Data.Map
(
Map
,
toList
)
import
Data.Map
(
Map
,
toList
)
import
Data.Maybe
(
catMaybes
)
import
Data.Text
(
Text
)
import
Data.Text
(
Text
)
import
Gargantext.API.Ngrams
(
saveNodeStory
)
import
Gargantext.API.Ngrams
(
saveNodeStory
)
import
Gargantext.API.Ngrams.Tools
(
getNodeStoryVar
)
import
Gargantext.API.Ngrams.Tools
(
getNodeStoryVar
)
...
@@ -31,8 +30,8 @@ import Gargantext.Core.Types.Main (ListType(CandidateTerm))
...
@@ -31,8 +30,8 @@ import Gargantext.Core.Types.Main (ListType(CandidateTerm))
import
Gargantext.Core.NodeStory
import
Gargantext.Core.NodeStory
import
Gargantext.Database.Action.Flow.Types
import
Gargantext.Database.Action.Flow.Types
import
Gargantext.Database.Admin.Types.Node
import
Gargantext.Database.Admin.Types.Node
import
Gargantext.Database.Query.Table.NodeNgrams
(
NodeNgramsPoly
(
..
),
NodeNgramsW
,
listInsertDb
,
getCgramsId
)
import
Gargantext.Database.Query.Table.NodeNgrams
(
NodeNgramsPoly
(
..
),
NodeNgramsW
{-, listInsertDb, getCgramsId -}
)
import
Gargantext.Database.Query.Table.Node_NodeNgramsNodeNgrams
--
import Gargantext.Database.Query.Table.Node_NodeNgramsNodeNgrams
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Database.Schema.Ngrams
(
NgramsType
(
..
))
import
Gargantext.Prelude
import
Gargantext.Prelude
import
qualified
Data.List
as
List
import
qualified
Data.List
as
List
...
@@ -89,18 +88,21 @@ flowList_DbRepo :: FlowCmdM env err m
...
@@ -89,18 +88,21 @@ flowList_DbRepo :: FlowCmdM env err m
->
m
ListId
->
m
ListId
flowList_DbRepo
lId
ngs
=
do
flowList_DbRepo
lId
ngs
=
do
-- printDebug "listId flowList" lId
-- printDebug "listId flowList" lId
{-
mapCgramsId <- listInsertDb lId toNodeNgramsW (Map.toList ngs)
mapCgramsId <- listInsertDb lId toNodeNgramsW (Map.toList ngs)
let toInsert = catMaybes [ (,) <$> (getCgramsId mapCgramsId ntype <$> (unNgramsTerm <$> parent))
let toInsert = catMaybes [ (,) <$> (getCgramsId mapCgramsId ntype <$> (unNgramsTerm <$> parent))
<*> getCgramsId mapCgramsId ntype ngram
<*> getCgramsId mapCgramsId ntype ngram
| (ntype, ngs') <- Map.toList ngs
| (ntype, ngs') <- Map.toList ngs
, NgramsElement { _ne_ngrams = NgramsTerm ngram
, NgramsElement { _ne_ngrams = NgramsTerm ngram
, _ne_parent = parent } <- ngs'
, _ne_parent = parent } <- ngs'
]
]
-}
-- Inserting groups of ngrams
-- Inserting groups of ngrams
_r
<-
insert_Node_NodeNgrams_NodeNgrams
--
_r <- insert_Node_NodeNgrams_NodeNgrams
$
map
(
\
(
a
,
b
)
->
Node_NodeNgrams_NodeNgrams
lId
a
b
Nothing
)
toInsert
--
$ map (\(a,b) -> Node_NodeNgrams_NodeNgrams lId a b Nothing) toInsert
printDebug
"flowList_Tficf':ngs"
ngs
--
printDebug "flowList_Tficf':ngs" ngs
listInsert
lId
ngs
listInsert
lId
ngs
--trace (show $ List.filter (\n -> _ne_ngrams n == "versatile") $ List.concat $ Map.elems ngs) $ listInsert lId ngs
--trace (show $ List.filter (\n -> _ne_ngrams n == "versatile") $ List.concat $ Map.elems ngs) $ listInsert lId ngs
...
...
src/Gargantext/Database/Action/Metrics/NgramsByContext.hs
View file @
4e9b6f41
...
@@ -208,16 +208,16 @@ selectNgramsOccurrencesOnlyByContextUser cId nt tms =
...
@@ -208,16 +208,16 @@ selectNgramsOccurrencesOnlyByContextUser cId nt tms =
queryNgramsOccurrencesOnlyByContextUser
::
DPS
.
Query
queryNgramsOccurrencesOnlyByContextUser
::
DPS
.
Query
queryNgramsOccurrencesOnlyByContextUser
=
[
sql
|
queryNgramsOccurrencesOnlyByContextUser
=
[
sql
|
WITH input_rows(terms) AS (?)
WITH input_rows(terms) AS (?)
SELECT ng.terms, COUNT(cng.
node
_id) FROM context_node_ngrams cng
SELECT ng.terms, COUNT(cng.
context
_id) FROM context_node_ngrams cng
JOIN ngrams
ng
ON cng.ngrams_id = ng.id
JOIN ngrams
ng
ON cng.ngrams_id = ng.id
JOIN input_rows ir ON ir.terms = ng.terms
JOIN input_rows
ir ON ir.terms = ng.terms
JOIN nodes_
nodes nn ON nn.node_id = cng.node
_id
JOIN nodes_
contexts nn ON nn.context_id = cng.context
_id
JOIN nodes
n ON nn.node_id
= n.id
JOIN nodes
n ON nn.node_id
= n.id
WHERE nn.node
1
_id = ? -- CorpusId
WHERE nn.node_id = ? -- CorpusId
AND n.typename = ? -- toDBid
AND n.typename = ? -- toDBid
AND cng.ngrams_type = ? -- NgramsTypeId
AND cng.ngrams_type = ? -- NgramsTypeId
AND nn.category > 0
AND nn.category > 0
GROUP BY cng.
node
_id, ng.terms
GROUP BY cng.
context
_id, ng.terms
|]
|]
...
@@ -242,17 +242,17 @@ selectNgramsOccurrencesOnlyByContextUser_withSample cId int nt tms =
...
@@ -242,17 +242,17 @@ selectNgramsOccurrencesOnlyByContextUser_withSample cId int nt tms =
queryNgramsOccurrencesOnlyByContextUser_withSample
::
DPS
.
Query
queryNgramsOccurrencesOnlyByContextUser_withSample
::
DPS
.
Query
queryNgramsOccurrencesOnlyByContextUser_withSample
=
[
sql
|
queryNgramsOccurrencesOnlyByContextUser_withSample
=
[
sql
|
WITH nodes_sample AS (SELECT id FROM
node
s n TABLESAMPLE SYSTEM_ROWS (?)
WITH nodes_sample AS (SELECT id FROM
context
s n TABLESAMPLE SYSTEM_ROWS (?)
JOIN nodes_
nodes nn ON n.id = nn.node2
_id
JOIN nodes_
contexts nn ON n.id = nn.context
_id
WHERE n.typename = ?
WHERE n.typename = ?
AND nn.node
1
_id = ?),
AND nn.node_id = ?),
input_rows(terms) AS (?)
input_rows(terms) AS (?)
SELECT ng.terms, COUNT(cng.
node
_id) FROM context_node_ngrams cng
SELECT ng.terms, COUNT(cng.
context
_id) FROM context_node_ngrams cng
JOIN ngrams ng ON cng.ngrams_id = ng.id
JOIN ngrams ng ON cng.ngrams_id = ng.id
JOIN input_rows ir ON ir.terms = ng.terms
JOIN input_rows ir ON ir.terms = ng.terms
JOIN nodes_
nodes nn ON nn.node2_id = cng.node
_id
JOIN nodes_
contexts nn ON nn.context_id = cng.context
_id
JOIN nodes_sample n ON nn.
node2
_id = n.id
JOIN nodes_sample n ON nn.
context
_id = n.id
WHERE nn.node
1_id
= ? -- CorpusId
WHERE nn.node
_id
= ? -- CorpusId
AND cng.ngrams_type = ? -- NgramsTypeId
AND cng.ngrams_type = ? -- NgramsTypeId
AND nn.category > 0
AND nn.category > 0
GROUP BY cng.node_id, ng.terms
GROUP BY cng.node_id, ng.terms
...
...
src/Gargantext/Database/Action/Metrics/TFICF.hs
View file @
4e9b6f41
...
@@ -46,6 +46,8 @@ getTficf cId mId nt = do
...
@@ -46,6 +46,8 @@ getTficf cId mId nt = do
countLocal
<-
selectCountDocs
cId
countLocal
<-
selectCountDocs
cId
countGlobal
<-
selectCountDocs
mId
countGlobal
<-
selectCountDocs
mId
printDebug
"getTficf"
(
mapTextDoubleLocal
,
mapTextDoubleGlobal
,
countLocal
,
countGlobal
)
pure
$
HM
.
mapWithKey
(
\
t
n
->
pure
$
HM
.
mapWithKey
(
\
t
n
->
tficf
(
TficfInfra
(
Count
n
)
tficf
(
TficfInfra
(
Count
n
)
(
Total
$
fromIntegral
countLocal
))
(
Total
$
fromIntegral
countLocal
))
...
@@ -71,6 +73,7 @@ getTficf_withSample cId mId nt = do
...
@@ -71,6 +73,7 @@ getTficf_withSample cId mId nt = do
<$>
getOccByNgramsOnlyFast_withSample
mId
countGlobal
nt
<$>
getOccByNgramsOnlyFast_withSample
mId
countGlobal
nt
(
HM
.
keys
mapTextDoubleLocal
)
(
HM
.
keys
mapTextDoubleLocal
)
printDebug
"getTficf_withSample"
(
mapTextDoubleLocal
,
mapTextDoubleGlobal
,
countLocal
,
countGlobal
)
pure
$
HM
.
mapWithKey
(
\
t
n
->
pure
$
HM
.
mapWithKey
(
\
t
n
->
tficf
(
TficfInfra
(
Count
n
)
tficf
(
TficfInfra
(
Count
n
)
(
Total
$
fromIntegral
countLocal
))
(
Total
$
fromIntegral
countLocal
))
...
...
src/Gargantext/Database/Admin/Trigger/ContextNodeNgrams.hs
View file @
4e9b6f41
...
@@ -18,7 +18,7 @@ module Gargantext.Database.Admin.Trigger.ContextNodeNgrams
...
@@ -18,7 +18,7 @@ module Gargantext.Database.Admin.Trigger.ContextNodeNgrams
import
Database.PostgreSQL.Simple.SqlQQ
(
sql
)
import
Database.PostgreSQL.Simple.SqlQQ
(
sql
)
import
Gargantext.Core
import
Gargantext.Core
import
Gargantext.Core.Types.Main
(
ListType
(
CandidateTerm
))
--
import Gargantext.Core.Types.Main (ListType(CandidateTerm))
import
Gargantext.Database.Admin.Types.Node
-- (ListId, CorpusId, NodeId)
import
Gargantext.Database.Admin.Types.Node
-- (ListId, CorpusId, NodeId)
import
Gargantext.Database.Prelude
(
Cmd
,
execPGSQuery
)
import
Gargantext.Database.Prelude
(
Cmd
,
execPGSQuery
)
import
Gargantext.Prelude
import
Gargantext.Prelude
...
@@ -105,6 +105,7 @@ triggerCountInsert2 = execPGSQuery query ( toDBid NodeCorpus
...
@@ -105,6 +105,7 @@ triggerCountInsert2 = execPGSQuery query ( toDBid NodeCorpus
-- TODO add the groups
-- TODO add the groups
-- TODO use context instead of nodes of type doc
-- TODO use context instead of nodes of type doc
{-
triggerCoocInsert :: HasDBid NodeType => Cmd err Int64
triggerCoocInsert :: HasDBid NodeType => Cmd err Int64
triggerCoocInsert = execPGSQuery query ( toDBid NodeCorpus
triggerCoocInsert = execPGSQuery query ( toDBid NodeCorpus
, toDBid NodeDocument
, toDBid NodeDocument
...
@@ -160,3 +161,4 @@ triggerCoocInsert = execPGSQuery query ( toDBid NodeCorpus
...
@@ -160,3 +161,4 @@ triggerCoocInsert = execPGSQuery query ( toDBid NodeCorpus
FOR EACH STATEMENT
FOR EACH STATEMENT
EXECUTE PROCEDURE set_cooc();
EXECUTE PROCEDURE set_cooc();
|]
|]
-}
src/Gargantext/Database/Admin/Trigger/NodesNodes.hs
View file @
4e9b6f41
...
@@ -21,7 +21,7 @@ import Database.PostgreSQL.Simple.SqlQQ (sql)
...
@@ -21,7 +21,7 @@ import Database.PostgreSQL.Simple.SqlQQ (sql)
import
Gargantext.Core
import
Gargantext.Core
import
Gargantext.Database.Admin.Config
import
Gargantext.Database.Admin.Config
import
Gargantext.Database.Admin.Types.Node
-- (ListId, CorpusId, NodeId)
import
Gargantext.Database.Admin.Types.Node
-- (ListId, CorpusId, NodeId)
import
Gargantext.Core.Types.Main
(
ListType
(
CandidateTerm
))
--
import Gargantext.Core.Types.Main (ListType(CandidateTerm))
import
Gargantext.Database.Prelude
(
Cmd
,
execPGSQuery
)
import
Gargantext.Database.Prelude
(
Cmd
,
execPGSQuery
)
import
Gargantext.Prelude
import
Gargantext.Prelude
import
qualified
Database.PostgreSQL.Simple
as
DPS
import
qualified
Database.PostgreSQL.Simple
as
DPS
...
@@ -157,6 +157,7 @@ triggerUpdateDel lId = execPGSQuery query (lId, nodeTypeId NodeList)
...
@@ -157,6 +157,7 @@ triggerUpdateDel lId = execPGSQuery query (lId, nodeTypeId NodeList)
|]
|]
-- TODO add groups
-- TODO add groups
{-
triggerCoocInsert :: MasterListId -> Cmd err Int64
triggerCoocInsert :: MasterListId -> Cmd err Int64
triggerCoocInsert lid = execPGSQuery query ( lid
triggerCoocInsert lid = execPGSQuery query ( lid
-- , nodeTypeId NodeCorpus
-- , nodeTypeId NodeCorpus
...
@@ -213,4 +214,4 @@ triggerCoocInsert lid = execPGSQuery query ( lid
...
@@ -213,4 +214,4 @@ triggerCoocInsert lid = execPGSQuery query ( lid
FOR EACH STATEMENT
FOR EACH STATEMENT
EXECUTE PROCEDURE nodes_nodes_set_cooc();
EXECUTE PROCEDURE nodes_nodes_set_cooc();
|]
|]
-}
src/Gargantext/Database/Query/Table/NodeContext.hs
View file @
4e9b6f41
...
@@ -141,7 +141,7 @@ selectCountDocs cId = runCountOpaQuery (queryCountDocs cId)
...
@@ -141,7 +141,7 @@ selectCountDocs cId = runCountOpaQuery (queryCountDocs cId)
restrict
-<
nc
^.
nc_node_id
.==
(
toNullable
$
pgNodeId
cId'
)
restrict
-<
nc
^.
nc_node_id
.==
(
toNullable
$
pgNodeId
cId'
)
restrict
-<
nc
^.
nc_category
.>=
(
toNullable
$
sqlInt4
1
)
restrict
-<
nc
^.
nc_category
.>=
(
toNullable
$
sqlInt4
1
)
restrict
-<
c
^.
context_typename
.==
(
sqlInt4
$
toDBid
NodeDocument
)
restrict
-<
c
^.
context_typename
.==
(
sqlInt4
$
toDBid
NodeDocument
)
returnA
-<
c
returnA
-<
c
-- | TODO use UTCTime fast
-- | TODO use UTCTime fast
...
@@ -177,7 +177,7 @@ joinInCorpus :: O.Select (ContextRead, NodeContextReadNull)
...
@@ -177,7 +177,7 @@ joinInCorpus :: O.Select (ContextRead, NodeContextReadNull)
joinInCorpus
=
leftJoin
queryContextTable
queryNodeContextTable
cond
joinInCorpus
=
leftJoin
queryContextTable
queryNodeContextTable
cond
where
where
cond
::
(
ContextRead
,
NodeContextRead
)
->
Column
SqlBool
cond
::
(
ContextRead
,
NodeContextRead
)
->
Column
SqlBool
cond
(
c
,
nc
)
=
c
^.
context_id
.==
nc
^.
nc_
node
_id
cond
(
c
,
nc
)
=
c
^.
context_id
.==
nc
^.
nc_
context
_id
joinOn1
::
O
.
Select
(
NodeRead
,
NodeContextReadNull
)
joinOn1
::
O
.
Select
(
NodeRead
,
NodeContextReadNull
)
...
...
src/Gargantext/Database/Query/Table/NodeNode.hs
View file @
4e9b6f41
...
@@ -21,21 +21,15 @@ commentary with @some markup@.
...
@@ -21,21 +21,15 @@ commentary with @some markup@.
module
Gargantext.Database.Query.Table.NodeNode
module
Gargantext.Database.Query.Table.NodeNode
(
module
Gargantext
.
Database
.
Schema
.
NodeNode
(
module
Gargantext
.
Database
.
Schema
.
NodeNode
,
queryNodeNodeTable
,
queryNodeNodeTable
,
selectNodesDates
,
selectDocNodes
,
selectDocs
,
getNodeNode
,
getNodeNode
,
insertNodeNode
,
insertNodeNode
,
deleteNodeNode
,
deleteNodeNode
,
selectPublicNodes
,
selectPublicNodes
,
selectCountDocs
)
)
where
where
import
Control.Arrow
(
returnA
)
import
Control.Arrow
(
returnA
)
import
Control.Lens
(
view
,
(
^.
))
import
Control.Lens
((
^.
))
import
Data.Maybe
(
catMaybes
)
import
Data.Text
(
Text
,
splitOn
)
import
qualified
Opaleye
as
O
import
qualified
Opaleye
as
O
import
Opaleye
import
Opaleye
...
@@ -119,59 +113,6 @@ deleteNodeNode n1 n2 = mkCmd $ \conn ->
...
@@ -119,59 +113,6 @@ deleteNodeNode n1 n2 = mkCmd $ \conn ->
rCount
rCount
)
)
------------------------------------------------------------------------
selectCountDocs
::
HasDBid
NodeType
=>
CorpusId
->
Cmd
err
Int
selectCountDocs
cId
=
runCountOpaQuery
(
queryCountDocs
cId
)
where
queryCountDocs
cId'
=
proc
()
->
do
(
n
,
nn
)
<-
joinInCorpus
-<
()
restrict
-<
nn
^.
nn_node1_id
.==
(
toNullable
$
pgNodeId
cId'
)
restrict
-<
nn
^.
nn_category
.>=
(
toNullable
$
sqlInt4
1
)
restrict
-<
n
^.
node_typename
.==
(
sqlInt4
$
toDBid
NodeDocument
)
returnA
-<
n
-- | TODO use UTCTime fast
selectNodesDates
::
HasDBid
NodeType
=>
CorpusId
->
Cmd
err
[
Text
]
selectNodesDates
cId
=
map
(
head'
"selectDocsDates"
.
splitOn
"-"
)
<$>
catMaybes
<$>
map
(
view
hd_publication_date
)
<$>
selectDocs
cId
selectDocs
::
HasDBid
NodeType
=>
CorpusId
->
Cmd
err
[
HyperdataDocument
]
selectDocs
cId
=
runOpaQuery
(
queryDocs
cId
)
queryDocs
::
HasDBid
NodeType
=>
CorpusId
->
O
.
Select
(
Column
SqlJsonb
)
queryDocs
cId
=
proc
()
->
do
(
n
,
nn
)
<-
joinInCorpus
-<
()
restrict
-<
nn
^.
nn_node1_id
.==
(
toNullable
$
pgNodeId
cId
)
restrict
-<
nn
^.
nn_category
.>=
(
toNullable
$
sqlInt4
1
)
restrict
-<
n
^.
node_typename
.==
(
sqlInt4
$
toDBid
NodeDocument
)
returnA
-<
view
(
node_hyperdata
)
n
selectDocNodes
::
HasDBid
NodeType
=>
CorpusId
->
Cmd
err
[
Node
HyperdataDocument
]
selectDocNodes
cId
=
runOpaQuery
(
queryDocNodes
cId
)
queryDocNodes
::
HasDBid
NodeType
=>
CorpusId
->
O
.
Select
NodeRead
queryDocNodes
cId
=
proc
()
->
do
(
n
,
nn
)
<-
joinInCorpus
-<
()
restrict
-<
nn
^.
nn_node1_id
.==
(
toNullable
$
pgNodeId
cId
)
restrict
-<
nn
^.
nn_category
.>=
(
toNullable
$
sqlInt4
1
)
restrict
-<
n
^.
node_typename
.==
(
sqlInt4
$
toDBid
NodeDocument
)
returnA
-<
n
joinInCorpus
::
O
.
Select
(
NodeRead
,
NodeNodeReadNull
)
joinInCorpus
=
leftJoin
queryNodeTable
queryNodeNodeTable
cond
where
cond
::
(
NodeRead
,
NodeNodeRead
)
->
Column
SqlBool
cond
(
n
,
nn
)
=
nn
^.
nn_node2_id
.==
(
view
node_id
n
)
joinOn1
::
O
.
Select
(
NodeRead
,
NodeNodeReadNull
)
joinOn1
=
leftJoin
queryNodeTable
queryNodeNodeTable
cond
where
cond
::
(
NodeRead
,
NodeNodeRead
)
->
Column
SqlBool
cond
(
n
,
nn
)
=
nn
^.
nn_node1_id
.==
n
^.
node_id
------------------------------------------------------------------------
------------------------------------------------------------------------
selectPublicNodes
::
HasDBid
NodeType
=>
(
Hyperdata
a
,
DefaultFromField
SqlJsonb
a
)
selectPublicNodes
::
HasDBid
NodeType
=>
(
Hyperdata
a
,
DefaultFromField
SqlJsonb
a
)
=>
Cmd
err
[(
Node
a
,
Maybe
Int
)]
=>
Cmd
err
[(
Node
a
,
Maybe
Int
)]
...
@@ -183,3 +124,8 @@ queryWithType nt = proc () -> do
...
@@ -183,3 +124,8 @@ queryWithType nt = proc () -> do
restrict
-<
n
^.
node_typename
.==
(
sqlInt4
$
toDBid
nt
)
restrict
-<
n
^.
node_typename
.==
(
sqlInt4
$
toDBid
nt
)
returnA
-<
(
n
,
nn
^.
nn_node2_id
)
returnA
-<
(
n
,
nn
^.
nn_node2_id
)
joinOn1
::
O
.
Select
(
NodeRead
,
NodeNodeReadNull
)
joinOn1
=
leftJoin
queryNodeTable
queryNodeNodeTable
cond
where
cond
::
(
NodeRead
,
NodeNodeRead
)
->
Column
SqlBool
cond
(
n
,
nn
)
=
nn
^.
nn_node1_id
.==
n
^.
node_id
src/Gargantext/Database/Query/Table/Node_NodeNgramsNodeNgrams.hs
View file @
4e9b6f41
...
@@ -29,11 +29,9 @@ Next Step benchmark:
...
@@ -29,11 +29,9 @@ Next Step benchmark:
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE TemplateHaskell #-}
module
Gargantext.Database.Query.Table.Node_NodeNgramsNodeNgrams
module
Gargantext.Database.Query.Table.Node_NodeNgramsNodeNgrams
(
module
Gargantext
.
Database
.
Schema
.
Node_NodeNgramsNodeNgrams
,
insert_Node_NodeNgrams_NodeNgrams
)
where
where
{-
import Gargantext.Database.Schema.Prelude
import Gargantext.Database.Schema.Prelude
import Gargantext.Database.Prelude (Cmd, runOpaQuery, mkCmd)
import Gargantext.Database.Prelude (Cmd, runOpaQuery, mkCmd)
import Gargantext.Database.Admin.Types.Node (pgNodeId)
import Gargantext.Database.Admin.Types.Node (pgNodeId)
...
@@ -68,3 +66,4 @@ insert_Node_NodeNgrams_NodeNgrams_W ns =
...
@@ -68,3 +66,4 @@ insert_Node_NodeNgrams_NodeNgrams_W ns =
, iReturning = rCount
, iReturning = rCount
, iOnConflict = (Just DoNothing)
, iOnConflict = (Just DoNothing)
}
}
-}
src/Gargantext/Database/Schema/Node_NodeNgramsNodeNgrams.hs
View file @
4e9b6f41
...
@@ -31,6 +31,7 @@ Next Step benchmark:
...
@@ -31,6 +31,7 @@ Next Step benchmark:
module
Gargantext.Database.Schema.Node_NodeNgramsNodeNgrams
module
Gargantext.Database.Schema.Node_NodeNgramsNodeNgrams
where
where
{-
import Gargantext.Database.Schema.Prelude
import Gargantext.Database.Schema.Prelude
import Gargantext.Database.Admin.Types.Node (CorpusId)
import Gargantext.Database.Admin.Types.Node (CorpusId)
import Gargantext.Database.Schema.Node()
import Gargantext.Database.Schema.Node()
...
@@ -84,4 +85,4 @@ instance DefaultFromField SqlInt4 (Maybe Int) where
...
@@ -84,4 +85,4 @@ instance DefaultFromField SqlInt4 (Maybe Int) where
instance DefaultFromField SqlFloat8 (Maybe Double) where
instance DefaultFromField SqlFloat8 (Maybe Double) where
defaultFromField = fromPGSFromField
defaultFromField = fromPGSFromField
-}
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