Skip to content
GitLab
Menu
Projects
Groups
Snippets
Loading...
Help
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
Menu
Open sidebar
OpenDAS
torch-sparse
Commits
1b956856
Commit
1b956856
authored
Nov 12, 2020
by
rusty1s
Browse files
fix e_id in sampling
parent
5931f37b
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
21 deletions
+21
-21
csrc/cpu/sample_cpu.cpp
csrc/cpu/sample_cpu.cpp
+21
-21
No files found.
csrc/cpu/sample_cpu.cpp
View file @
1b956856
...
...
@@ -19,15 +19,14 @@ sample_adj_cpu(torch::Tensor rowptr, torch::Tensor col, torch::Tensor idx,
auto
out_rowptr_data
=
out_rowptr
.
data_ptr
<
int64_t
>
();
out_rowptr_data
[
0
]
=
0
;
std
::
vector
<
std
::
vector
<
int64_t
>>
cols
;
std
::
vector
<
std
::
vector
<
std
::
tuple
<
int64_t
,
int64_t
>>>
cols
;
// col, e_id
std
::
vector
<
int64_t
>
n_ids
;
std
::
unordered_map
<
int64_t
,
int64_t
>
n_id_map
;
std
::
vector
<
int64_t
>
e_ids
;
int64_t
i
;
for
(
int64_t
n
=
0
;
n
<
idx
.
numel
();
n
++
)
{
i
=
idx_data
[
n
];
cols
.
push_back
(
std
::
vector
<
int64_t
>
());
cols
.
push_back
(
std
::
vector
<
std
::
tuple
<
int64_t
,
int64_t
>
>
());
n_id_map
[
i
]
=
n
;
n_ids
.
push_back
(
i
);
}
...
...
@@ -49,9 +48,7 @@ sample_adj_cpu(torch::Tensor rowptr, torch::Tensor col, torch::Tensor idx,
n_id_map
[
c
]
=
n_ids
.
size
();
n_ids
.
push_back
(
c
);
}
cols
[
i
].
push_back
(
n_id_map
[
c
]);
e_ids
.
push_back
(
e
);
cols
[
i
].
push_back
(
std
::
make_tuple
(
n_id_map
[
c
],
e
));
}
out_rowptr_data
[
i
+
1
]
=
out_rowptr_data
[
i
]
+
cols
[
i
].
size
();
}
...
...
@@ -72,9 +69,7 @@ sample_adj_cpu(torch::Tensor rowptr, torch::Tensor col, torch::Tensor idx,
n_id_map
[
c
]
=
n_ids
.
size
();
n_ids
.
push_back
(
c
);
}
cols
[
i
].
push_back
(
n_id_map
[
c
]);
e_ids
.
push_back
(
c
);
cols
[
i
].
push_back
(
std
::
make_tuple
(
n_id_map
[
c
],
e
));
}
out_rowptr_data
[
i
+
1
]
=
out_rowptr_data
[
i
]
+
cols
[
i
].
size
();
}
...
...
@@ -106,29 +101,34 @@ sample_adj_cpu(torch::Tensor rowptr, torch::Tensor col, torch::Tensor idx,
n_id_map
[
c
]
=
n_ids
.
size
();
n_ids
.
push_back
(
c
);
}
cols
[
i
].
push_back
(
n_id_map
[
c
]);
e_ids
.
push_back
(
c
);
cols
[
i
].
push_back
(
std
::
make_tuple
(
n_id_map
[
c
],
e
));
}
out_rowptr_data
[
i
+
1
]
=
out_rowptr_data
[
i
]
+
cols
[
i
].
size
();
}
}
int64_t
n_len
=
n_ids
.
size
(),
e_len
=
e_ids
.
size
();
auto
n_id
=
torch
::
from_blob
(
n_ids
.
data
(),
{
n_len
},
col
.
options
()).
clone
();
auto
e_id
=
torch
::
from_blob
(
e_ids
.
data
(),
{
e_len
},
col
.
options
()).
clone
();
int64_t
N
=
n_ids
.
size
();
auto
out_n_id
=
torch
::
from_blob
(
n_ids
.
data
(),
{
N
},
col
.
options
()).
clone
();
auto
out_col
=
torch
::
empty
(
e_len
,
col
.
options
());
int64_t
E
=
out_rowptr_data
[
idx
.
numel
()];
auto
out_col
=
torch
::
empty
(
E
,
col
.
options
());
auto
out_col_data
=
out_col
.
data_ptr
<
int64_t
>
();
auto
out_e_id
=
torch
::
empty
(
E
,
col
.
options
());
auto
out_e_id_data
=
out_e_id
.
data_ptr
<
int64_t
>
();
i
=
0
;
for
(
std
::
vector
<
int64_t
>
&
col_vec
:
cols
)
{
std
::
sort
(
col_vec
.
begin
(),
col_vec
.
end
());
for
(
const
int64_t
&
c
:
col_vec
)
{
out_col_data
[
i
]
=
c
;
for
(
std
::
vector
<
std
::
tuple
<
int64_t
,
int64_t
>>
&
col_vec
:
cols
)
{
std
::
sort
(
col_vec
.
begin
(),
col_vec
.
end
(),
[](
const
std
::
tuple
<
int64_t
,
int64_t
>
&
a
,
const
std
::
tuple
<
int64_t
,
int64_t
>
&
b
)
->
bool
{
return
std
::
get
<
0
>
(
a
)
<
std
::
get
<
0
>
(
b
);
});
for
(
const
std
::
tuple
<
int64_t
,
int64_t
>
&
value
:
col_vec
)
{
out_col_data
[
i
]
=
std
::
get
<
0
>
(
value
);
out_e_id_data
[
i
]
=
std
::
get
<
1
>
(
value
);
i
+=
1
;
}
}
return
std
::
make_tuple
(
out_rowptr
,
out_col
,
n_id
,
e_id
);
return
std
::
make_tuple
(
out_rowptr
,
out_col
,
out_
n_id
,
out_
e_id
);
}
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