C/C++ Programming Tutorial A

Total Page:16

File Type:pdf, Size:1020Kb

C/C++ Programming Tutorial A C/C++ Programming Tutorial A A.1 Introduction This tutorial introduces a minimal subset of C/C++ that should be sufficient to complete the optional progamming exercises in this book. The programs here run from the command line—the Command Prompt applica- tion in Windows, or the Terminal application in MacOS X or other flavors of UNIX. The discussion here assumes some basic knowledge of how to use the command line. You should know at a minimum how to start and exit the command line application, and how to list files and folders (dir on Windows, and ls on MacOS X or other UNIX systems). You should also know how to parse file pathnames on your system (for example, “C:\Files\test.cpp” on Windows which means that the file test.cpp is in the top- level folder “My Files” which is on the drive labelled “C”. On MacOS X we could have “/home/myname/test.cpp” which means that test.cpp is in the folder “myname” which is in the enclosing top-level folder “home”.) C/C++ is a commonly used computer programming language. C++ is an extra layer on top of an older language called C. We will not use this extra layer except for the routines for reading and writing to the computer screen (input-output or I/O). C/C++ is a compiled language. This means that programming proceeds in two steps. First, we write the source program in C/C++. This is in a plain text file with the filename ending in the extension .cpp (e.g., test.cpp). Second, we compile the source program by running a compiler such as g++. If using g++, we could type in a command such as the following at the command prompt: g++ test.cpp -o test.exe © Springer Nature Singapore Pte Ltd. 2020 299 S. Lynn, Valuation for Accountants, Springer Texts in Business and Economics, https://doi.org/10.1007/978-981-15-0357-3 300 A C/C++ Programming Tutorial This command would read the source program test.cpp and create an executable file (a set of machine-readable instructions) called test.exe. We can directly run the file test.exe by entering its name at the command prompt: test.exe On some UNIX platforms such as MacOS X, we may need to first set the user permissions to make the file runnable, by issuing the following command at the command prompt: chmod u+x test.exe We may also need to specify the path when running the executable, as follows: ./test.exe where . is UNIX shorthand for the current directory (folder). This is because UNIX systems are often configured not to look for executables in the current directory unless this directory is specifically indicated when calling the executable. A.2 Getting the C/C++ Compiler While any C/C++ compiler should work fine with our programs, it is recommended that you get the GNU C/C++ compiler gcc (or its near-equivalent Clang). These work similarly on all major platforms. We will assume the GNU C/C++ compiler in the examples that follow. To get the GNU C/C++ compiler for Windows, you can install mingw (minimal- ist GNU for Windows), currently available at http://www.mingw.org. An alternative is Cygwin, which is currently available at http://www.cygwin.com. To install the gcc compiler on Mac OS X (actually Clang), you would install the command line tools for XCode, from the Apple developer website at http:// developer.apple.com. On other UNIX-based systems such as Linux, the GNU compiler or equivalent is typically a standard part of the platform and is likely to be pre-installed. If not pre- installed, it should be easy to install using the standard package installation process. Check your system documentation. You can also install gcc (actually Clang) on a smartphone running Android by installing the “termux” app, which produces a UNIX command prompt. Once installed, you can use the following command to install gcc: pkg install clang It is also desirable on Termux to install a user-friendly text editor such as nano on Termux to edit programs (pkg install nano). A.3 Program Format 301 A.3 Program Format All the programs in our exercises follow a consistent format. They ask the user to input various parameters for some model, say a binomial lattice model for option valuation. Then they run the model with these parameters. Finally they print out the model output, say the option value. All the action takes place at the command prompt. So to run these programs, open a command prompt window in Windows, or run the Terminal app in MacOS X (or Linux etc.). To illustrate the basic format of a program, we will start with a simple program that does nothing. Let us call this program donothing.cpp. A.3.1 The #include Directive The opening lines of the program are calls to include various standard C source files in our program so that we can use the standard routines defined in these files. We will consistently include two standard files: iostream, which defines the standard C++ I/O routines, and “math.h” which defines several math functions (in plain C) that we will use in our programs. To include a standard C/C++ source file, we use the invocation: #include <... > Task Try to write out the commands to include iostream and math.h, before looking at the solution given below: Solution #include <iostream > #include <math.h> A.3.2 The Program Body C programs are built up out of functions. A function has a standard format as follows: Type_Of_Return_Value name_of_function ( list_of_inputs ){ C/C++ statement_ending_in_semicolon ; C/C++ statement_ending_in_semicolon ; ... } Every runnable program must have a function called main. By convention, this function returns a value of type “int” or integer (a positive or negative whole number). 302 A C/C++ Programming Tutorial Task Create and compile a program donothing.cpp with our standard headers followed by an empty main function (the input list is blank and there are no C/C++ statements in the body). This must be a plain text file. So do not use a word-processor like MS Word to create the file. Use a text editor like Notepad on Windows or TextEdit on the Mac. After saving, compile and check that your program works by running the executable donothing.exe. Be careful that C/C++ is case-sensitive. This means that “main” is not the same as “Main” or “mAin” or “MAIN”. Solution (donothing.cpp) #include <iostream > #include <math.h> int main(){ } Compiler Command g++ donothing.cpp -o donothing.exe A.3.3 Comments Comments are memos to the human reader (you, the programmer) that are ignored by the compiler. Comments in C are enclosed within the symbols /∗ ...∗/. In addition, C++ allows comments that start with the symbol // and run to the end of the current line. Task Edit donothing.cpp to include C- and C++-style comments that say “This program does nothing”. You can put them anywhere in the program. Solution (donothing.cpp) #include <iostream > #include <math.h> // This program does nothing int main(){ / ∗ This program does nothing ∗ / } A.4 Printing Text to the Screen 303 A.4 Printing Text to the Screen Strings of text are enclosed in double inverted commas (double quotes) as in “hello”. These are called strings in computer programming jargon. The C++ command to print a string to the screen is: std::cout «... The prefix std signifies that cout is a command that is defined in the standard namespace (“std”). This is to avoid any conflict in case cout is defined somewhere else in your program. The items to be printed to the screen are separated by the symbol “«”. You can remember this by thinking of an open mouth spitting out something (output). The items to be printed to the screen could include strings, variables (to be discussed soon), mathematical expressions (to be discussed later), and a special command to signify end of line: std::endl. For example, if we have a variable named x and we want to print out “The value of x is: ” followed by the value of x, followed by a new line, we would include the C++ statement: std :: cout << ‘‘The value of x is : ’’ << x << std :: endl ; Do not forget the semicolon. In the body of a function, every C/C++ statement must end with a semicolon. Task Create and run a program called helloworld.cpp (executable helloworld.exe) that prints the text “Hello World!” followed by a new line. Solution (helloworld.cpp) #include <iostream > #include <math.h> int main(){ std :: cout << "Hello world !" << std :: endl ; } 304 A C/C++ Programming Tutorial A.5 Variables A variable is an item that can take on different values in the course of a program. In C/C++, although a variable can take on different values, the values must all be of the same type, for example whole number or decimal. We need to declare the type of a variable before we use that variable. We will just consider two types in our minimal subset of C/C++ (there are many others): int an integer, a whole number which could be positive or negative, e.g., -1, 2, 3, 0, 500 are all integers. double a decimal, e.g., 7.89, 0.1453, -1.0, or -1.859. To declare the type of a variable, we type int or double followed by the name of the variable and ending of course in a semicolon. For example, to declare an integer called x, we type int x; To declare a double named y, we type double y; We can declare multiple variables of the same type by separating the variable names with commas.
Recommended publications
  • The Reposit Project
    The Reposit Project An Improved Solution For Autogenerating QuantLibXL Source Code Father Guido Sarducci's Five Minute University In five minutes, you learn what the average college graduate remembers five years after he or she is out of school. https://www.youtube.com/watch?v=kO8x8eoU3L4 • Replace the gensrc Python script with the Reposit Project reposit SWIG module Five Second • QuantLibAddin object wrapper code autogenerated not handwritten University: • Objective: Export all of QuantLib to Excel 2 Reposit Project Website http://www.quantlib.org/reposit 3 Documentation http://quantlib.org/reposit/documentation.html Documentation for the Reposit project. docs/ObjectHandler-docs-1.5.0-html/index.html Documentation for the ObjectHandler repository. docs/swig/Reposit.html Documentation for the SWIG module. 4 Overview ObjectHandler ObjectHandler • Object repository namespace ObjectHandler { • Object base class map<string, Object*> repository; QuantLibObjects class Object • Classes which inherit from { /*...*/}; Object and wrap QuantLib template <class T> • Native support for serialization class LibraryObject : public Object { /*...*/}; QuantLibAddin } • Functional interface which exports QuantLibObjects to inheritance QuantLib QuantLibObjects target platforms (C++, Excel) namespace QuantLib { namespace QuantLibObjects { class Instrument composition class Instrument : gensrc (deprecated) { /*...*/}; public ObjectHandler::LibraryObject • autogenerates addin source <QuantLib::Instrument> { /*...*/}; code composition SWIG reposit module class
    [Show full text]
  • Quantlib Cython Wrapper Documentation Release 0.1.1
    Quantlib cython wrapper Documentation Release 0.1.1 Didrik Pinte & Patrick Hénaff Aug 30, 2018 Contents 1 Getting started 3 1.1 PyQL - an overview...........................................3 1.2 Building and installing PyQL......................................4 1.3 Installation from source.........................................4 1.4 Installation from source on Windows..................................5 2 Tutorial 9 3 User’s guide 11 3.1 Business dates.............................................. 11 3.2 Reference................................................. 15 3.3 Mlab................................................... 16 3.4 Notebooks................................................ 17 4 Reference guide 19 4.1 Reference documentation for the quantlib package......................... 19 4.2 How to wrap QuantLib classes with cython............................... 21 5 Roadmap 25 6 Documentation 27 7 Indices and tables 29 Python Module Index 31 i ii Quantlib cython wrapper Documentation, Release 0.1.1 Contents: Contents 1 Quantlib cython wrapper Documentation, Release 0.1.1 2 Contents CHAPTER 1 Getting started 1.1 PyQL - an overview Why building a new set of QuantLib wrappers for Python? The SWIG wrappers provide a very good coverage of the library but have a number of pain points: • Few Pythonic optimisations in the syntax: the python code for invoking QuantLib functions looks like the C++ version; • No docstring or function signature are available on the Python side; • The debugging is complex, and any customization of the wrapper involves complex programming; • The build process is monolithic: any change to the wrapper requires the recompilation of the entire project; • Complete loss of the C++ code organisation with a flat namespace in Python; • SWIG typemaps development is not that fun. For those reasons, and to have the ability to expose some of the QuantLib internals that could be very useful on the Python side, we chose another road.
    [Show full text]
  • Dr. Sebastian Schlenkrich Institut Für Mathematik Bereich Stochastik
    Dr. Sebastian Schlenkrich Institut für Mathematik Bereich Stochastik November 13, 2020 Interest Rate Modelling and Derivative Pricing, WS 2020/21 Exercise 1 1. Preliminaries Exercises will comprise in large parts setting up, extending and modifying Python scripts. We will also use the open source QuantLib financial library which facilitates many financial modelling tasks. You will need a Python environment with the QuantLib package included. We will demonstrate the examples with Anaconda Python and Visual Studio Code IDE and Jupyter .1 A Python environment with QuantLib (and some other useful packages) can be set up along the following steps (a) Download and install Anaconda Python 3.x from www.anaconda.com/download/. The Vi- sual Studio Code IDE comes with the Anaconda installer. Jupyter Notebook also comes with Anaconda. (b) Set up a Python 3.7 environment in Anaconda Navigator > Environments > Create (c) Select the new Python 3.7 environment, run ’Open Terminal’ and install the packages Pandas, Matplotlib and QuantLib: pip install pandas pip install numpy pip install scipy pip install matplotlib pip install QuantLib (d) Test Python environment and QuantLib: Launch Visual Studio Code from Anaconda Nav- igator > Home (make sure your Python 3.6 environment is still selected). Select a working directory via File > Open Folder. Create a new file test.py. Include Python script import pandas as pd import matplotlib.pyplot as plt import QuantLib as ql d = ql.Settings.getEvaluationDate(ql.Settings.instance()) print(d) Execute the script via right click on test.py and ’Run Python File in Terminal’. You should see a terminal output like November 13th, 2020 (e) Python/QuantLib examples will be provided via GitHub at https://github.com/sschlenkrich/QuantLibPython.
    [Show full text]
  • Rquantlib: Interfacing Quantlib from R R / Finance 2010 Presentation
    QuantLib RQuantLib Fixed Income Summary RQuantLib: Interfacing QuantLib from R R / Finance 2010 Presentation Dirk Eddelbuettel1 Khanh Nguyen2 1Debian Project 2UMASS at Boston R / Finance 2010 April 16 and 17, 2010 Chicago, IL, USA Eddelbuettel and Nguyen RQuantLib QuantLib RQuantLib Fixed Income Summary Overview Architecture Examples Outline 1 QuantLib Overview Timeline Architecture Examples 2 RQuantLib Overview Key components Examples 3 Fixed Income Overview and development Examples 4 Summary Eddelbuettel and Nguyen RQuantLib The initial QuantLib release was 0.1.1 in Nov 2000 The first Debian QuantLib package was prepared in May 2001 Boost has been a QuantLib requirement since July 2004 The long awaited QuantLib 1.0.0 release appeared in Feb 2010 QuantLib RQuantLib Fixed Income Summary Overview Architecture Examples QuantLib releases Showing the growth of QuantLib over time Growth of QuantLib code over its initial decade: From version 0.1.1 in Nov 2000 to 1.0 in Feb 2010 0.1.1 0.1.9 0.2.0 0.2.1 0.3.0 0.3.1 0.3.3 0.3.4 0.3.5 0.3.7 0.3.8 0.3.9 0.3.10 0.3.11 0.3.12 0.3.13 0.3.14 0.4.0 0.8.0 0.9.0 0.9.5 0.9.7 0.9.9 1.0 ● ● 3.60 3.5 ● 3.40 ● 3.0 ● 3.00 2.5 ● 2.10 2.0 ● ● 1.90 ● ● 1.70 ● 1.60 1.5 ● ● ● 1.50 Release size in mb Release size ● 1.40 ● ● 1.20 ● 1.10 1.0 ● 0.83 ● 0.73 ● ● 0.61 0.5 0.55 ● 0.29 ● 0.10 0.0 2002 2004 2006 2008 2010 Eddelbuettel and Nguyen RQuantLib The first Debian QuantLib package was prepared in May 2001 Boost has been a QuantLib requirement since July 2004 The long awaited QuantLib 1.0.0 release appeared in Feb 2010
    [Show full text]
  • Interest Rate Models
    Interest Rate Models Marco Marchioro www.marchioro.org October 6th, 2012 Advanced Derivatives, Interest Rate Models 2011, 2012 c Marco Marchioro Introduction to exotic derivatives 1 Details • Universit`adegli Studi di Milano-Bicocca • Facolt`adi Economia • Corso di laurea Magistrale in Economia e Finanza • Curriculum: Asset and Risk Management • Class: Advanced Derivatives • Module: Interest-Rate Models Advanced Derivatives, Interest Rate Models 2011, 2012 c Marco Marchioro Introduction to exotic derivatives 2 Lecture details • Every Saturday from October 1st to December 17th (2011) • From 8:45 am to 11:30am (15 mins break) • Usually in room U16-12 • Teaching-assistant sessions: not present, however, refer to Edit Rroji • Official class language: English (Italian also available if all stu- dents agree) Advanced Derivatives, Interest Rate Models 2011, 2012 c Marco Marchioro Introduction to exotic derivatives 3 Syllabus (1/2) Introduction • Introduction to exotic derivatives Interest rate derivatives • Linear interest-rate derivatives • Bootstrap of interest-rate term structures • Options on interest rates, caps/floors, and swaptions • Basic interest-rate models • Advanced interest-rate models • Libor Market Model Advanced Derivatives, Interest Rate Models 2011, 2012 c Marco Marchioro Introduction to exotic derivatives 4 Syllabus (2/2) Credit derivatives • Introduction to credit derivatives • Instruments with embedded credit risk Current topics • Crisis of 2007: multi-curve bootstrapping Advanced Derivatives, Interest Rate Models 2011, 2012
    [Show full text]
  • Derivatives Pricing Using Quantlib: an Introduction
    INDIAN INSTITUTE OF MANAGEMENT AHMEDABAD • INDIA Research and Publications Derivatives Pricing using QuantLib: An Introduction Jayanth R. Varma Vineet Virmani W.P. No. 2015-03-16 March 2015 The main objective of the Working Paper series of IIMA is to help faculty members, research staff, and doctoral students to speedily share their research findings with professional colleagues and to test out their research findings at the pre-publication stage. INDIAN INSTITUTE OF MANAGEMENT AHMEDABAD – 380015 INDIA W.P. No. 2015-03-16 Page No. 1 IIMA • INDIA Research and Publications Derivatives Pricing using QuantLib: An Introduction Jayanth R. Varma Vineet Virmani Abstract Given the complexity of over-the-counter derivatives and structured products, al- most all of derivatives pricing today is based on numerical methods. While large fi- nancial institutions typically have their own team of developers who maintain state- of-the-art financial libraries, till a few years ago none of that sophistication was avail- able for use in teaching and research. For the last decade„ there is now a reliable C++ open-source library available called QuantLib. This note introduces QuantLib for pricing derivatives and documents our experience using QuantLib in our course on Computational Finance at the Indian Institute of Management Ahmedabad. The fact that it is also available (and extendable) in Python has allowed us to harness the power of C++ with the ease of iPython notebooks in the classroom as well as for stu- dent’s projects. Keywords: Derivatives pricing, Financial engineering, Open-source computing, Python, QuantLib 1 Introduction Financial engineering and algorithmic trading are perhaps two of the most computation- ally intensive parts of all of finance.
    [Show full text]
  • Applied Quantitative Finance
    Applied Quantitative Finance Wolfgang H¨ardle Torsten Kleinow Gerhard Stahl In cooperation with G¨okhanAydınlı, Oliver Jim Blaskowitz, Song Xi Chen, Matthias Fengler, J¨urgenFranke, Christoph Frisch, Helmut Herwartz, Harriet Holzberger, Steffi H¨ose, Stefan Huschens, Kim Huynh, Stefan R. Jaschke, Yuze Jiang Pierre Kervella, R¨udigerKiesel, Germar Kn¨ochlein, Sven Knoth, Jens L¨ussem,Danilo Mercurio, Marlene M¨uller,J¨ornRank, Peter Schmidt, Rainer Schulz, J¨urgenSchumacher, Thomas Siegl, Robert Wania, Axel Werwatz, Jun Zheng June 20, 2002 Contents Preface xv Contributors xix Frequently Used Notation xxi I Value at Risk 1 1 Approximating Value at Risk in Conditional Gaussian Models 3 Stefan R. Jaschke and Yuze Jiang 1.1 Introduction . 3 1.1.1 The Practical Need . 3 1.1.2 Statistical Modeling for VaR . 4 1.1.3 VaR Approximations . 6 1.1.4 Pros and Cons of Delta-Gamma Approximations . 7 1.2 General Properties of Delta-Gamma-Normal Models . 8 1.3 Cornish-Fisher Approximations . 12 1.3.1 Derivation . 12 1.3.2 Properties . 15 1.4 Fourier Inversion . 16 iv Contents 1.4.1 Error Analysis . 16 1.4.2 Tail Behavior . 20 1.4.3 Inversion of the cdf minus the Gaussian Approximation 21 1.5 Variance Reduction Techniques in Monte-Carlo Simulation . 24 1.5.1 Monte-Carlo Sampling Method . 24 1.5.2 Partial Monte-Carlo with Importance Sampling . 28 1.5.3 XploRe Examples . 30 2 Applications of Copulas for the Calculation of Value-at-Risk 35 J¨ornRank and Thomas Siegl 2.1 Copulas . 36 2.1.1 Definition .
    [Show full text]
  • High Dimensional American Options
    High Dimensional American Options Neil Powell Firth Brasenose College University of Oxford A thesis submitted for the degree of Doctor of Philosophy Trinity Term 2005 I dedicate this thesis to my lovely wife Ruth. Acknowledgements I acknowledge the help of both my supervisors, Dr. Jeff Dewynne and Dr. William Shaw and thank them for their advice during my time in Oxford. Also, Dr. Sam Howison, Prof. Jon Chapman, Dr. Peter Carr, Dr. Ben Hambly, Dr. Peter Howell and Prof. Terry Lyons have spared time for helpful discussions. I especially thank Dr. Gregory Lieb for allowing me leave from Dresdner Kleinwort Wasserstein to complete this research. I would like to thank Dr. Bob Johnson and Prof. Peter Ross for their help, advice, and references over the years. Andy Dickinson provided useful ideas and many cups of tea. The EPSRC and Nomura International plc made this research possible by providing funding. Finally, I would like to thank my parents for their love and encouragement over the years, and my wife, Ruth, for her unfailing and invaluable love and support throughout the course of my research. Abstract Pricing single asset American options is a hard problem in mathematical finance. There are no closed form solutions available (apart from in the case of the perpetual option), so many approximations and numerical techniques have been developed. Pricing multi–asset (high dimensional) American options is still more difficult. We extend the method proposed theoretically by Glasserman and Yu (2004) by employing regression basis functions that are martingales under geometric Brownian motion. This results in more accurate Monte Carlo simulations, and computationally cheap lower and upper bounds to the American option price.
    [Show full text]
  • Derivatives Pricing Using Quantlib: an Introduction
    INDIAN INSTITUTE OF MANAGEMENT AHMEDABAD • INDIA Research and Publications Derivatives Pricing using QuantLib: An Introduction Jayanth R. Varma Vineet Virmani W.P. No. 2015-03-16 April 2015 The main objective of the Working Paper series of IIMA is to help faculty members, research staff, and doctoral students to speedily share their research findings with professional colleagues and to test out their research findings at the pre-publication stage. INDIAN INSTITUTE OF MANAGEMENT AHMEDABAD – 380015 INDIA W.P. No. 2015-03-16 Page No. 1 IIMA • INDIA Research and Publications Derivatives Pricing using QuantLib: An Introduction Jayanth R. Varma Vineet Virmani Abstract Given the complexity of over-the-counter derivatives and structured products, al- most all of derivatives pricing today is based on numerical methods. While large fi- nancial institutions typically have their own team of developers who maintain state- of-the-art financial libraries, till a few years ago none of that sophistication was avail- able for use in teaching and research. For the last decade„ there is now a reliable C++ open-source library available called QuantLib. This note introduces QuantLib for pricing derivatives and documents our experience using QuantLib in our course on Computational Finance at the Indian Institute of Management Ahmedabad. The fact that it is also available (and extendable) in Python has allowed us to harness the power of C++ with the ease of iPython notebooks in the classroom as well as for stu- dent’s projects. Keywords: Derivatives pricing, Financial engineering, Open-source computing, Python, QuantLib 1 Introduction Financial engineering and algorithmic trading are perhaps two of the most computation- ally intensive parts of all of finance.
    [Show full text]
  • Implementing Quantlib
    Implementing QuantLib Luigi Ballabio This book is for sale at http://leanpub.com/implementingquantlib This version was published on 2021-01-16 This is a Leanpub book. Leanpub empowers authors and publishers with the Lean Publishing process. Lean Publishing is the act of publishing an in-progress ebook using lightweight tools and many iterations to get reader feedback, pivot until you have the right book and build traction once you do. © 2014 - 2021 Luigi Ballabio Tweet This Book! Please help Luigi Ballabio by spreading the word about this book on Twitter! The suggested hashtag for this book is #quantlib. Find out what other people are saying about the book by clicking on this link to search for this hashtag on Twitter: #quantlib Also By Luigi Ballabio QuantLib Python Cookbook 构建 QuantLib Implementing QuantLib の和訳 Contents 1. Introduction ............................................... 1 2. Financial instruments and pricing engines ............................ 4 2.1 The Instrument class ..................................... 4 2.1.1 Interface and requirements ............................ 4 2.1.2 Implementation .................................. 5 2.1.3 Example: interest-rate swap ........................... 9 2.1.4 Further developments ............................... 13 2.2 Pricing engines ......................................... 13 2.2.1 Example: plain-vanilla option .......................... 20 A. Odds and ends ............................................... 26 Basic types ................................................. 26 Date calculations
    [Show full text]
  • Python for Computational Finance
    Python for computational finance Alvaro Leitao Rodriguez TU Delft - CWI June 24, 2016 Alvaro Leitao Rodriguez (TU Delft - CWI) Python for computational finance June 24, 2016 1 / 40 1 Why Python for computational finance? 2 QuantLib 3 Pandas Alvaro Leitao Rodriguez (TU Delft - CWI) Python for computational finance June 24, 2016 2 / 40 Why Python for computational finance? Everything we have already seen so far. Flexibility and interoperability. Huge python community. Widely used in financial institutions. Many mature financial libraries available. Alvaro Leitao Rodriguez (TU Delft - CWI) Python for computational finance June 24, 2016 3 / 40 QuantLib Open-source library. It is implemented in C++. Object-oriented paradigm. Bindings and extensions for many languages: Python, C#, Java, Perl, Ruby, Matlab/Octave, S-PLUS/R, Mathematica, Excel, etc. Widely used: d-fine, Quaternion, DZ BANK, Deloitte, Banca IMI, etc. Alvaro Leitao Rodriguez (TU Delft - CWI) Python for computational finance June 24, 2016 4 / 40 QuantLib - Advantages It is free!! Es gratis!! Het is gratis!! Source code available. Big community of programmers behind improving the library. For researchers (us), benchmark results and performance. Common framework. Avoid worries about basic implementations. Pre-build tools: Black-Scholes, Monte Carlo, PDEs, etc. Good starting point for object-oriented concepts. Alvaro Leitao Rodriguez (TU Delft - CWI) Python for computational finance June 24, 2016 5 / 40 QuantLib - Disadvantages Learning curve. Immature official documentation: only available for C++. Some inconsistencies between C++ and Python. Alvaro Leitao Rodriguez (TU Delft - CWI) Python for computational finance June 24, 2016 6 / 40 QuantLib - Python resources QuantLib Python examples. QuantLib Python Cookbook (June 2016) by Luigi Ballabio.
    [Show full text]
  • Quantlib.Jl Documentation Release 0.0.1
    QuantLib.jl Documentation Release 0.0.1 Chris Alexander Nov 12, 2018 Contents 1 Getting Started 3 1.1 Price a fixed rate bond..........................................3 1.2 Calculate the Survival Probability of a Credit Default Swap......................5 1.3 Price a Swaption Using a G2 Calibrated Model.............................6 2 CashFlow Types and Functions9 2.1 Basic CashFlow and Coupon Types and Methods............................9 2.2 Cash Flow Legs............................................. 11 3 Currencies 15 4 Index Types and Functions 17 4.1 General Interest Rate Index Methods.................................. 17 4.2 Ibor Index................................................ 17 4.3 Libor Index................................................ 18 4.4 Indexes Derived from Libor and Ibor.................................. 19 4.5 Swap Index................................................ 19 5 Instruments 21 5.1 Bonds................................................... 21 5.2 Forwards................................................. 24 5.3 Options.................................................. 25 5.4 Payoffs.................................................. 26 5.5 Swaps................................................... 26 5.6 Swaptions................................................ 28 6 Interest Rates 29 6.1 Compounding Types........................................... 30 6.2 Duration................................................. 30 7 Math Module 31 7.1 General Math methods.......................................... 31 7.2 Interpolation..............................................
    [Show full text]