instoptstock
Construct stock option
Syntax
Description
InstSet = instoptstock(OptSpec,Strike,Settle,ExerciseDates)
InstSet = instoptstock(___,AmericanOpt)AmericanOpt.
[
                lists field meta-data for the stock option instrument.FieldList,ClassList,TypeString] = instoptstock
Examples
Create an instrument set of two stock options with the following data:
OptSpec = {'put';'call'};
Strike = [95;98];
Settle = datetime(2012,5,1);
ExerciseDates = [datetime(2014,5,1) ; datetime(2015,5,1)];
AmericanOpt = [0;1];Create the stock option instruments.
InstSet = instoptstock(OptSpec, Strike,Settle, ExerciseDates, AmericanOpt)
InstSet = struct with fields:
        FinObj: 'Instruments'
    IndexTable: [1×1 struct]
          Type: {'OptStock'}
     FieldName: {{5×1 cell}}
    FieldClass: {{5×1 cell}}
     FieldData: {{5×1 cell}}
Display the instrument set.
instdisp(InstSet)
Index Type OptSpec Strike Settle ExerciseDates AmericanOpt 1 OptStock put 95 01-May-2012 01-May-2014 0 2 OptStock call 98 01-May-2012 01-May-2015 1
Input Arguments
Instrument variable, specified only when adding stock option instruments
                        to an existing instrument set. For more information on the
                            InstSet variable, see instget.
Data Types: struct
Definition of option, specified as a scalar  'call' or
                            'put' or an
                            NINST-by-1 cell array of character
                        vectors.
Data Types: char | cell
Option strike price value, specified with a scalar or an
                            NINST-by-1 or an
                            NINST-by-NSTRIKES depending on the
                        option type:
- For a European option, use an - NINST-by-- 1vector of strike prices.
- For a Bermuda option, use an - NINST-by-- NSTRIKESmatrix of strike prices. Each row is the schedule for one option. If an option has fewer than- NSTRIKESexercise opportunities, the end of the row is padded with- NaNs.
- For an American option, use an - NINST-by-- 1of strike prices.
Note
The interpretation of the Strike and
                                ExerciseDates arguments depends upon the
                            setting of the AmericanOpt argument. If
                                AmericanOpt = 0, NaN, or is
                            unspecified, the option is a European or Bermuda option. If
                                AmericanOpt = 1, the option is an American
                            option.
Data Types: double
Settlement date or trade date, specified as a scalar or an
                            NINST-by-1 vector using a datetime
                        array, string array, or date character vectors.
To support existing code, instoptstock also
    accepts serial date numbers as inputs, but they are not recommended.
Option exercise dates, specified as a scalar or an
                            NINST-by-1,NINST-by-2,
                        or an NINST-by-NSTRIKES vector using a
                        datetime array, string array, or date character vectors, depending on the
                        option type:
- For a European option, use an - NINST-by-- 1vector of dates. Each row is the schedule for one option. For a European option, there is only one- ExerciseDateson the option expiry date.
- For a Bermuda option, use an - NINST-by-- NSTRIKESvector of dates. Each row is the schedule for one option.
- For an American option, use an - NINST-by-- 2vector of exercise date boundaries. The option can be exercised on any date between or including the pair of dates on that row.
Note
The interpretation of the Strike and
                                    ExerciseDates arguments depends upon the
                                setting of the AmericanOpt argument. If
                                    AmericanOpt = 0, NaN, or
                                is unspecified, the option is a European or Bermuda option. If
                                    AmericanOpt = 1, the option is an American
                                option.
To support existing code, instoptstock also
    accepts serial date numbers as inputs, but they are not recommended.
(Optional) Option type, specified as a scalar or an
                            NINST-by-1 vector of integer flags
                        with values: 
- 0— European or Bermuda
- 1— American
Data Types: double
Output Arguments
Variable containing a collection of instruments, returned as a structure.
                        Instruments are broken down by type and each type can have different data
                        fields. Each stored data field has a row vector or string for each
                        instrument. For more information on the InstSet variable,
                        see instget.
Name of each data field for a stock option instrument, returned as an
                            NFIELDS-by-1 cell array of
                        character vectors.
Data class for each field, returned as an
                            NFIELDS-by-1 cell array of
                        character vectors. The class determines how arguments are parsed. Valid
                        character vectors are 'dble', 'date',
                        and 'char'. 
Type of instrument, returned as a character vector. For a stock option
                        instrument, TypeString = 'OptStock'.
More About
A vanilla option is a category of options that includes only the most standard components.
A vanilla option has an expiration date and straightforward strike price. American-style options and European-style options are both categorized as vanilla options.
The payoff for a vanilla option is as follows:
- For a call: 
- For a put: 
where:
St is the price of the underlying asset at time t.
K is the strike price.
For more information, see Vanilla Option.
Version History
Introduced before R2006aAlthough instoptstock supports serial date numbers,
                        datetime values are recommended instead. The
                        datetime data type provides flexible date and time
                formats, storage out to nanosecond precision, and properties to account for time
                zones and daylight saving time.
To convert serial date numbers or text to datetime values, use the datetime function. For example:
t = datetime(738427.656845093,"ConvertFrom","datenum"); y = year(t)
y =
        2021
There are no plans to remove support for serial date number inputs.
MATLAB Command
You clicked a link that corresponds to this MATLAB command:
Run the command by entering it in the MATLAB Command Window. Web browsers do not support MATLAB commands.
Seleccione un país/idioma
Seleccione un país/idioma para obtener contenido traducido, si está disponible, y ver eventos y ofertas de productos y servicios locales. Según su ubicación geográfica, recomendamos que seleccione: .
También puede seleccionar uno de estos países/idiomas:
Cómo obtener el mejor rendimiento
Seleccione China (en idioma chino o inglés) para obtener el mejor rendimiento. Los sitios web de otros países no están optimizados para ser accedidos desde su ubicación geográfica.
América
- América Latina (Español)
- Canada (English)
- United States (English)
Europa
- Belgium (English)
- Denmark (English)
- Deutschland (Deutsch)
- España (Español)
- Finland (English)
- France (Français)
- Ireland (English)
- Italia (Italiano)
- Luxembourg (English)
- Netherlands (English)
- Norway (English)
- Österreich (Deutsch)
- Portugal (English)
- Sweden (English)
- Switzerland
- United Kingdom (English)