Skip to content

Commit

Permalink
Standarize universe data type implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
Martin-Molinero committed Mar 13, 2024
1 parent 977f8ca commit fc2ddc6
Show file tree
Hide file tree
Showing 4 changed files with 609 additions and 9 deletions.
20 changes: 17 additions & 3 deletions DemonstrationUniverse.cs
Original file line number Diff line number Diff line change
Expand Up @@ -38,18 +38,32 @@ public override void Initialize()
SetCash(100000);

// add a custom universe data source (defaults to usa-equity)
AddUniverse<MyCustomDataUniverseType>("MyCustomDataUniverseType", Resolution.Daily, data =>
var universe = AddUniverse<MyCustomDataUniverseType>(data =>
{
foreach (var datum in data)
foreach (MyCustomDataUniverseType datum in data)
{
Log($"{datum.Symbol},{datum.SomeCustomProperty},{datum.SomeNumericProperty}");
}

// define our selection criteria
return from d in data
return from MyCustomDataUniverseType d in data
where d.SomeCustomProperty == "buy"
select d.Symbol;
});

var history = History(universe, 1).ToList();
if (history.Count != 1)
{
throw new System.Exception($"Unexpected historical data count!");
}
foreach (var dataForDate in history)
{
var coarseData = dataForDate.ToList();
if (coarseData.Count < 300)
{
throw new System.Exception($"Unexpected historical universe data!");
}
}
}

/// <summary>
Expand Down
14 changes: 11 additions & 3 deletions DemonstrationUniverse.py
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@
### <summary>
### Example algorithm using the custom data type as a source of alpha
### </summary>
class CustomDataUniverse(QCAlgorithm):
class CustomDataUniverse(QCAlgorithm):
def Initialize(self):
''' Initialise the data and resolution required, as well as the cash and start-end dates for your algorithm. All algorithms must initialized. '''

Expand All @@ -28,7 +28,15 @@ def Initialize(self):
self.SetCash(100000)

# add a custom universe data source (defaults to usa-equity)
self.AddUniverse(MyCustomDataUniverseType, "MyCustomDataUniverseType", Resolution.Daily, self.UniverseSelection)
universe = self.AddUniverse(MyCustomDataUniverse, self.UniverseSelection)

history = self.History(universe, TimeSpan(1, 0, 0, 0))
if len(history) != 1:
raise ValueError(f"Unexpected history count {len(history)}! Expected 1")

for dataForDate in history:
if len(dataForDate) < 300:
raise ValueError(f"Unexpected historical universe data!")

def UniverseSelection(self, data):
''' Selected the securities
Expand All @@ -37,7 +45,7 @@ def UniverseSelection(self, data):
:return: List of Symbol objects '''

for datum in data:
self.Log(f"{datum.Symbol},{datum.Followers},{datum.DayPercentChange},{datum.WeekPercentChange}")
self.Log(f"{datum.Symbol},{datum.SomeNumericProperty},{datum.SomeCustomProperty}")

# define our selection criteria
return [d.Symbol for d in data if d.SomeCustomProperty == 'buy']
Expand Down
8 changes: 5 additions & 3 deletions MyCustomDataUniverseType.cs → MyCustomDataUniverse.cs
Original file line number Diff line number Diff line change
Expand Up @@ -21,14 +21,15 @@
using QuantConnect.Data;
using System.Collections.Generic;
using System.Globalization;
using QuantConnect.Data.UniverseSelection;

namespace QuantConnect.DataSource
{
/// <summary>
/// Example custom data type
/// </summary>
[ProtoContract(SkipConstructor = true)]
public class MyCustomDataUniverseType : BaseData
public class MyCustomDataUniverse : BaseDataCollection
{
/// <summary>
/// Some custom data property
Expand Down Expand Up @@ -67,7 +68,8 @@ public override SubscriptionDataSource GetSource(SubscriptionDataConfig config,
"universe",
$"{date.ToStringInvariant(DateFormat.EightCharacter)}.csv"
),
SubscriptionTransportMedium.LocalFile
SubscriptionTransportMedium.LocalFile,
FileFormat.FoldingCollection
);
}

Expand All @@ -85,7 +87,7 @@ public override BaseData Reader(SubscriptionDataConfig config, string line, Date

var someNumericProperty = decimal.Parse(csv[2], NumberStyles.Any, CultureInfo.InvariantCulture);

return new MyCustomDataUniverseType
return new MyCustomDataUniverse
{
Symbol = new Symbol(SecurityIdentifier.Parse(csv[0]), csv[1]),
SomeNumericProperty = someNumericProperty,
Expand Down
Loading

0 comments on commit fc2ddc6

Please sign in to comment.