Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in
Toggle navigation
S
strategy_embedding
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
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
rank
strategy_embedding
Commits
ee69f945
Commit
ee69f945
authored
Nov 26, 2020
by
赵威
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
add timer
parent
d5c8c8c0
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
24 additions
and
3 deletions
+24
-3
match_api.py
personas_vector/match_api.py
+24
-3
No files found.
personas_vector/match_api.py
View file @
ee69f945
...
...
@@ -20,16 +20,21 @@ TAG_EMBEDDING_DICT = redis_client_db.hgetall("personas_tags_embedding")
@bind
(
"strategy_embedding/personas_vector/match"
)
def
match_tractate_by_device
(
device_id
,
n
=
10
):
try
:
if
device_id
not
in
[
"0"
,
"unknown"
,
"87654"
]:
if
device_id
not
in
[
"0"
,
"unknown"
,
"87654"
,
""
]:
time_begin
=
time
.
time
()
portrait_time_begin
=
time
.
time
()
business_tags
=
get_user_portrait_tag3_business_tags
(
device_id
,
tags_num
=
3
)
portrait_time_end
=
time
.
time
()
-
portrait_time_begin
res
=
[]
if
business_tags
:
vectors_time_begin
=
time
.
time
()
vectors
=
[]
for
tag
in
business_tags
:
lst
=
json
.
loads
(
TAG_EMBEDDING_DICT
.
get
(
bytes
(
tag
,
"utf-8"
),
b
"[]"
))
if
lst
:
vectors
.
append
(
np
.
array
(
lst
)
.
astype
(
"float32"
))
vectors_time_end
=
time
.
time
()
-
vectors_time_begin
search_time_begin
=
time
.
time
()
if
vectors
:
D
,
I
=
FAISS_TAGS_INDEX
.
search
(
np
.
array
([
np
.
average
(
vectors
,
axis
=
0
)])
.
astype
(
"float32"
),
n
)
distances
=
D
.
tolist
()[
0
]
...
...
@@ -37,10 +42,26 @@ def match_tractate_by_device(device_id, n=10):
for
(
index
,
i
)
in
enumerate
(
distances
):
if
i
<=
5.0
:
res
.
append
(
ids
[
index
])
search_time_end
=
time
.
time
()
-
search_time_begin
time_end
=
time
.
time
()
-
time_begin
if
time_end
>
0.04
:
send_performance_msg_to_dingtalk
(
"match_tractate_by_device {} n={} cost {:.3f}ms"
.
format
(
device_id
,
n
,
time_end
*
1000
))
timer_dict
=
{
"method"
:
"match_tractate_by_device"
,
"api"
:
"strategy_embedding/personas_vector/match"
,
"device_id"
:
device_id
,
"n"
:
n
,
"get_business_tags"
:
"{:.3f}ms"
.
format
(
portrait_time_end
*
1000
),
"get_vectors"
:
"{:.3f}ms"
.
format
(
vectors_time_end
*
1000
),
"search"
:
"{:.3f}ms"
.
format
(
search_time_end
*
1000
),
"total_time"
:
"{:.3f}ms"
.
format
(
time_end
*
1000
)
}
msg_res
=
""
for
(
k
,
v
)
in
timer_dict
.
items
():
msg_res
+=
str
(
k
)
msg_res
+=
": "
msg_res
+=
str
(
v
)
msg_res
+=
"
\n
"
send_performance_msg_to_dingtalk
(
msg_res
)
return
res
return
[]
except
Exception
as
e
:
...
...
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