mirror of
https://github.com/wassname/catalyst.git
synced 2026-06-30 02:20:07 +08:00
81 lines
2.6 KiB
Python
81 lines
2.6 KiB
Python
import datetime
|
|
import zmq
|
|
import json
|
|
import pytz
|
|
import copy
|
|
import multiprocessing
|
|
import logging
|
|
import random
|
|
|
|
import qsim.util as qutil
|
|
|
|
class DataSource(object):
|
|
def __init__(self, feed, source_id):
|
|
self.source_id = source_id
|
|
self.logger = qutil.logger
|
|
self.feed = feed
|
|
self.sync = qutil.FeedSync(self.feed, str(source_id))
|
|
self.data_address = self.feed.data_address
|
|
self.logger.info("data address is {ds}".format(ds=self.feed.data_address))
|
|
self.cur_event = None
|
|
|
|
def start(self):
|
|
self.proc = multiprocessing.Process(target=self.run)
|
|
self.proc.start()
|
|
|
|
|
|
def open(self):
|
|
self.logger.info("starting data source:{source_id} on {addr}".format(source_id=self.source_id, addr=self.feed.data_address))
|
|
self.context = zmq.Context()
|
|
|
|
#create the data sink. Based on http://zguide.zeromq.org/py:tasksink2
|
|
self.data_socket = self.context.socket(zmq.PUSH)
|
|
self.data_socket.connect(self.data_address)
|
|
|
|
#signal we are ready
|
|
self.sync.confirm()
|
|
|
|
def run(self):
|
|
try:
|
|
self.open()
|
|
self.send_all()
|
|
self.close()
|
|
except Exception as err:
|
|
self.logger.exception("Unexpected failure running datasource - {name}.".format(name=self.source_id))
|
|
|
|
def send(self, event):
|
|
event['s'] = self.source_id
|
|
event['type'] = 'event'
|
|
self.data_socket.send(json.dumps(event))
|
|
|
|
def close(self):
|
|
done_msg = {}
|
|
done_msg['type'] = 'DONE'
|
|
done_msg['s'] = self.source_id
|
|
self.data_socket.send(json.dumps(done_msg))
|
|
self.data_socket.close()
|
|
self.context.term()
|
|
self.logger.info("finished processing data source")
|
|
|
|
class RandomEquityTrades(DataSource):
|
|
|
|
def __init__(self, sid, feed, source_id, count):
|
|
DataSource.__init__(self, feed, source_id)
|
|
self.count = count
|
|
self.sid = sid
|
|
|
|
def send_all(self):
|
|
trade_start = datetime.datetime.now()
|
|
minute = datetime.timedelta(minutes=1)
|
|
price = random.uniform(5.0,50.0)
|
|
|
|
for i in range(self.count):
|
|
price = price + random.uniform(-0.05,0.05)
|
|
event = {'sid':self.sid, 'dt':qutil.format_date(trade_start + (minute * i)),'price':price, 'volume':random.randrange(100,10000,100)}
|
|
self.send(event)
|
|
|
|
|
|
|
|
|
|
|