Margin Interest Rate
Key Concepts
Set Models
The brokerage model of your algorithm automatically sets the margin interest rate model for each security, but you can override it. To manually set the margin interest rate model of a security, assign a model to the MarginInterestRateModel
property of the Security object.
// In Initialize var security = AddEquity("SPY"); security.MarginInterestRateModel = MarginInterestRateModel.Null;
# In Initialize security = self.add_equity("SPY") security.set_margin_interest_rate_model(MarginInterestRateModel.NULL)
You can also set the margin interest rate model in a security initializer. If your algorithm has a dynamic universe, use the security initializer technique. In order to initialize single security subscriptions with the security initializer, call SetSecurityInitializer
set_security_initializer
before you create the subscriptions.
// In the Initialize method, set the security initializer to seed initial the prices and models of assets. SetSecurityInitializer(new MySecurityInitializer(BrokerageModel, new FuncSecuritySeeder(GetLastKnownPrices))); class MySecurityInitializer : BrokerageModelSecurityInitializer { public MySecurityInitializer(IBrokerageModel brokerageModel, ISecuritySeeder securitySeeder) : base(brokerageModel, securitySeeder) {} public override void Initialize(Security security) { // First, call the superclass definition. // This method sets the reality models of each security using the default reality models of the brokerage model. base.Initialize(security); // Next, overwrite some of the reality models security.MarginInterestRateModel = MarginInterestRateModel.Null; } }
# In the Initialize method, set the security initializer to seed initial the prices and models of assets. self.set_security_initializer(MySecurityInitializer(self.brokerage_model, FuncSecuritySeeder(self.get_last_known_prices))) # Outside of the algorithm class class MySecurityInitializer(BrokerageModelSecurityInitializer): def __init__(self, brokerage_model: IBrokerageModel, security_seeder: ISecuritySeeder) -> None: super().__init__(brokerage_model, security_seeder) def initialize(self, security: Security) -> None: # First, call the superclass definition. # This method sets the reality models of each security using the default reality models of the brokerage model. super().initialize(security) # Next, overwrite some of the reality models security.set_margin_interest_rate_model(MarginInterestRateModel.NULL)
To view all the pre-built margin interest rate models, see Supported Models.
Default Behavior
The brokerage model of your algorithm automatically sets the margin interest rate model of each security. The default brokerage model is the DefaultBrokerageModel
, which sets the NullMarginInterestRateModel.
Model Structure
Margin interest rate models should implement the IMarginInterestRateModel
interface. Extensions of the IMarginInterestRateModel
interface must implement the ApplyMarginInterestRate
apply_margin_interest_rate
method, which applies margin interest payments to the portfolio.
// In the Initialize method, set the margin interest rate model security.SetMarginInterestRateModel(new MyMarginInterestRateModel()); // Define the custom margin interest rate model public class MyMarginInterestRateModel : IMarginInterestRateModel { public void ApplyMarginInterestRate(MarginInterestRateParameters marginInterestRateParameters) { var holdings = marginInterestRateParameters.Security.Holdings; var positionValue = holdings.GetQuantityValue(holdings.Quantity); positionValue.Cash.AddAmount(-1); } }
# In the Initialize method, set the margin interest rate model security.set_margin_interest_rate_model(MyMarginInterestRateModel()) # Define the custom margin interest rate model class MyMarginInterestRateModel: def apply_margin_interest_rate(self, margin_interest_rate_parameters: MarginInterestRateParameters) -> None: holdings = margin_interest_rate_parameters.security.holdings position_value = holdings.get_quantity_value(holdings.quantity) position_value.cash.add_amount(-1)
For a full example algorithm, see this backtestthis backtest.
The ApplyMarginInterestRate
apply_margin_interest_rate
method is automatically called at the top of each hour.