ADTast-experimentalpthread-emulation
Last change
on this file since ee0176b was
08ed947,
checked in by Michael Brooks <mlbrooks@…>, 3 years ago
|
Roll up of string changes for performance testing/improvement, and a couple API features supporting them.
String API changes:
Defining a tuning knob to control the heap growth policy (relapaces former 10% hardcode, downgraded to a default)
Implementing findFrom (allowing find-non-first); leaving find as find-first.
String implementation perf improvements:
Calling C-malloc directly instead of via CFA-alloc.
Replacings loops that copy with memmove calls.
Replacings loops that search for a value with memchr calls.
String perf testing realized:
Makefile supporting several prog-*.cfa, chosen by OPERATION value (implies prog.cfa changes to support the adjusted protocol)
Adjusting the starter/accumulater declarations in PEQ and PTA to behave consistently in cfa v cpp.
Adding tests: allocation, find, normalize, pass-by-val, pass-by-x.
Adding helper shell scripts for: generating flame graphs, collecting/crunching allocation stats using Mubeen's malloc wrappers
|
-
Property mode set to
100755
|
File size:
1.4 KB
|
Line | |
---|
1 | #! /usr/bin/python3 |
---|
2 | |
---|
3 | import glob |
---|
4 | import os |
---|
5 | import re |
---|
6 | |
---|
7 | print("corpuslen", "expansion", "elapsed_whole_test", "elapsed_last_alloc", "seclast_req_mem", sep=",") |
---|
8 | |
---|
9 | thepath = "preload_dump--qrun1*" |
---|
10 | |
---|
11 | for mypath in glob.glob(thepath): |
---|
12 | pathparsed=re.match(r'preload_dump--qrun1--corpus-1-(\d+)-1.txt--expansion-(0\.\d+).txt', mypath) |
---|
13 | corpuslen=pathparsed.group(1) |
---|
14 | expansion=pathparsed.group(2) |
---|
15 | |
---|
16 | with open(mypath) as file: |
---|
17 | lines = file.readlines() |
---|
18 | |
---|
19 | nAllocs = len(lines) |
---|
20 | |
---|
21 | epoch_timestamp_bp = lines[0].find("epoch_timestamp(ms)") |
---|
22 | epoch_timestamp_ep = epoch_timestamp_bp + len("epoch_timestamp(ms)") |
---|
23 | current_req_mem_bp = lines[0].find("current_req_mem(B)") |
---|
24 | current_req_mem_ep = current_req_mem_bp + len("current_req_mem(B)") |
---|
25 | |
---|
26 | first_timestamp = lines[ 1][epoch_timestamp_bp:epoch_timestamp_ep].strip() |
---|
27 | seclast_req_mem = lines[nAllocs-2][current_req_mem_bp:current_req_mem_ep].strip() |
---|
28 | seclast_timestamp = lines[nAllocs-2][epoch_timestamp_bp:epoch_timestamp_ep].strip() |
---|
29 | last_timestamp = lines[nAllocs-1][epoch_timestamp_bp:epoch_timestamp_ep].strip() |
---|
30 | |
---|
31 | elapsed_whole_test = int(last_timestamp) - int(first_timestamp) |
---|
32 | elapsed_last_alloc = int(last_timestamp) - int(seclast_timestamp) |
---|
33 | |
---|
34 | print(corpuslen, expansion, elapsed_whole_test, elapsed_last_alloc, seclast_req_mem, sep=",") |
---|
Note: See
TracBrowser
for help on using the repository browser.