量化交易之HFT篇 - long beach - SigDiff.h

// .h

#ifndef LONGBEACH_SIGNALS_SIGDIFF_H
#define LONGBEACH_SIGNALS_SIGDIFF_H

#include <longbeach/signals/Signal.h>
#include <longbeach/signals/SignalSpec.h>
#include <longbeach/signals/SignalSpecMemberList.h>

#include <longbeach/core/TimeWindow.h>

namespace longbeach {
namespace signals {

///
/// Signal that is the difference of two price providers
/// i.e. s = a - b
/// Note:m_refPxP is aliased to 'b'
///

class SigDiffSpec : public SignalSpecT2<SigDiffSpec>
{
public:
    LONGBEACH_DECLARE_SCRIPTING();
    static void initMembers();

    SigDiffSpec();
    virtual instrument_t getInstrument() const { return a->getInstrument(); }
    virtual ISignalPtr build(SignalBuilder *builder) const;
    virtual void checkValid() const;
    // virtual bool compare(const ISignalSpec* other) const;
    // virtual void print(std::ostream &o, const LuaPrintSettings &ps) const;
    virtual void getDataRequirements(IDataRequirements *rqs) const;

    IPriceProviderSpecPtr a;
};

class SigDiff
    : public SignalSmonImpl
{
public:
    SigDiff( const ClientContextPtr& cc, const IPriceProviderPtr& a, const IPriceProviderPtr& b, const std::string& desc, bool vbose);

private:
    void onInputChange( const IPriceProvider& pxp );
    void eval();
    void recomputeState() const;

private:
    EventDistributorPtr m_spED;
    Priority m_evalPriority;
    IPriceProviderPtr m_a;
    IPriceProviderPtr m_b;
    std::vector<Subscription> m_subs;
    bool m_bEvalScheduled;
    TimeWindow<double> m_tw;
};

} // namespace signals
} // namespace longbeach

#endif // LONGBEACH_SIGNALS_SIGDIFF_H

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值