Skip to content

Jupyter notebooks for the LUSID SDK. LUSID is a bi-temporal investment management data platform with portfolio accounting capabilities.

Notifications You must be signed in to change notification settings

finbourne/finbourne-notebooks

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 

Repository files navigation

LUSID Jupyter notebooks

This repository contains Jupyter notebooks that show how to use LUSID. The examples in this repository are in Python. but the underlying LUSID functionality can be implemented using any language that has a HTTP client library. The notebooks are divided into two categories:

  • features - Notebooks showing specific LUSID features. These notebooks are short and specific.
  • use-cases - Notebooks showing sample business implementations or use-cases. These notebooks will combine various LUSID features to solve a business use-case. The use-case notebooks are generally longer than the features ones.

V2

V2/product/abor

filename title description features
Generate a Trial Balance (using Luminesce).ipynb Generate a trial balance Demonstrates how to setup LUSID to run a trial balance on a portfolio using Luminesce. abor, trial balance, transaction types, luminesce

V2/university/T00000-Using-Python-with-LUSID

filename title description features
Basic Python scripting.ipynb Basic Python scripting An introduction to Python and writing some Python code. python, variables, types, loops, functions, classes, objects, libraries
Using NumPy to efficiently work with large, multi-dimensional data.ipynb Using NumPy to efficiently work with large, multi-dimensional data An introduction to NumPy and processing multi-dimensional arrays. python, numpy, arrays, vectorised operations
Using Pandas to work with DataFrames.ipynb Using Pandas to work with DataFrames An introduction to the widely-used pandas library. python, pandas, dataframes
Using the FINBOURNE Python SDKs.ipynb Using the FINBOURNE Python SDKs An introduction to the FINBOURNE Python SDKs and tools for interacting with LUSID in our hosted Jupyter environment. python, sdk, Jupyter
What are Python and Jupyter_.ipynb What are Python and Jupyter? An introduction to Python and Jupyter, which are commonly used to view and analyse data using short Python scripts. python, Jupyter Notebooks

V2/university/T01001-LUSID-core-concepts

filename title description features
T01001-LUSID-core-concepts.ipynb LUSID core concepts Creating a portfolio containing equities, bonds and cash, trading positions, and viewing daily asset allocation. portfolios, instruments, transactions, holdings, valuation, market data

V2/university/T01002-Creating-an-instrument-master

filename title description features
T01002-Creating-an-instrument-master.ipynb Creating an instrument master Populating the LUSID instrument master from different data sources. portfolios, instruments, identifiers, data lineage

V2/university/T01003-Setting-up-a-transaction-portfolio-with-strategies

filename title description features
T01003-Setting-up-a-transaction-portfolio-with-strategies.ipynb Setting up a transaction portfolio with strategies Load transactions from two systems into separate investment strategies and calculate holdings grouped by strategy on trade date vs settlement date. portfolios, instruments, transactions, holdings

V2/university/T01005-Basic-portfolio-valuation

filename title description features
T01005-Basic-portfolio-valuation.ipynb Basic portfolio valuation Populating the LUSID instrument master from different data sources. portfolios, instruments, identifiers, data lineage

V2/university/T01006-Introduction-to-transaction-configuration

filename title description features
T01006-Breaking-out-broker-commission-as-a-separate-cash-holding.ipynb Breaking out broker commission as a separate cash holding Create a holdings report that breaks out money paid in broker commissions on equity purchases into a separate cash holding. properties, property definitions, SHKs
T01006-Ensuring-different-transaction-codes-have-the-same-economic-impact.ipynb Ensuring different transaction codes have the same economic impact Load transactions from different systems which use different transaction codes for the same economic activity and have LUSID apply a uniform economic impact when generating holdings. transactions, aliases, holdings
T01006-Ensuring-the-same-transaction-code-has-different-economic-impacts.ipynb Ensuring the same transaction code has different economic impacts Load transactions from different systems which use the same transaction code for the different economic activities and have LUSID apply the correct economic impact for each transaction when generating holdings. transactions, aliases, holdings
T01006-Reducing-the-cash-balance-by-the-cost-of-broker-commission.ipynb Reducing the cash balance by the cost of broker commission Creating custom transaction types to reduce cash balance by money paid out in broker commissions as well as the cost of equities purchased. properties, property definitions, SHKs

V2/university/T02002-Luminesce-syntax

filename title description features
Luminesce Syntax.ipynb Luminesce syntax An introduction to using Luminesce SQL. Luminesce, sql, query, providers

V2/university/T02003-Luminesce-Providers-and-Views

filename title description features
Providers and Views.ipynb Providers and views An introduction to using Luminesce read and write data providers, direct providers, and creating your own custom views. Luminesce, data provider, direct provider, writer, custom view

V2/university/T09001-EventsAndNotifications-WhatAreEvents

filename title description features
T09001-EventsAndNotifications-WhatAreEvents.ipynb Events and Notifications: What are events? An introduction to events and event types in the Notification Service notifications, events, subscriptions

V2/university/T09002-EventsAndNotifications-SubscribingToEvents

filename title description features
T09002-EventsAndNotifications-SubscribingToEvents.ipynb Events and Notifications: Subscribing to events An introduction to subscriptions and using the Notification API to subscribe to an event. notifications, events, subscriptions, filtering

V2/university/T09003-EventsAndNotifications-SendingNotifications

filename title description features
T09003-EventsAndNotifications-SendingNotifications.ipynb Events and Notifications: Sending notifications An introduction to setting up email and SMS notifications using the Notification API. notifications, events, email, SMS

V2/university/T09004-EventsAndNotifications-SendingWebhooks

filename title description features
T09004-EventsAndNotifications-SendingWebhooks.ipynb Events and Notifications: Sending webhooks An introduction to setting up internal and external webhooks using the Notification API. notifications, events, webhook

V2/university/T12002-Properties-DefiningProperties

filename title description features
T12002-Properties-DefiningProperties.ipynb Defining properties An introduction to creating properties in LUSID. property, property definition, data types

V2/university/T12003-Properties-PopulatingPerpetualPropertyValues

filename title description features
T12003-Properties-PopulatingPerpetualPropertyValues.ipynb Populating perpetual property values An introduction to creating perpetual properties and decorating a value on an entity. property, property definition, perpetual property

V2/university/T12004-Properties-PopulatingTimeVariantPropertyValues

filename title description features
T12004-Properties-PopulatingTimeVariantPropertyValues.ipynb Populating time-variant property values An introduction to creating time-variant properties and decorating a value on an entity. property, property definition, perpetual property

V2/university/T12005-Properties-ViewingAPropertysHistory

filename title description features
T12004-Properties-PopulatingTimeVariantPropertyValues.ipynb Viewing a property's history An introduction to viewing the bitemporal history of a property value. property value, bitemporality, asAt, effectiveAt

V1

V1/engineering-best-practises

filename title description features
Example Data Load.ipynb Example Data Load Loads some example data into LUSID cutlabels, portfolio groups, quotes, transactions, valuation
Paging and limiting LUSID's API calls.ipynb Paging and limiting LUSID's API calls Shows how to slice up large requests to LUSID into smaller requests using the limit and page parameters. paging
Requesting log details using the Insights API.ipynb Requesting details of inline valuation operations using the insights API Insights, Request Logs
Business Agility - migration between investment systems.ipynb Business agility Demonstration of how to migrate your data from one system to another. holdings, instruments, properties, reconciliations, set holdings, transaction configuration, transactions
Safely and efficiently test changes to your system.ipynb Testing system changes Demonstration of how to safely test changes to your data in a production environment derived portfolios, instrument definitions, instruments, set holdings, transactions
Set up a sandbox trading environment.ipynb Sandbox trading environment Learn how to setup a virtual trading environment in LUSID. aggregation, instruments, properties, quotes, reference portfolios, set holdings, transactions
Loading data with the Lusid-Python-Tools (LPT) package.ipynb Loading data with LUSID Python Tools Demonstrates how to load portfolios, instruments, holdings, and transactions. cocoon, instruments, portfolios, transactions

V1/features/entitlements

filename title description features
Access Metadata entitlements.ipynb Portfolio look-through in LUSID Demonstrates the use of policies to grant access to portfolios based on their Access Metadata (AMD) in LUSID. access metadata, amd, entitlements
Portfolio Entitlements.ipynb Portfolio Entitlements Demonstrates how to create policies/access control to various date items. entitlements
Property value entitlements.ipynb Portfolio look-through in LUSID Demonstrates the use of policies to grant access to property values in LUSID. entitlements, property values, transactions
Restrict Transactions between two effective dates.ipynb Create Policy to Restrict Portfolio Updates in a Period This notebook shows how to create a policy to restrict portfolio updates inbetween 2 effective dates by denying any write/delete activity to all portfolios in a given scope. policies, portfolios

V1/features/bi-temporality

filename title description features
Bi-temporal example.ipynb Bi-temporal Example Demonstration of how the asAt date can be used to get data from different system dates. bi-temporality, cocoon - identify_cash_items, holdings, transaction configuration, transactions
bitemporal-backtrade.ipynb Bi-temporal backtrade Demonstrates how to add a missing trade and then get back transactions using the AsAt date. bi-temporality

V1/features/horizon/data-feeds

filename title description features
Using TraderMade FX spot price data in LUSID.ipynb Using TraderMade FX spot price data in LUSID This notebook shows you how to access TraderMade spot FX data in LUSID quotes

V1/features/instruments

filename title description features
Bond.ipynb Bonds - Computing P&L and Accrued Interest for Bonds P&L, accrued interest, bond, bonds, recipes, valuations
BondWithAmortisation.ipynb Bonds - Amortisation P&L, a2b, amortisation, amortization, bond
Contract for Difference.ipynb Contract for Difference - Calculating Intraday P&L for CFD's with and without Daily Close outs P&L, cfd, close out, contract for difference, recipes, valuations
Equity Option.ipynb Equity Option - Booking and valuing an Equity Option with physical settlement P&L, equity option, physical settlement, recipes, valuations
Equity Options - Pricing and risk using Black-Scholes.ipynb Equity Option - Pricing and risk black scholes, equity option, exposure, inline valuations, market value, option delta
FX Forward.ipynb FX Forward - Valuation Workflow FX Forwards, complex market data, recipes, valuations
Funding Leg Swap.ipynb Variable Funding Leg + Equity or Cash Instrument Demonstrates creation and pricing of a funding leg with
variable notional and constructing a related position in
an stock or underlying instrument. This construct can be used
to represent the mechanics of a total return or equity swap.
aggregation, funding leg swap, instruments, market data store, quotes, results store
fx-forward-pricing-models.ipynb FX Forward Pricing Models FX Forwards, Pricing Models, Valuation
fx-inference-triangulation.ipynb FX Inference Triangulation FX, FX inference, Foreign Exchange, Triangulation
Interest Rate Swap.ipynb Interest Rate Swap Valuation Demonstrates pricing of an Interest Rate Swap based on a user defined Instrument. instruments, lifecycle events, market data store, quotes, results store, valuation
Mortgage Backed Securities.ipynb Mortgage Backed Securities in LUSID complex bond, mbs, mortgage backed securities, pool factor, schedule
Simple Equity.ipynb Equity - Computing P&L and Handling Dividends for Equities P&L, dividend, equity, recipes, valuations
Term Deposit.ipynb Term Deposit Valuation Demonstrates pricing of a Term Deposit Investment. instruments, lifecycle events, market data store, quotes, results store, valuation
Managing a transaction lifecycle using LUSID's properties.ipynb Managing the transaction lifecycle on LUSID Demonstration of how to use properties to manage the transaction lifecycle cocoon, data types, instruments, properties, transactions
Bond Pricing And Accrued Interest Calculation.ipynb Bond Pricing And Accrued Interest Calculation Demonstrates pricing a bond and calculating it's accrued interest based on a user defined Bond Instrument. aggregation, instruments, market data store, quotes, results store
FundingLeg Valuation with compounding interests.ipynb FundingLeg - Valuation with daily resets Compounding, FundingLeg, recipes, valuations
Futures Valuation with Differing Cost Basis Treatments (Synthetic Cash Method).ipynb Futures Valuation Workflow futures, recipes, transaction types, valuations
Futures Valuation with Differing Cost Basis Treatments.ipynb Futures Valuation Workflow futures, recipes, transaction types, valuations
Futures Valuation with notional cost and variation margin.ipynb Futures Valuation Workflow futures, recipes, transaction types, valuations
Total Return Swap Pricing With Reference Instrument.ipynb Total Return Swap Pricing With Reference Instrument Demonstrates pricing of an Total Return Swap with AssetLeg having the ReferenceInstrument as underlying. instruments, reference-instrument, valuation

V1/features/workflow

filename title description features
Call Api On File Upload.ipynb Call Api on File Upload events, luminesce, notifications, subscriptions

V1/product/abor

filename title description features
Create and Setup Chart of Accounts and General Ledger Accounts.ipynb Corporate Actions in LUSID Accounts, Chart of Accounts, Properties
Generate P&L with different accounting methods (FIFO and LIFO).ipynb Accounting methods Generating P&L with different accounting methods (FIFO and LIFO) accounting methods, cocoon, derived portfolios, transaction configuration
Using Custodian Accounts.ipynb Custodian Accounts in LUSID custodian accounts, transaction portfolios, transactions
Identifying Downstream Consumers affected by Backdated Corrections on a Locked Reporting Window.ipynb Identifying backdated corrections Demonstration of how to identify backdated corrections and their impact build transaction, cocoon - seed_data, insights, portfolio changes
Maintain a fund in multiple currencies and share classes.ipynb Modelling share classes in LUSID This notebook shows how to model a fund that operates in different currencies and share classes. adjust holdings, aggregation, holdings, instrument definitions, quotes, transactions
Creating Portfolios With Different Tax Lot Management Methods.ipynb Creating portfolios with different tax lot management methods This notebook demonstrates how to create transaction portfolios under different tax lot accounting methodologies. accounting, corporate actions, holdings, taxlots, transactions

V1/product/compliance

filename title description features
Configuring and Running Pre-Trade Compliance.ipynb Compliance in LUSID Compliance, OMS, Pre/Post trade checks

V1/product/edm

filename title description features
Relations.ipynb Relations Demonstrates how to create relationships between different portfolios. relations
Multi-Value Properties.ipynb Time-variant Properties (e.g. coupon schedule) in LUSID Illustrates the use of multi-value properties. coupon schedules, multi-valued properties, time-variant properties
TimeVariant Properties.ipynb Time-variant Properties (e.g. coupon schedule) in LUSID Illustrates the use of time-variant properties, a type of property that depend on different effective dates. coupon schedules, multi-valued properties, time-variant properties
Maintaining an instrument master in LUSID.ipynb Maintaining an instrument master Demonstrates how to import, update, retrieve, and delete instruments. instruments, properties, search

V1/product/ibor

filename title description features
Valuation.ipynb Valuation Demonstrates how to value a portfolio using a custom recipe. valuation
Booking subscriptions and redemptions.ipynb Booking subscriptions and redemptions Demonstration of how to model subscriptions and redemptions in LUSID cocoon - seed_data, holdings, transaction configuration
Manual journal entries to correct cash balances.ipynb Correcting cash balances with manual journal entries Demonstration of how to model manual journal entries in LUSID cancel transactions, cocoon, holdings, reconciliations, transaction configuration
Checking a portfolio for transaction updates since an AsAt time.ipynb Checking a portfolio for transaction updates since an AsAt time AsAt, GetPortfolioChanges API, Transaction Portfolios
Output Transactions.ipynb Output Transactions This notebook shows how LUSID uses synthetic transactions to fill in the gaps between user-instructed transactions and corporate actions. adjust holdings, build transactions, corporate actions, instruments, output transactions, portfolios, stock split, sub-holding keys, transactions
Processing Corporate Actions as native LUSID transitions.ipynb Processing Corporate Actions using LUSID transitions Demonstration of booking corporate actions using LUSID's transitions cocoon - seed_data, corporate actions, holdings, transaction configuration, transactions
Sub-holding Keys.ipynb Sub-Holding Keys Demonstration of how to set up and use sub-holding keys cocoon - seed_data, holdings, properties, prorated, sub-holding keys
Derived portfolios.ipynb Derived portfolios Shows how to use derived portfolios, a type of portfolio that inherits the contents from a parent portfolio. derived portfolios, holdings, transactions
Generating an IBOR extract with LUSID's GetHoldings method.ipynb Generating an IBOR extract Demonstrates how to use the GetHoldings API to generate IBOR extracts. cocoon - seed_data, holdings
Cancelling transactions in LUSID.ipynb Cancelling transactions Demonstration of how to use the CancelTransactions endpoint to cancel transactions in a LUSID portfolio. cancel transactions, cocoon - seed_data, holdings, transactions
Corporate Actions.ipynb Equity - Handling Corporate Actions bonus issue, corporate actions, dividend, equity, merger, recipes, spin-off, split, valuations
Generating Corporate actions natively in LUSID.ipynb Corporate Actions in LUSID Demonstrates how to create and apply a corporate action to a portfolio. corporate actions, derived portfolios, holdings, transactions
Generating holdings with the movements engine in LUSID.ipynb Generating holdings Generating holdings with the movements engine cocoon, instruments, transaction configuration, transactions
Get Holdings and Extract to csv.ipynb Get Holdings Shows how to use the Get Holdings endpoint and extract it to a csv holdings, transaction portfolios
Get a consolidated view of your data from multiple systems.ipynb Consolidating multiple systems Demonstration of how to migrate funds from multiple source systems into LUSID aggregation, holdings, instruments, properties, quotes, reconciliations, transaction configuration
How do I create holdings in LUSID.ipynb Creating holdings in LUSID Demonstrates how to load transactions based on custom transaction types and then compute the subsequent holdings. properties, transaction configuration, transactions
IBOR User Journey.ipynb IBOR User Journey A day in the life of an IBOR using LUSID aggregation, aggregation, cocoon, corporate actions, instruments, quotes, results store, sub-holding keys, transaction configuration, valuation reconciliation
Load Transactions from an External System.ipynb Loading transactions from an external system Demonstration of loading a transaction XML file from another "External System" into LUSID. cocoon, holdings, transactions
Perform a reconciliation.ipynb Reconciliations Demonstration of how to use LUSID to find discrepancies between versions of a portfolio adjust holdings, instruments, portfolio groups, properties, reconciliations, set holdings, transactions
Portfolio types and portfolio groups in LUSID.ipynb Portfolios and Portfolio Groups Demonstrates how to do various operations with portfolios and portfolio groups. commands, corporate actions, portfolio groups, portfolios, transactions
Running a Global Fund.ipynb Running a global fund Demonstration of using LUSID to run funds fed from multiple source systems across multiple regions aggregation, cocoon, cut labels, instruments, quotes, recipes, transaction configuration, transactions
Using cut-labels to manage your business across different time-zones.ipynb Cut Labels Demonstrates how to use cut labels to simplify timestamps and streamline usage of LUSID when used across multiple timezones. cut labels, holdings, instruments, transactions
Transactions with Trade To Portfolio Rate.ipynb Trade To Portfolio Rate (TTPR) Demo This notebook demonstrates how LUSID can resolve the Trade To Portfolio Rate for transactions booked with different trade currencies to the base portfolio currency. instruments, portfolios, quotes, recipes, trade to portfolio rate, transactions
Managing cashflows - capital calls and income distributions.ipynb Running a Fund with Investors Demonstration of how to manage a fund's subscriptions and capital calls with investors in LUSID holdings, instruments, properties, transaction configuration, transactions
Supporting a multi-asset class book of business.ipynb Bespoke asset classes Demonstration of how to create your own custom instrument inside LUSID, create a transaction against it and value it. aggregation, instruments, properties, quotes, transactions
Private Markets and Real Estate.ipynb Private Markets and Real Estate cash flows, excel, lookthrough, pdf, private markets, quotes, real estate, transactions
Backtesting with LUSID derived portfolios.ipynb Backtesting with derived portfolios Shows how to use a derived portfolio to test different trading strategies. aggregation, cocoon, derived portfolios, holdings, instruments, quotes
Calculating P&L on strategy.ipynb Calculating P&L on strategies Demonstration of how to use sub-holding keys and output transactions to track P&L on different strategies. cocoon - seed_data, derived portfolios, output transactions, properties, sub-holding keys, transactions
Composite returns adjusted for FX rates.ipynb Loading and caculating returns Demonstration of how to get aggregate returns adjusted by FX performance Composite portfolios, FX performance, Returns
Loading and calculating returns.ipynb Loading and calculating returns Demonstration of how to load and calculate returns in LUSID. Returns
Manage your investment strategies.ipynb Managing investment strategies Demonstration of how to compare how strategies are performing across all of our client's holdings, rather than just looking at a single portfolio in isolation. aggregation, data types, instruments, portfolio groups, properties, set holdings, transactions
Returns on composite portfolios.ipynb Loading and caculating returns Demonstration of how to load and calculate returns on composite portfolios in LUSID Composite portfolios, Returns
Track trading commissions in your portfolio.ipynb Track trading costs and commissions in your portfolio Demonstrates how to track commissions and fees separately from trade costs. cocoon, instruments, portfolio groups, properties, sub-holding keys, transaction configuration, transactions
Configuration Recipe Composability Using Recipe Composer.ipynb Recipe Composer Workflow recipe composers, recipes, valuations
Externally Calculated Metrics.ipynb Save externally calculated metrics and use them within the Valuation Engine Attributes
----------
Look-through valuation.ipynb Portfolio look-through in LUSID Shows how to compute the value of a child portfolio's holding as though they were directly held by the parent portfolio. holdings, look through, portfolios, securitised portfolios, valuations
Model selection using instrument features and properties.ipynb Model selection using instrument features and properties Demonstration of how to configure model selectio for valuation based on instrument features as well as instrument properties. Derived instrument properties, Instrument features, Instruments, Model selection
Real-time Valuation.ipynb Real-time valuation using streamed market data This notebook shows how to value a portfolio using real-time streamed market data recipes, valuation
SRS csv Example.ipynb Structured Results Store for storage of Portfolio data luminesce, structured_results_store, virtual_document
Simple Valuation.ipynb Simple valuation with default recipes This notebook shows how to value a portfolio using recipes, for an out of the box look at positions and valuations manifests, recipes, transactions, valuation
Valuations with recipes.ipynb Valuation with recipes This notebook shows how to value a portfolio using recipes with different pricing sources manifests, recipes, transactions, valuation

V1/product/oms

filename title description features
Incorporating live orders into your holdings view.ipynb Live Orders with Holdings in LUSID holdings, instruments, orders, portfolio, quotes, recipe

V1/product/pms

filename title description features
Rebalancing with a model portfolio.ipynb Rebalancing with a model portfolio This notebook shows how you can automatically generate transactions to rebalance a transaction portfolio with a model portfolio reference portfolios, transactions portfolios
Setting up a blended benchmark with floating weights.ipynb Setting up a blended benchmark Demonstration of how to load a blended benchmark.
We also show how floating weights with a periodic reset.
Floating weights, Reference portfolios, Securitised portfolios, Weights
Households.ipynb Households Demonstration of how to manage the holdings for an investor based on each Mandate & Household they are associated with. aggregation, instruments, portfolio groups, portfolios, properties, quotes, set holdings
Valuation Analysis.ipynb Valuation Debugging instruments, recipes, transactions, valuation, valuation manifest

V1/university/T02002-Luminesce-syntax

filename title description features
Luminesce Syntax.ipynb Luminesce Syntax Attributes
----------

V1/university/T02003-Luminesce-Providers-and-Views

filename title description features
Providers and Views.ipynb Luminesce Providers and Views Attributes
----------

About

Jupyter notebooks for the LUSID SDK. LUSID is a bi-temporal investment management data platform with portfolio accounting capabilities.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published