def run(conf = {}):
    """
    调度整个模块。
    """
    date = conf.get('date',Date.getDate())
    logging.info("Statistics module is started.Run date is %s" % date)
    conf["projectPath"] = os.path.join(conf.get("SYS_HOME"),conf.get("STATISTICS_PROJECT_PATH"))
    check = Check.Check(conf = conf)
    if not check.checkStatisticsCondition(date = date):
        logging.warning("Statistics is invailable.date:%s" % date)
        return False

    accuracy=Accuracy(conf)
    accuracyResult = accuracy.compute(date = date)
    if accuracyResult !=False:
        path = os.path.join(conf.get("SYS_HOME",SYS_HOME),conf.get("ACCURACY_DATA_PATH",ACCURACY_DATA_PATH),date+SUFFIX)
        Dumper.dump(data = accuracyResult,path = path)
        logging.info("Accuracy statistics run success.Result is dump to %s" % path )
        logging.debug("Accuracy statistics run result %s" % accuracyResult)
    else:
        logging.info("Accuracy statistics run failed.")

    profile = Profile(conf)
    profileResult = profile.profile()
    if profileResult !=False:
        path = os.path.join(conf.get("SYS_HOME",SYS_HOME),conf.get("PROFILE_PATH",PROFILE_DATA_PATH),date+SUFFIX)
        Dumper.dump(data = profileResult,path = path)
        logging.info("Profile statistics run success.Result is dump to %s"%path)
        logging.debug("Profile statistics run result %s" % profileResult)
        return True
    else:
        logging.info("Profile statistics run failed.")
        return False
def run(conf={}):
    stock=conf.get("stock",Stock(conf))
    date=conf.get('date',Date.getDate())
    logging.info("Start strategic app.Date is %s" %date)

    check = Check.Check(conf = conf)
    if not check.checkStrategicCondition(date = date):
        logging.warning("Strategic is invailable.date:%s" % date)
        return False

    strategic_conf ={}
    strategic_conf.update(conf)
    strategic_conf['stock']=stock
    strategic = Strategic(conf = strategic_conf)
    strategicResult = strategic.compute()
    path = os.path.join(conf.get("SYS_HOME"),conf.get("STRATEGIC_DATA_PATH",STRATEGIC_DATA_PATH),date+SUFFIX)
    logging.debug("Dump strategic result to %s.\nStrategic result is:\n %s" % (strategic.data,path))
    Dumper.dump(path = path,data = strategicResult)
    logging.info("Finish strategic compute of date %s "%date)


    logging.info("Start Bayes statistics.")
    bayesHandler = Bayes(conf)
    bayes = bayesHandler.posterior()
    if bayes != False:
        Dumper.dump(data = bayes,\
        path = os.path.join(conf.get("SYS_HOME"),conf.get("BAYES_DATA_PATH",BAYES_DATA_PATH),date+SUFFIX))
        logging.info("Bayes statistics run success.")
        logging.debug("Bayes statistics run result %s" % bayes)
        return True
    else:
        logging.info("Bayes statistics run fail.")
        return False
Example #3
0
def run(conf = {}):
    """
    传入日期,读入projects和传入日期的statistics.进行计算,得到符合条件的strategic和股票code
    例如一个report的project为“短线股票池”,里面定义了多少天内上涨概率大于多少的公式。如果某策略的统计数据符合该公式,则返回该策略的股票代码及其他相关信息。
    >> reporter.run({"statistics":case['statistics']})
    
    更新 statistics => probability
    注:这里statistics主要指统计得到的bayes值.
    """
    logging.info("Report program start.")
    logging.debug("Report config %s"%str(conf))

    conf['REPORTER_PROJECT_PATH']=os.path.join(\
        conf.get("SYS_HOME",""),\
        conf.get("REPORTER_PROJECT_PATH",REPORTER_PROJECT_PATH))

    options={}
    options.update(conf)
    options.update(conf)
    conf=options
    date=conf.get('date',Date.getDate())
    check = Check.Check(conf = conf)
    if not check.checkReporterCondition(date = date):
        logging.warning("Reporter is invailable.date:%s" % date)
        return False
    #get statistics
    path = os.path.join(conf.get("SYS_HOME"),\
        conf.get("BAYES_DATA_PATH",BAYES_DATA_PATH),\
        date+SUFFIX)
    statistics = conf.get("statistics" , Reader.read(path = path)) #载入指定日期的监控策略
    if not statistics:
        logging.warning("Reporter not find statistics data.Exit it.")
        return None

    #filter by conditions
    strategic = Strategic(date = date ,conf = conf)
    report = Report(conf = conf)
    report.compute(strategic,statistics)

    #dump result
    if report != False:
        path = os.path.join(conf.get("SYS_HOME",""),\
            conf.get("REPORTER_DATA_PATH",REPORTER_DATA_PATH),date+SUFFIX)
        Dumper.dump(path = path , data = report.data)
        logging.info("Reporter result : %s" % str(report.data))
    else:
        logging.info("Reporter run fail.")
    return report
Example #4
0
def run(conf={}):
    date = Date.getInstantDate() #instant date 应该Date.getDate +1,key的编码问题
    conf['date']=date

    logging.info("start downloading instant data.Date is %s" % conf['date'])
    downloader = Downloader(conf = conf)
    downloader.download("instant")

    logging.info("start computing instant data.Date is %s"% conf['date'])
    stock=Stock(conf)
    extract = Extract(conf = conf)
    extract.extract(project = "instant", stock = stock, date = date)

    logging.info("start instant strategic data.Date is %s" %conf['date'])
    strategic_conf ={}
    strategic_conf.update(conf)
    strategic_conf['stock']=stock
    strategic = Strategic(conf = strategic_conf)
    strategicResult = strategic.compute()
    Dumper.dump(path = os.path.join(conf.get("SYS_HOME"),conf.get("INSTANT_DATA_PATH"),"strategic.json"),data = strategicResult)

    logging.info("Start Bayes statistics.Date is %s"% conf['date'])
    conf['strategic']=strategic
    bayesHandler = Bayes(conf)
    bayes = bayesHandler.posterior()
    Dumper.dump(path = os.path.join(conf.get("SYS_HOME"),conf.get("INSTANT_DATA_PATH"),"bayes.json"),data = bayes)

    logging.info("Start report.Date is %s"% conf['date'])
    report = Report(conf = conf)
    report.compute(strategic = strategic , statistics = bayes)
    print report

    #profile
    profile_conf =  {"stock":stock,"date":date}
    profile_conf.update(conf)
    profile = Profile(profile_conf)
    profile.viewProfile()

    path = os.path.join(conf.get("SYS_HOME"),conf.get("INSTANT_REPORT_DATA_PATH"))
    Dumper.dump(path = path,data = report.data)
    return report.data