Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Cupybackend, mixed backends #37

Open
wants to merge 59 commits into
base: dev
Choose a base branch
from
Open
Changes from 1 commit
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
3dc26db
add cutensor backend
Jul 6, 2021
e7ef12b
add experiment group arg
Jul 6, 2021
149e340
update experiment group
Jul 7, 2021
4477818
update fixed size tensor contraction
Jul 9, 2021
b2f4c71
update measurement for tncontract
Jul 13, 2021
7bfb3fe
update byte calculation
Jul 13, 2021
f765aeb
restructure and change torch gen_tensor from cpu to gpu
sansangela Jul 16, 2021
3ac3a76
restructure and change torch gen_tensor from cpu to gpu
Jul 16, 2021
a0e73e7
Merge branch 'matmul' of https://github.com/DaniloZZZ/QTensor into ma…
sansangela Jul 19, 2021
5a60560
add bridge
sansangela Jul 19, 2021
c92f7e7
random generate tensors
sansangela Jul 20, 2021
974a158
add benchmark functions for matmul and tncontract
sansangela Jul 21, 2021
0660314
remove get_operation
sansangela Jul 21, 2021
2d3964b
add random generate tensor
sansangela Jul 23, 2021
4659a7b
update ggen_sizes
sansangela Jul 23, 2021
0df2083
add random tensor transpose
sansangela Jul 26, 2021
7a8b263
add test
sansangela Aug 4, 2021
5c6c28a
update args init
sansangela Aug 4, 2021
bf01bd3
add transpose backend
sansangela Aug 10, 2021
e44b1eb
add transposed backends
sansangela Aug 10, 2021
33049dc
update timing
sansangela Aug 11, 2021
dc16ef7
add transpose backend & update timing
sansangela Aug 11, 2021
42c65bb
update dtype casting
sansangela Aug 17, 2021
1a88493
Mixed BE Implemented
huaxuan250 Aug 18, 2021
d56013d
Modified Json Format
huaxuan250 Aug 18, 2021
eccbb37
Higher Threshold and Complete
huaxuan250 Aug 18, 2021
41b17a5
Adding Numpy-Torch Conpatibility
huaxuan250 Aug 26, 2021
f96f695
Adding Watershed Control
huaxuan250 Aug 31, 2021
fafb4f0
Accurate Width Calculation
huaxuan250 Aug 31, 2021
ddbfa59
Auto Threshold Optimization
huaxuan250 Sep 3, 2021
731a05b
Basic Performance Probing using 12 4 3
huaxuan250 Sep 5, 2021
c3c6d90
Bris Benchmarking by Bucket
huaxuan250 Sep 8, 2021
bdce309
Updated Parameter
huaxuan250 Sep 8, 2021
eaaabbf
merged backends
sansangela Sep 8, 2021
1889e3b
Mixed Merged Working
huaxuan250 Sep 11, 2021
76ea8ff
Name Change
huaxuan250 Sep 14, 2021
53635bb
QAOA Mix Merge Operational
huaxuan250 Sep 14, 2021
31c1ed7
String Parsing Fixed
huaxuan250 Sep 14, 2021
0bf7215
Bucket Iso
huaxuan250 Nov 17, 2021
747b143
Iso Done
huaxuan250 Nov 24, 2021
74f3a33
Probing Done
huaxuan250 Jan 5, 2022
32e9b70
Probing Result on V100
huaxuan250 Jan 5, 2022
d11c067
Fitting Done
huaxuan250 Jan 12, 2022
1c77a20
Merge branch 'cupybackend' of https://github.com/DaniloZZZ/QTensor in…
huaxuan250 Jan 12, 2022
b07d25d
Updated Result
huaxuan250 Jan 12, 2022
c578a79
1.12 Result
huaxuan250 Jan 12, 2022
075dce1
Probing Test Metrics
huaxuan250 Jan 19, 2022
a974fa9
Merge branch 'cupybackend' of https://github.com/DaniloZZZ/QTensor in…
huaxuan250 Jan 19, 2022
1fb42f7
Probing Done with Tests
huaxuan250 Jan 19, 2022
9f72abe
load detection
huaxuan250 Feb 2, 2022
c78e4fb
Load Detect Focus on maxwidth
huaxuan250 Feb 9, 2022
d0600e8
Updated Thr control
huaxuan250 Feb 9, 2022
3b02dd2
Basic Util Completes
huaxuan250 Feb 23, 2022
eaceb1d
CPU UTIL DONE FOR BASIC PROBING
huaxuan250 Feb 23, 2022
b3015b6
Example Code Done
huaxuan250 Feb 23, 2022
fb359d2
Change to Timing
huaxuan250 Feb 23, 2022
cfb320b
test script for merged backend
danlkv May 5, 2022
87b3a37
rename gpu_mix_test file
danlkv May 5, 2022
593b1d9
add notebook with tensor compression tests
danlkv May 6, 2022
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
random generate tensors
  • Loading branch information
sansangela committed Jul 20, 2021
commit c92f7e759bac96e38c2748b12f6a98a6cea036c8
9 changes: 0 additions & 9 deletions scratchpad/bench/matmul.py
Original file line number Diff line number Diff line change
@@ -151,15 +151,6 @@ def main():
repeats += 2
dtypes = ['float', 'double', 'complex64', 'complex128']

# for backend in backends:
# size_m, size_l, size_n = 2, 2, 2
# sizes = [size_m,size_n], [size_n, size_l]
# dtype = 'float'
# b = backends[backend]
# matmulbench = MatmulBench(b)
# _, bench_result = matmulbench.benchmark(b, num_tensors, *sizes, dtype=dtype)
# json_result = matmulbench.print_results_json(use_strip, backend, *sizes, dtype=dtype, results=bench_result, experiment_group=experiment_group)

for backend in backends:
for size_m, size_n, size_l in zip(sizes_m, sizes_n, sizes_l):
sizes = [size_m,size_n], [size_n, size_l]
38 changes: 26 additions & 12 deletions scratchpad/bench/tncontract.py
Original file line number Diff line number Diff line change
@@ -38,21 +38,29 @@ def get_params(cls, *sizes):
param_in = np.prod(sizes[0]) + np.prod(sizes[1])
param_out = sizes[0][0] * sizes[0][2] * sizes[1][3]
return ops.item(), param_in.item(), param_out


def gen_sizes(max_size):
sizes = np.random.randint(1, max_size+1, size=6).tolist()
size = [sizes[0:4], sizes[1:5]]
return size


class CuTensorTncontract(CuTensor):
@classmethod
def get_ready(self, num_tensors, *sizes):
sizes = list(sizes)
num_tensors += 1
unit_size = sizes[0][0]
sizes.append([unit_size for i in range(3)])
size_a = sizes[0][0]
size_c = sizes[0][2]
size_f = sizes[1][3]
sizes.append([size_a, size_c, size_f])
return num_tensors, *sizes


def main():

experiment_group = "Angela_nslb_tncontract_test"
experiment_group = "Angela_nslb_tncontract_random"

contraction = 'abcd,bcdf->acf' # tensor

@@ -72,7 +80,7 @@ def main():
num_tensors = 2
dim = 4 # tensor
# sizes = [2, 4, 8, 10, 16, 20, 30, 32, 40, 50, 60, 64, 70, 80, 100, 120, 128, 130, 150] # tensor
sizes = [2, 4, 8, 10, 16, 20, 30, 32, 40, 50, 60, 64, 70, 80, 100, 120] # tensor
sizes = [4, 8, 10, 16, 20, 30, 32, 40, 50, 60, 64, 70, 80, 100, 120] # tensor
dtypes = ['float', 'double', 'complex64', 'complex128']

# Test properties
@@ -81,20 +89,26 @@ def main():
if use_strip:
repeats += 2

is_square = True

# Bechmark
for backend in backends:
for size in sizes:
input_sizes = [size for i in range(dim)] # square tensors
for max_size in sizes:
results = []
if is_square:
input_sizes = [max_size for i in range(dim)] # square tensors
size = [input_sizes, input_sizes]
results = []
else:
size = gen_sizes(max_size)

for backend in backends:
b = backends[backend]
tncontractbench = TncontractBench(b)

for dtype in dtypes:
for _ in range(repeats):
b = backends[backend]
tncontractbench = TncontractBench(b)
_, bench_result = tncontractbench.benchmark(b,num_tensors, *size, dtype=dtype, contraction=contraction)
results.append(bench_result)
json_result = tncontractbench.print_results_json(use_strip, backend, *size, dtype=dtype, results=results, experiment_group=experiment_group)

json_result = tncontractbench.print_results_json(use_strip, backend, *size, dtype=dtype, results=results, experiment_group=experiment_group)


if __name__ == "__main__":