keep the original dumpLog, and create a dumpVrLog

This commit is contained in:
yunfeibai
2017-05-10 16:12:45 -07:00
parent c3e3e1e983
commit 719dba5cd1
2 changed files with 140 additions and 66 deletions

View File

@@ -8,60 +8,60 @@ import argparse
from time import sleep from time import sleep
def readLogFile(filename, verbose = True): def readLogFile(filename, verbose = True):
f = open(filename, 'rb') f = open(filename, 'rb')
print('Opened'), print('Opened'),
print(filename) print(filename)
keys = f.readline().decode('utf8').rstrip('\n').split(',') keys = f.readline().decode('utf8').rstrip('\n').split(',')
fmt = f.readline().decode('utf8').rstrip('\n') fmt = f.readline().decode('utf8').rstrip('\n')
# The byte number of one record # The byte number of one record
sz = struct.calcsize(fmt) sz = struct.calcsize(fmt)
# The type number of one record # The type number of one record
ncols = len(fmt) ncols = len(fmt)
if verbose: if verbose:
print('Keys:'), print('Keys:'),
print(keys) print(keys)
print('Format:'), print('Format:'),
print(fmt) print(fmt)
print('Size:'), print('Size:'),
print(sz) print(sz)
print('Columns:'), print('Columns:'),
print(ncols) print(ncols)
# Read data # Read data
wholeFile = f.read() wholeFile = f.read()
# split by alignment word # split by alignment word
chunks = wholeFile.split(b'\xaa\xbb') chunks = wholeFile.split(b'\xaa\xbb')
log = list() log = list()
if verbose: if verbose:
print("num chunks:") print("num chunks:")
print(len(chunks)) print(len(chunks))
chunkIndex = 0 chunkIndex = 0
for chunk in chunks: for chunk in chunks:
print("len(chunk)=",len(chunk)," sz = ", sz) print("len(chunk)=",len(chunk)," sz = ", sz)
if len(chunk) == sz: if len(chunk) == sz:
print("chunk #",chunkIndex) print("chunk #",chunkIndex)
chunkIndex=chunkIndex+1 chunkIndex=chunkIndex+1
values = struct.unpack(fmt, chunk) values = struct.unpack(fmt, chunk)
record = list() record = list()
for i in range(ncols): for i in range(ncols):
record.append(values[i]) record.append(values[i])
if verbose: if verbose:
print(" ",keys[i],"=",values[i]) print(" ",keys[i],"=",values[i])
log.append(record) log.append(record)
return log return log
numArgs = len(sys.argv) numArgs = len(sys.argv)
print ('Number of arguments:', numArgs, 'arguments.') print ('Number of arguments:', numArgs, 'arguments.')
print ('Argument List:', str(sys.argv)) print ('Argument List:', str(sys.argv))
fileName = "data/example_log_vr.bin" fileName = "log.bin"
if (numArgs>1): if (numArgs>1):
fileName = sys.argv[1] fileName = sys.argv[1]
@@ -70,39 +70,5 @@ print("filename=")
print(fileName) print(fileName)
verbose = True verbose = True
log = readLogFile(fileName,verbose)
# the index of the first integer in the vr log file for packed buttons readLogFile(fileName,verbose)
firstPackedButtonIndex = 13
# the number of packed buttons in one integer
numGroupedButtons = 10
# the number of integers for packed buttons
numPackedButtons = 7
# the mask to get the button state
buttonMask = 7
for record in log:
# indices of buttons that are down
buttonDownIndices = []
# indices of buttons that are triggered
buttonTriggeredIndices = []
# indices of buttons that are released
buttonReleasedIndices = []
buttonIndex = 0
for packedButtonIndex in range(firstPackedButtonIndex, firstPackedButtonIndex+numPackedButtons):
for packButtonShift in range(numGroupedButtons):
buttonEvent = buttonMask & record[packedButtonIndex]
if buttonEvent & 1:
buttonDownIndices.append(buttonIndex)
elif buttonEvent & 2:
buttonTriggeredIndices.append(buttonIndex)
elif buttonEvent & 4:
buttonReleasedIndices.append(buttonIndex)
record[packedButtonIndex] = record[packedButtonIndex] >> 3
buttonIndex += 1
if len(buttonDownIndices) or len(buttonTriggeredIndices) or len(buttonReleasedIndices):
print ('timestamp: ', record[1])
print ('button is down: ', buttonDownIndices)
print ('button is triggered: ', buttonTriggeredIndices)
print ('button is released: ', buttonReleasedIndices)

View File

@@ -0,0 +1,108 @@
import time
import math
from datetime import datetime
import struct
import sys
import os, fnmatch
import argparse
from time import sleep
def readLogFile(filename, verbose = True):
f = open(filename, 'rb')
print('Opened'),
print(filename)
keys = f.readline().decode('utf8').rstrip('\n').split(',')
fmt = f.readline().decode('utf8').rstrip('\n')
# The byte number of one record
sz = struct.calcsize(fmt)
# The type number of one record
ncols = len(fmt)
if verbose:
print('Keys:'),
print(keys)
print('Format:'),
print(fmt)
print('Size:'),
print(sz)
print('Columns:'),
print(ncols)
# Read data
wholeFile = f.read()
# split by alignment word
chunks = wholeFile.split(b'\xaa\xbb')
log = list()
if verbose:
print("num chunks:")
print(len(chunks))
chunkIndex = 0
for chunk in chunks:
print("len(chunk)=",len(chunk)," sz = ", sz)
if len(chunk) == sz:
print("chunk #",chunkIndex)
chunkIndex=chunkIndex+1
values = struct.unpack(fmt, chunk)
record = list()
for i in range(ncols):
record.append(values[i])
if verbose:
print(" ",keys[i],"=",values[i])
log.append(record)
return log
numArgs = len(sys.argv)
print ('Number of arguments:', numArgs, 'arguments.')
print ('Argument List:', str(sys.argv))
fileName = "data/example_log_vr.bin"
if (numArgs>1):
fileName = sys.argv[1]
print("filename=")
print(fileName)
verbose = True
log = readLogFile(fileName,verbose)
# the index of the first integer in the vr log file for packed buttons
firstPackedButtonIndex = 13
# the number of packed buttons in one integer
numGroupedButtons = 10
# the number of integers for packed buttons
numPackedButtons = 7
# the mask to get the button state
buttonMask = 7
for record in log:
# indices of buttons that are down
buttonDownIndices = []
# indices of buttons that are triggered
buttonTriggeredIndices = []
# indices of buttons that are released
buttonReleasedIndices = []
buttonIndex = 0
for packedButtonIndex in range(firstPackedButtonIndex, firstPackedButtonIndex+numPackedButtons):
for packButtonShift in range(numGroupedButtons):
buttonEvent = buttonMask & record[packedButtonIndex]
if buttonEvent & 1:
buttonDownIndices.append(buttonIndex)
elif buttonEvent & 2:
buttonTriggeredIndices.append(buttonIndex)
elif buttonEvent & 4:
buttonReleasedIndices.append(buttonIndex)
record[packedButtonIndex] = record[packedButtonIndex] >> 3
buttonIndex += 1
if len(buttonDownIndices) or len(buttonTriggeredIndices) or len(buttonReleasedIndices):
print ('timestamp: ', record[1])
print ('button is down: ', buttonDownIndices)
print ('button is triggered: ', buttonTriggeredIndices)
print ('button is released: ', buttonReleasedIndices)