docs: added example3 with gil_load

This commit is contained in:
Maarten A. Breddels 2020-12-15 14:57:07 +01:00
parent e08c18dd36
commit 06d2ea5d30
3 changed files with 66 additions and 1 deletions

3
.gitignore vendored
View File

@ -131,4 +131,5 @@ dmypy.json
*.json *.json
*.html *.html
*.data *.data
*.data.old *.data.old
*.ipynb

View File

@ -126,3 +126,25 @@ Merge the viztracer and perf/per4m results into a single html file.
## GIL load vs GIL wait
Even though a thread may have a lock on the GIL, if other don't need it, it's fine. For instance, using [gil_load](https://github.com/chrisjbillington/gil_load):
```
$ python -m gil_load per4m/example3.py
eld: 1.0 (1.0, 1.0, 1.0)
wait: 0.083 (0.083, 0.083, 0.083)
<139967101757248>
held: 1.0 (1.0, 1.0, 1.0)
wait: 0.0 (0.0, 0.0, 0.0)
<139957774272256>
held: 0.0 (0.0, 0.0, 0.0)
wait: 0.083 (0.083, 0.083, 0.083)
<139957765879552>
held: 0.0 (0.0, 0.0, 0.0)
wait: 0.083 (0.083, 0.083, 0.083)
```
Show one thread that has a high GIL load, but it does not keep the others from running (except 8% of the time), i.e. wait is low (see [example3.py](https://github.com/maartenbreddels/per4m/blob/master/per4m/example3.py)). We can visualize this using `giltracer` (not that we import numpy and some other modules before tracing to avoid clutter)
$ per4m giltracer --import="numpy,threading,time,gil_load" -m per4m.example3
![image](https://user-images.githubusercontent.com/1765949/102223915-96996400-3ee5-11eb-9e2e-46ac6fd5c5e3.png)

42
per4m/example3.py Normal file
View File

@ -0,0 +1,42 @@
# shows high gil load, but no wait
import threading
import time
import numpy as np
# if we don't run with gil_load, we just skip it
import gil_load
try:
gil_load.init()
use_gil_load = True
except RuntimeError:
use_gil_load = False
N = 1024*1024*32
M = 4
x = np.arange(N, dtype='f8')
def run():
total = 0
for i in range(M):
total += x.sum()
return total
if use_gil_load:
gil_load.start()
thread1 = threading.Thread(target=run)
thread2 = threading.Thread(target=run)
thread1.start()
thread2.start()
total = 0
for i in range(1_000_000):
total += i
for thread in [thread1, thread2]:
thread.join()
if use_gil_load:
gil_load.stop()
stats = gil_load.get()
print(gil_load.format(stats))