gstreamer/examples/gst/ilat.py
David I. Lehn 5dc00dc590 trying to improve timing accuracy to figure out why python identity is 3x faster than the C one...
Original commit message from CVS:
trying to improve timing accuracy to figure out why python identity
is 3x faster than the C one...
2002-10-03 22:38:07 +00:00

111 lines
2.6 KiB
Python
Executable file

#!/usr/bin/env python
#
# gst-python
# Copyright (C) 2002 David I. Lehn
#
# This library is free software; you can redistribute it and/or
# modify it under the terms of the GNU Library General Public
# License as published by the Free Software Foundation; either
# version 2 of the License, or (at your option) any later version.
#
# This library is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Library General Public License for more details.
#
# You should have received a copy of the GNU Library General Public
# License along with this library; if not, write to the
# Free Software Foundation, Inc., 59 Temple Place - Suite 330,
# Boston, MA 02111-1307, USA.
#
# Author: David I. Lehn <dlehn@vt.edu>
#
import sys
from gstreamer import *
from gobject import GObject
import time
from identity import Identity
def update(sender, *args):
print sender.get_name(), args
def build(filters, b):
# create a new bin to hold the elements
bin = Pipeline('pipeline')
src = gst_element_factory_make('fakesrc', 'source');
assert src
src.set_property('silent', 1)
src.set_property('num_buffers', b)
sink = gst_element_factory_make('fakesink', 'sink')
assert sink
sink.set_property('silent', 1)
elements = [src] + filters + [sink]
# add objects to the main pipeline
for e in elements:
bin.add(e)
# connect the elements
previous = None
for e in elements:
if previous:
previous.connect(e)
previous = e
return bin
def filter(bin):
bin.set_state(STATE_PLAYING);
while bin.iterate(): pass
bin.set_state(STATE_NULL)
ccnt = 0
def c():
global ccnt
id = gst_element_factory_make ('identity', 'c identity %d' % ccnt);
assert id
id.set_property('silent', 1)
id.set_property('loop_based', 0)
ccnt += 1
return id
pcnt = 0
def py():
id = Identity()
assert id
global pcnt
id.set_name('py identity %d' % pcnt)
pcnt += 1
return id
def check(f, n, b):
fs = []
for i in range(n):
fs.append(f())
pipe = build(fs, b)
start = time.time()
ret = filter(pipe)
end = time.time()
print '%s b:%d i:%d t:%f' % (f, b, n, end - start)
return ret
def main():
"Identity timer and latency check"
gst_debug_set_categories(0L)
if len(sys.argv) < 3:
print 'usage: %s identites buffers' % (sys.argv[0],)
return -1
n = int(sys.argv[1])
b = int(sys.argv[2])
for f in (c, py):
check(f, n, b)
if __name__ == '__main__':
ret = main()
sys.exit (ret)