Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
C
cython
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Labels
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Commits
Open sidebar
nexedi
cython
Commits
de6c2c52
Commit
de6c2c52
authored
Feb 10, 2020
by
Chris Gyurgyik
Committed by
GitHub
Feb 10, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add skeleton, functions of <numeric> library (#3332)
parent
9355dc5e
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
170 additions
and
0 deletions
+170
-0
Cython/Includes/libcpp/numeric.pxd
Cython/Includes/libcpp/numeric.pxd
+23
-0
tests/run/cpp_stl_numeric_ops.pyx
tests/run/cpp_stl_numeric_ops.pyx
+147
-0
No files found.
Cython/Includes/libcpp/numeric.pxd
0 → 100644
View file @
de6c2c52
cdef
extern
from
"<numeric>"
namespace
"std"
nogil
:
T
inner_product
[
InputIt1
,
InputIt2
,
T
](
InputIt1
first1
,
InputIt1
last1
,
InputIt2
first2
,
T
init
)
T
inner_product
[
InputIt1
,
InputIt2
,
T
,
BinaryOperation1
,
BinaryOperation2
](
InputIt1
first1
,
InputIt1
last1
,
InputIt2
first2
,
T
init
,
BinaryOperation1
op1
,
BinaryOperation2
op2
)
void
iota
[
ForwardIt
,
T
](
ForwardIt
first
,
ForwardIt
last
,
T
value
)
T
accumulate
[
InputIt
,
T
](
InputIt
first
,
InputIt
last
,
T
init
)
T
accumulate
[
InputIt
,
T
,
BinaryOperation
](
InputIt
first
,
InputIt
last
,
T
init
,
BinaryOperation
op
)
void
adjacent_difference
[
InputIt
,
OutputIt
](
InputIt
in_first
,
InputIt
in_last
,
OutputIt
out_first
)
void
adjacent_difference
[
InputIt
,
OutputIt
,
BinaryOperation
](
InputIt
in_first
,
InputIt
in_last
,
OutputIt
out_first
,
BinaryOperation
op
)
void
partial_sum
[
InputIt
,
OutputIt
](
InputIt
in_first
,
OutputIt
in_last
,
OutputIt
out_first
)
void
partial_sum
[
InputIt
,
OutputIt
,
BinaryOperation
](
InputIt
in_first
,
InputIt
in_last
,
OutputIt
out_first
,
BinaryOperation
op
)
tests/run/cpp_stl_numeric_ops.pyx
0 → 100644
View file @
de6c2c52
# mode: run
# tag: cpp, werror, cpp11
from
libcpp.numeric
cimport
inner_product
,
iota
,
accumulate
,
adjacent_difference
,
partial_sum
from
libcpp.vector
cimport
vector
from
libcpp
cimport
bool
# Subtracts two integers.
cdef
int
subtract_integers
(
int
lhs
,
int
rhs
):
return
lhs
-
rhs
# Adds two integers.
cdef
int
add_integers
(
int
lhs
,
int
rhs
):
return
lhs
+
rhs
# Multiplies two integers.
cdef
int
multiply_integers
(
int
lhs
,
int
rhs
):
return
lhs
*
rhs
# Determines equality for two integers.
# If lhs == rhs, returns true. Returns false otherwise.
cdef
bool
is_equal
(
int
lhs
,
int
rhs
):
return
lhs
==
rhs
def
test_inner_product
(
vector
[
int
]
v1
,
vector
[
int
]
v2
,
int
init
):
"""
Test inner_product with integer values.
>>> test_inner_product([1, 2, 3], [1, 2, 3], 1)
15
"""
return
inner_product
(
v1
.
begin
(),
v1
.
end
(),
v2
.
begin
(),
init
)
def
test_inner_product_with_zero
(
vector
[
int
]
v1
,
vector
[
int
]
v2
,
int
init
):
"""
Test inner_product with a zero value in the container.
>>> test_inner_product_with_zero([1, 2, 0], [1, 1, 1], 0)
3
"""
return
inner_product
(
v1
.
begin
(),
v1
.
end
(),
v2
.
begin
(),
init
)
def
test_inner_product_with_bin_op
(
vector
[
int
]
v1
,
vector
[
int
]
v2
,
int
init
):
"""
Test inner_product with two binary operations. In this case,
Looks at number of pairwise matches between v1 and v2.
[5, 1, 2, 3, 4]
[5, 4, 2, 3, 1]
There are 3 matches (5, 2, 3). So, 1 + 1 + 1 = 3.
>>> test_inner_product_with_bin_op([5, 1, 2, 3, 4], [5, 4, 2, 3, 1], 0)
3
"""
return
inner_product
(
v1
.
begin
(),
v1
.
end
(),
v2
.
begin
(),
init
,
add_integers
,
is_equal
)
def
test_iota
(
vector
[
int
]
v
,
int
value
):
"""
Test iota with beginning value of 0.
>>> test_iota(range(6), 0)
[0, 1, 2, 3, 4, 5]
"""
iota
(
v
.
begin
(),
v
.
end
(),
value
)
return
v
def
test_iota_negative_init
(
vector
[
int
]
v
,
int
value
):
"""
Test iota with a negative beginning value.
>>> test_iota_negative_init(range(7), -4)
[-4, -3, -2, -1, 0, 1, 2]
"""
iota
(
v
.
begin
(),
v
.
end
(),
value
)
return
v
def
test_accumulate
(
vector
[
int
]
v
,
int
init
):
"""
Test accumulate.
0 + 1 = 1
1 + 2 = 3
3 + 3 = 6
>>> test_accumulate([1, 2, 3], 0)
6
"""
return
accumulate
(
v
.
begin
(),
v
.
end
(),
init
)
def
test_accumulate_with_subtraction
(
vector
[
int
]
v
,
int
init
):
"""
Test accumulate with subtraction. Note that accumulate is a fold-left operation.
0 - 1 = -1
-1 - 2 = -3
-3 - 3 = -6
>>> test_accumulate_with_subtraction([1, 2, 3], 0)
-6
"""
return
accumulate
(
v
.
begin
(),
v
.
end
(),
init
,
subtract_integers
)
def
test_adjacent_difference
(
vector
[
int
]
v
):
"""
Test adjacent_difference with integer values.
2 - 0, -> 2
4 - 2, -> 2
6 - 4, -> 2
8 - 6, -> 2
10 - 8, -> 2
12 - 10 -> 2
>>> test_adjacent_difference([2, 4, 6, 8, 10, 12])
[2, 2, 2, 2, 2, 2]
"""
adjacent_difference
(
v
.
begin
(),
v
.
end
(),
v
.
begin
())
return
v
def
test_adjacent_difference_with_bin_op
(
vector
[
int
]
v
):
"""
Test adjacent_difference with a binary operation.
0 + 1 -> 1
1 + 2 -> 3
2 + 4 -> 6
4 + 5 -> 9
5 + 6 -> 11
>>> test_adjacent_difference_with_bin_op([1, 2, 4, 5, 6])
[1, 3, 6, 9, 11]
"""
adjacent_difference
(
v
.
begin
(),
v
.
end
(),
v
.
begin
(),
add_integers
)
return
v
def
test_partial_sum
(
vector
[
int
]
v
):
"""
Test partial_sum with integer values.
2 + 0 -> 2
2 + 2 -> 4
4 + 2 -> 6
6 + 2 -> 8
8 + 2 -> 10
10 + 2 -> 12
>>> test_partial_sum([2, 2, 2, 2, 2, 2])
[2, 4, 6, 8, 10, 12]
"""
partial_sum
(
v
.
begin
(),
v
.
end
(),
v
.
begin
())
return
v
def
test_partial_sum_with_bin_op
(
vector
[
int
]
v
):
"""
Test partial_sum with a binary operation.
Using multiply_integers, partial_sum will calculate the first 5 powers of 2.
>>> test_partial_sum_with_bin_op([2, 2, 2, 2, 2])
[2, 4, 8, 16, 32]
"""
partial_sum
(
v
.
begin
(),
v
.
end
(),
v
.
begin
(),
multiply_integers
)
return
v
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