ScatterPlot.py 2.98 KB
Newer Older
1 2
# -*- coding: utf-8 -*-
## Add path to library (just for examples; you do not need this)
3
import initExample
4

5
from pyqtgraph.Qt import QtGui, QtCore
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
import pyqtgraph as pg
import numpy as np

app = QtGui.QApplication([])
mw = QtGui.QMainWindow()
mw.resize(800,800)
view = pg.GraphicsLayoutWidget()  ## GraphicsView with GraphicsLayout inserted by default
mw.setCentralWidget(view)
mw.show()

## create four areas to add plots
w1 = view.addPlot()
w2 = view.addViewBox()
w2.setAspectLocked(True)
view.nextRow()
w3 = view.addPlot()
w4 = view.addPlot()
23
print("Generating data, this takes a few seconds...")
24 25 26 27 28 29

## There are a few different ways we can draw scatter plots; each is optimized for different types of data:


## 1) All spots identical and transform-invariant (top-left plot). 
## In this case we can get a huge performance boost by pre-rendering the spot 
Luke Campagnola's avatar
Luke Campagnola committed
30
## image and just drawing that image repeatedly.
31 32

n = 300
Luke Campagnola's avatar
Luke Campagnola committed
33
s1 = pg.ScatterPlotItem(size=10, pen=pg.mkPen(None), brush=pg.mkBrush(255, 255, 255, 120))
34 35 36 37 38
pos = np.random.normal(size=(2,n), scale=1e-5)
spots = [{'pos': pos[:,i], 'data': 1} for i in range(n)] + [{'pos': [0,0], 'data': 1}]
s1.addPoints(spots)
w1.addItem(s1)

Luke Campagnola's avatar
Luke Campagnola committed
39 40
## Make all plots clickable
lastClicked = []
41
def clicked(plot, points):
Luke Campagnola's avatar
Luke Campagnola committed
42 43 44
    global lastClicked
    for p in lastClicked:
        p.resetPen()
45
    print("clicked points", points)
Luke Campagnola's avatar
Luke Campagnola committed
46 47 48
    for p in points:
        p.setPen('b', width=2)
    lastClicked = points
49 50 51 52 53 54 55 56 57 58
s1.sigClicked.connect(clicked)



## 2) Spots are transform-invariant, but not identical (top-right plot). 
## In this case, drawing is as fast as 1), but there is more startup overhead
## and memory usage since each spot generates its own pre-rendered image.

s2 = pg.ScatterPlotItem(size=10, pen=pg.mkPen('w'), pxMode=True)
pos = np.random.normal(size=(2,n), scale=1e-5)
59
spots = [{'pos': pos[:,i], 'data': 1, 'brush':pg.intColor(i, n), 'symbol': i%5, 'size': 5+i/10.} for i in range(n)]
60 61 62 63 64 65 66 67 68 69 70 71 72
s2.addPoints(spots)
w2.addItem(s2)
s2.sigClicked.connect(clicked)


## 3) Spots are not transform-invariant, not identical (bottom-left). 
## This is the slowest case, since all spots must be completely re-drawn 
## every time because their apparent transformation may have changed.

s3 = pg.ScatterPlotItem(pxMode=False)   ## Set pxMode=False to allow spots to transform with the view
spots3 = []
for i in range(10):
    for j in range(10):
73
        spots3.append({'pos': (1e-6*i, 1e-6*j), 'size': 1e-6, 'pen': {'color': 'w', 'width': 8}, 'brush':pg.intColor(i*10+j, 100)})
74 75 76 77 78
s3.addPoints(spots3)
w3.addItem(s3)
s3.sigClicked.connect(clicked)


Luke Campagnola's avatar
Luke Campagnola committed
79
## Test performance of large scatterplots
80

Luke Campagnola's avatar
Luke Campagnola committed
81
s4 = pg.ScatterPlotItem(size=10, pen=pg.mkPen(None), brush=pg.mkBrush(255, 255, 255, 20))
82 83 84
pos = np.random.normal(size=(2,10000), scale=1e-9)
s4.addPoints(x=pos[0], y=pos[1])
w4.addItem(s4)
Luke Campagnola's avatar
Luke Campagnola committed
85
s4.sigClicked.connect(clicked)
86 87 88 89



## Start Qt event loop unless running in interactive mode.
90 91 92 93
if __name__ == '__main__':
    import sys
    if (sys.flags.interactive != 1) or not hasattr(QtCore, 'PYQT_VERSION'):
        QtGui.QApplication.instance().exec_()
94