Home | History | Annotate | only in /external/walt/pywalt
Up to higher level directory
NameDateSize
.gitignore06-Dec-20171K
LICENSE06-Dec-201711.1K
plothist.py06-Dec-2017853
pywalt/06-Dec-2017
README.md06-Dec-20173.9K
setup.py06-Dec-2017372
walt06-Dec-201791

README.md

      1 # PyWALT
      2 Python scripts for [WALT Latency Timer](https://github.com/google/walt) on Linux and ChromeOS.
      3 
      4  * Based on [ChromeOS scroll test implementation](https://chromium.googlesource.com/chromiumos/platform/touchbot/+/master/quickstep/)
      5  * Currently supprots tap and drag (scroll) latency measurements
      6  * For tests using evetest or drm (all touch and screen tests) pywalt needs to run as root
      7  * In order to find the name/number of your touch device run `evtest`. It will list available input devices and once you enter a device number it will show incoming events when you touch that touchpad / touchscreen.
      8 
      9 
     10 Synopsis:
     11 ```
     12 $ ./walt.py --help
     13 usage: walt.py [-h] [-i INPUT] [-s SERIAL] [-t TYPE] [-l LOGDIR] [-n N]
     14                [-p PORT] [-d]
     15 
     16 Run the touchpad drag latency test using WALT Latency Timer
     17 
     18 optional arguments:
     19   -h, --help            show this help message and exit
     20   -i INPUT, --input INPUT
     21                         input device, e.g: 6 or /dev/input/event6 (default: )
     22   -s SERIAL, --serial SERIAL
     23                         WALT serial port (default: /dev/ttyACM0)
     24   -t TYPE, --type TYPE  Test type: drag|tap|screen|sanity|curve|bridge
     25                         (default: drag)
     26   -l LOGDIR, --logdir LOGDIR
     27                         where to store logs (default: /tmp)
     28   -n N                  Number of laser toggles to read (default: 40)
     29   -p PORT, --port PORT  Port to listen on for the TCP bridge (default: 50007)
     30   -d, --debug           talk more (default: False)
     31  ```
     32 
     33 
     34 ## Tap Latency ##
     35 See the [tap latency section](../docs/usage/WALT_usage.md#tap-latency) in Android app usage doc.
     36 
     37 Below is output from an example run of a tap latency test that reads touch events from `/dev/input/event4` (in this case a touchpad). After 40 events (20 down and 20 up) are detected, the script prints median delays and exits.
     38 
     39 The input device option is mandatory since several touch devices might be preset (e.g. touchpad and touch screen). You can use a shorthand notation `-i 4` which is expanded to `-i /dev/input/event4`.
     40 
     41 The following must be run as root.
     42 
     43 ```
     44 $ ./walt.py -t tap -n 40 -i /dev/input/event4
     45 
     46 Starting tap latency test
     47 Clock zeroed at 1487105210 (rt 0.250 ms)
     48 Event: time 1487105212.048997, type 1 (EV_KEY), code 330 (BTN_TOUCH), value 1
     49 
     50 shock t 1990338, tap t 1487105212.048997, tap val 1. dt=63738.9
     51 Event: time 1487105212.262449, type 1 (EV_KEY), code 330 (BTN_TOUCH), value 0
     52 
     53 shock t 2219992, tap t 1487105212.262449, tap val 0. dt=47537.0
     54 Event: time 1487105212.702711, type 1 (EV_KEY), code 330 (BTN_TOUCH), value 1
     55 
     56 ...
     57 
     58 Processing data...
     59 dt_down = [63.74, 26.96, 27.14 ...
     60 dt_up = [47.54, 47.03, 41.52...
     61 
     62 Median latency, down: 23.9, up: 47.1
     63 ```
     64 
     65 ## Drag / Scroll Latency ##
     66 See the [drag latency section](../docs/usage/WALT_usage.md#dragscroll-latency) in Android app usage doc.
     67 
     68 Below is a drag latency measurement of the trackpad on Asus Flip. The trackpad input device is `/dev/input/event4` which was selected using the `-i 4` argument.
     69 
     70 The `-n 20` option tells the script to record 20 laser events. Any change in laser sensor reading counts as one event, therefore one crossing of the beam counts as two events (laser goes off and back on), and a full cycle of the finger going up and down counts as 4 events. This measurement recorded 20/4 = 5 full cycles of the finger moving up and down.
     71 
     72 In addition to moving your finger up and down please also move it slowly along the beam. The calculation used by pywalt needs some spread of the x coordinates for better precision.
     73 
     74 Drag latency uses evtest and must therefore be run as root.
     75 
     76 ```
     77 #./walt.py -t drag -i 4 -n 20
     78 Starting drag latency test
     79 Input device   : /dev/input/event4
     80 Serial device  : /dev/ttyACM1
     81 Laser log file : /tmp/WALT_2017_03_07__1532_12_laser.log
     82 evtest log file: /tmp/WALT_2017_03_07__1532_12_evtest.log
     83 Clock zeroed at 1488918733 (rt 0.306 ms)
     84 ....................
     85 Processing data, may take a minute or two...
     86 Drag latency (min method) = 21.07 ms
     87 ```
     88